You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@struts.apache.org by lu...@apache.org on 2013/03/18 13:28:12 UTC

svn commit: r1457733 - in /struts/struts2/trunk/xwork-core/src: main/java/com/opensymphony/xwork2/validator/ main/java/com/opensymphony/xwork2/validator/annotations/ test/java/com/opensymphony/xwork2/validator/

Author: lukaszlenart
Date: Mon Mar 18 12:28:12 2013
New Revision: 1457733

URL: http://svn.apache.org/r1457733
Log:
WW-4011 Improves ShortRangeFieldValidator annotation to match ShortRangeFieldValidator class

Modified:
    struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilder.java
    struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/annotations/ShortRangeFieldValidator.java
    struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationAction.java
    struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilderTest.java
    struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationExpAction.java

Modified: struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilder.java
URL: http://svn.apache.org/viewvc/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilder.java?rev=1457733&r1=1457732&r2=1457733&view=diff
==============================================================================
--- struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilder.java (original)
+++ struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilder.java Mon Mar 18 12:28:12 2013
@@ -680,12 +680,18 @@ public class AnnotationValidationConfigu
             params.put("fieldName", v.fieldName());
         }
 
-        if (v.min() != null && v.min().length() > 0) {
+        if (StringUtils.isNotEmpty(v.min())) {
             params.put("min", v.min());
         }
-        if (v.max() != null && v.max().length() > 0) {
+        if (StringUtils.isNotEmpty(v.max())) {
             params.put("max", v.max());
         }
+        if (StringUtils.isNotEmpty(v.maxExpression())) {
+            params.put("maxExpression", v.maxExpression());
+        }
+        if (StringUtils.isNotEmpty(v.minExpression())) {
+            params.put("minExpression", v.minExpression());
+        }
 
         validatorFactory.lookupRegisteredValidatorType(validatorType);
         return new ValidatorConfig.Builder(validatorType)
@@ -694,6 +700,7 @@ public class AnnotationValidationConfigu
                 .shortCircuit(v.shortCircuit())
                 .defaultMessage(v.message())
                 .messageKey(v.key())
+                .messageParams(v.messageParams())
                 .build();
     }
 

Modified: struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/annotations/ShortRangeFieldValidator.java
URL: http://svn.apache.org/viewvc/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/annotations/ShortRangeFieldValidator.java?rev=1457733&r1=1457732&r2=1457733&view=diff
==============================================================================
--- struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/annotations/ShortRangeFieldValidator.java (original)
+++ struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/annotations/ShortRangeFieldValidator.java Mon Mar 18 12:28:12 2013
@@ -56,6 +56,12 @@ import java.lang.annotation.Target;
  * <td class='confluenceTd'>i18n key from language specific properties file.</td>
  * </tr>
  * <tr>
+ * <td class='confluenceTd'>messageParams</td>
+ * <td class='confluenceTd'>no</td>
+ * <td class='confluenceTd'>&nbsp;</td>
+ * <td class='confluenceTd'>Additional params to be used to customize message - will be evaluated against the Value Stack</td>
+ * </tr>
+ * <tr>
  * <td class='confluenceTd'>fieldName</td>
  * <td class='confluenceTd'>no</td>
  * <td class='confluenceTd'>&nbsp;</td>
@@ -114,16 +120,26 @@ import java.lang.annotation.Target;
 public @interface ShortRangeFieldValidator {
 
     /**
-     *  Integer property. The minimum the number must be.
+     * Short property. The minimum the number must be.
      */
     String min() default "";
 
     /**
-     *  Integer property. The maximum number can be.
+     * The minimum the number must be defined as an expression.
+     */
+    String minExpression() default "";
+
+    /**
+     *  Short property. The maximum number can be.
      */
     String max() default "";
 
     /**
+     * The maximum number can be defined as an expression
+     */
+    String maxExpression() default "";
+
+    /**
      * The default error message for this validator.
      * NOTE: It is required to set a message, if you are not using the message key for 18n lookup!
      */
@@ -135,6 +151,11 @@ public @interface ShortRangeFieldValidat
     String key() default "";
 
     /**
+     * Additional params to be used to customize message - will be evaluated against the Value Stack
+     */
+    String[] messageParams() default {};
+
+    /**
      * The optional fieldName for SIMPLE validator types.
      */
     String fieldName() default "";

Modified: struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationAction.java
URL: http://svn.apache.org/viewvc/struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationAction.java?rev=1457733&r1=1457732&r2=1457733&view=diff
==============================================================================
--- struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationAction.java (original)
+++ struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationAction.java Mon Mar 18 12:28:12 2013
@@ -13,6 +13,7 @@ import com.opensymphony.xwork2.validator
 import com.opensymphony.xwork2.validator.annotations.RegexFieldValidator;
 import com.opensymphony.xwork2.validator.annotations.RequiredFieldValidator;
 import com.opensymphony.xwork2.validator.annotations.RequiredStringValidator;
+import com.opensymphony.xwork2.validator.annotations.ShortRangeFieldValidator;
 import com.opensymphony.xwork2.validator.annotations.ValidationParameter;
 
 /**
@@ -51,6 +52,8 @@ public class AnnotationValidationAction 
             messageParams = {"one", "two", "three"}, shortCircuit = true)
     @RequiredStringValidator(fieldName = "foo", key = "requiredstring.key", message = "Foo is required!",
             messageParams = {"one", "two", "three"}, shortCircuit = true, trim = false)
+    @ShortRangeFieldValidator(fieldName = "foo", key = "short.key", message = "Foo is out of range!", min = "1", max = "10",
+            messageParams = {"one", "two", "three"}, shortCircuit = true)
     public String execute() {
         return SUCCESS;
     }

Modified: struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilderTest.java
URL: http://svn.apache.org/viewvc/struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilderTest.java?rev=1457733&r1=1457732&r2=1457733&view=diff
==============================================================================
--- struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilderTest.java (original)
+++ struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationConfigurationBuilderTest.java Mon Mar 18 12:28:12 2013
@@ -25,6 +25,7 @@ import com.opensymphony.xwork2.validator
 import com.opensymphony.xwork2.validator.validators.RegexFieldValidator;
 import com.opensymphony.xwork2.validator.validators.RequiredFieldValidator;
 import com.opensymphony.xwork2.validator.validators.RequiredStringValidator;
+import com.opensymphony.xwork2.validator.validators.ShortRangeFieldValidator;
 
 import java.text.ParseException;
 import java.text.SimpleDateFormat;
@@ -46,7 +47,7 @@ public class AnnotationValidationConfigu
         List<Validator> validators = manager.getValidators(AnnotationValidationAction.class, null);
 
         // then
-        assertEquals(validators.size(), 12);
+        assertEquals(validators.size(), 13);
         for (Validator validator : validators) {
             validate(validator);
         }
@@ -63,7 +64,7 @@ public class AnnotationValidationConfigu
         ValueStack valueStack = container.getInstance(ValueStackFactory.class).createValueStack();
         valueStack.push(new AnnotationValidationExpAction());
 
-        assertEquals(validators.size(), 12);
+        assertEquals(validators.size(), 13);
         for (Validator validator : validators) {
             validator.setValueStack(valueStack);
             validate(validator);
@@ -95,9 +96,21 @@ public class AnnotationValidationConfigu
             validateRequiredFieldValidator((RequiredFieldValidator) validator);
         } else if (validator.getValidatorType().equals("requiredstring")) {
             validateRequiredStringValidator((RequiredStringValidator) validator);
+        }else if (validator.getValidatorType().equals("short")) {
+            validateShortRangeFieldValidator((ShortRangeFieldValidator) validator);
         }
     }
 
+    private void validateShortRangeFieldValidator(ShortRangeFieldValidator validator) {
+        assertEquals("foo", validator.getFieldName());
+        assertEquals("Foo is out of range!", validator.getDefaultMessage());
+        assertEquals("short.key", validator.getMessageKey());
+        assertTrue(Arrays.equals(new String[]{"one", "two", "three"}, validator.getMessageParameters()));
+        assertEquals(Short.valueOf("10"), validator.getMax());
+        assertEquals(Short.valueOf("1"), validator.getMin());
+        assertEquals(true, validator.isShortCircuit());
+    }
+
     private void validateRequiredStringValidator(RequiredStringValidator validator) {
         assertEquals("foo", validator.getFieldName());
         assertEquals("requiredstring.key", validator.getMessageKey());

Modified: struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationExpAction.java
URL: http://svn.apache.org/viewvc/struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationExpAction.java?rev=1457733&r1=1457732&r2=1457733&view=diff
==============================================================================
--- struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationExpAction.java (original)
+++ struts/struts2/trunk/xwork-core/src/test/java/com/opensymphony/xwork2/validator/AnnotationValidationExpAction.java Mon Mar 18 12:28:12 2013
@@ -13,6 +13,7 @@ import com.opensymphony.xwork2.validator
 import com.opensymphony.xwork2.validator.annotations.RegexFieldValidator;
 import com.opensymphony.xwork2.validator.annotations.RequiredFieldValidator;
 import com.opensymphony.xwork2.validator.annotations.RequiredStringValidator;
+import com.opensymphony.xwork2.validator.annotations.ShortRangeFieldValidator;
 import com.opensymphony.xwork2.validator.annotations.ValidationParameter;
 
 import java.text.ParseException;
@@ -57,6 +58,9 @@ public class AnnotationValidationExpActi
             messageParams = {"one", "two", "three"}, shortCircuit = true)
     @RequiredStringValidator(fieldName = "foo", key = "requiredstring.key", message = "Foo is required!",
             messageParams = {"one", "two", "three"}, shortCircuit = true, trim = false)
+    @ShortRangeFieldValidator(fieldName = "foo", key = "short.key", message = "Foo is out of range!",
+            minExpression = "${shortMin}", maxExpression = "${shortMax}",
+            messageParams = {"one", "two", "three"}, shortCircuit = true)
     public String execute() {
         return SUCCESS;
     }
@@ -105,4 +109,12 @@ public class AnnotationValidationExpActi
         return 1;
     }
 
+    public short getShortMin() {
+        return 1;
+    }
+
+    public short getShortMax() {
+        return 10;
+    }
+
 }