changeset 1151:7a9bc3fe0efd

Moved probe validation to have all subobject available during validation.
author Raimund Renkert <raimund.renkert@intevation.de>
date Mon, 07 Nov 2016 12:30:35 +0100 (2016-11-07)
parents cf1eb19f896b
children b81a515f765d
files src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java
diffstat 1 files changed, 12 insertions(+), 14 deletions(-) [+]
line wrap: on
line diff
--- a/src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java	Mon Nov 07 11:06:23 2016 +0100
+++ b/src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java	Mon Nov 07 12:30:35 2016 +0100
@@ -152,12 +152,6 @@
             if(i == Identified.UPDATE) {
                 merger.merge(old, probe);
                 newProbe = old;
-                Violation violation = probeValidator.validate(newProbe);
-                for (Entry<String, List<Integer>> warn : violation.getWarnings().entrySet()) {
-                    for (Integer code : warn.getValue()) {
-                        currentWarnings.add(new ReportItem("validation", warn.getKey(), code));
-                    }
-                }
             }
             // Probe was found but some data does not match
             else if(i == Identified.REJECT){
@@ -179,15 +173,13 @@
             // It is a brand new probe!
             else if(i == Identified.NEW){
                 Violation violation = probeValidator.validate(probe);
-                for (Entry<String, List<Integer>> err : violation.getErrors().entrySet()) {
-                    for (Integer code : err.getValue()) {
-                        currentErrors.add(new ReportItem("validation", err.getKey(), code));
+                if (violation.hasErrors()) {
+                    for (Entry<String, List<Integer>> err : violation.getErrors().entrySet()) {
+                        for (Integer code : err.getValue()) {
+                            currentErrors.add(new ReportItem("validation", err.getKey(), code));
+                        }
                     }
-                }
-                for (Entry<String, List<Integer>> warn : violation.getWarnings().entrySet()) {
-                    for (Integer code : warn.getValue()) {
-                        currentWarnings.add(new ReportItem("validation", warn.getKey(), code));
-                    }
+                    return;
                 }
                 Response created = repository.create(probe, "land");
                 newProbe = ((Probe)created.getData());
@@ -252,6 +244,12 @@
         for (int i = 0; i < object.getMessungen().size(); i++) {
             create(object.getMessungen().get(i), newProbe.getId(), newProbe.getMstId());
         }
+        Violation violation = probeValidator.validate(newProbe);
+        for (Entry<String, List<Integer>> warn : violation.getWarnings().entrySet()) {
+            for (Integer code : warn.getValue()) {
+                currentWarnings.add(new ReportItem("validation", warn.getKey(), code));
+            }
+        }
         if (currentErrors.size() > 0) {
             errors.put(object.getIdentifier(),
                 new ArrayList<ReportItem>(currentErrors));
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)