[Lada-commits] [PATCH] Remove wrong period check

Wald Commits scm-commit at wald.intevation.org
Fri Sep 23 17:56:56 CEST 2016


# HG changeset patch
# User Tom Gottfried <tom at intevation.de>
# Date 1474646182 -7200
# Node ID 3c9616e5439ff90d01aa513d743960c20e7e9898
# Parent  a7404bf577fd0168715dbafdd9bf0d133ab32c36
Remove wrong period check.

The validity period can be e.g. from November till February,
thus spanning over turn of the year and allowing a from value
greater than to value (in terms of day of year).

diff -r a7404bf577fd -r 3c9616e5439f db_schema/lada_schema.sql
--- a/db_schema/lada_schema.sql	Thu Sep 22 16:14:57 2016 +0200
+++ b/db_schema/lada_schema.sql	Fri Sep 23 17:56:22 2016 +0200
@@ -583,13 +583,12 @@
     teilintervall_von integer NOT NULL,
     teilintervall_bis integer NOT NULL,
     intervall_offset integer,
-    gueltig_von integer NOT NULL,
-    gueltig_bis integer NOT NULL,
+    gueltig_von integer NOT NULL CHECK(gueltig_von BETWEEN 0 AND 364),
+    gueltig_bis integer NOT NULL CHECK(gueltig_bis BETWEEN 0 AND 364),
     probe_nehmer_id integer,
     probe_kommentar character varying(80),
     letzte_aenderung timestamp without time zone DEFAULT now() NOT NULL,
-    CHECK (teilintervall_von <= teilintervall_bis),
-    CHECK (gueltig_von <= gueltig_bis)
+    CHECK (teilintervall_von <= teilintervall_bis)
 );
 CREATE TRIGGER letzte_aenderung_messprogramm BEFORE UPDATE ON messprogramm FOR EACH ROW EXECUTE PROCEDURE update_letzte_aenderung();
 
diff -r a7404bf577fd -r 3c9616e5439f src/main/java/de/intevation/lada/validation/rules/messprogramm/ValidFromTo.java
--- a/src/main/java/de/intevation/lada/validation/rules/messprogramm/ValidFromTo.java	Thu Sep 22 16:14:57 2016 +0200
+++ b/src/main/java/de/intevation/lada/validation/rules/messprogramm/ValidFromTo.java	Fri Sep 23 17:56:22 2016 +0200
@@ -19,17 +19,27 @@
 @ValidationRule("Messprogramm")
 public class ValidFromTo implements Rule {
 
+    private static final int DOY_MIN = 0;
+
+    // Leap years should be handled in generation of Probe objects
+    private static final int DOY_MAX = 364;
+
     @Override
     public Violation execute(Object object) {
         Messprogramm messprogramm = (Messprogramm)object;
         Violation violation = new Violation();
 
         if (messprogramm.getGueltigVon() != null
-            && messprogramm.getGueltigBis() != null
-            && messprogramm.getGueltigVon() > messprogramm.getGueltigBis()) {
-            violation.addError("gueltigVon", 662);
-            violation.addError("gueltigBis", 662);
-        }
+            && (messprogramm.getGueltigVon() < DOY_MIN
+                || messprogramm.getGueltigVon() > DOY_MAX)) {
+                violation.addError("gueltigVon", 612);
+            }
+
+        if (messprogramm.getGueltigBis() != null
+            && (messprogramm.getGueltigBis() < DOY_MIN
+                || messprogramm.getGueltigBis() > DOY_MAX)) {
+                violation.addError("gueltigBis", 612);
+            }
 
         return violation.hasErrors()
             ? violation


More information about the Lada-commits mailing list