mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2025-01-09 21:17:59 +01:00
Remove ValidateElement.EmptyValidateElement
because it has the same semantic as BasicValidateElement.
This commit is contained in:
parent
c770b12348
commit
d78b39d117
3 changed files with 9 additions and 33 deletions
|
@ -117,32 +117,6 @@ public abstract class ValidateElement implements PacketExtension {
|
||||||
*/
|
*/
|
||||||
public abstract void checkConsistency(FormField formField);
|
public abstract void checkConsistency(FormField formField);
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* This defines the empty validate element that does only specify a 'datatype' attribute.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public static class EmptyValidateElement extends ValidateElement {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param dataType
|
|
||||||
* @see #getDatatype()
|
|
||||||
*/
|
|
||||||
public EmptyValidateElement(String dataType) {
|
|
||||||
super(dataType);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void appendXML(XmlStringBuilder buf) {
|
|
||||||
// The empty validate element does not contain any further elements or text, it is empty.
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void checkConsistency(FormField formField) {
|
|
||||||
// Since we can't know all possible datatypes, we can not perform any validation here
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Validation only against the datatype itself. Indicates that the value(s) should simply match the field type and
|
* Validation only against the datatype itself. Indicates that the value(s) should simply match the field type and
|
||||||
* datatype constraints.
|
* datatype constraints.
|
||||||
|
|
|
@ -22,7 +22,6 @@ import java.util.logging.Logger;
|
||||||
import org.jivesoftware.smack.util.ParserUtils;
|
import org.jivesoftware.smack.util.ParserUtils;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.BasicValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.BasicValidateElement;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.EmptyValidateElement;
|
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.ListRange;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.ListRange;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.OpenValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.OpenValidateElement;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.RangeValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.RangeValidateElement;
|
||||||
|
@ -81,7 +80,9 @@ public class DataValidationProvider {
|
||||||
case XmlPullParser.END_TAG:
|
case XmlPullParser.END_TAG:
|
||||||
if (parser.getDepth() == initialDepth) {
|
if (parser.getDepth() == initialDepth) {
|
||||||
if (dataValidation == null) {
|
if (dataValidation == null) {
|
||||||
dataValidation = new EmptyValidateElement(dataType);
|
// XEP-122 § 3.2 states that "If no validation method is specified,
|
||||||
|
// form processors MUST assume <basic/> validation."
|
||||||
|
dataValidation = new BasicValidateElement(dataType);
|
||||||
}
|
}
|
||||||
dataValidation.setListRange(listRange);
|
dataValidation.setListRange(listRange);
|
||||||
break outerloop;
|
break outerloop;
|
||||||
|
|
|
@ -25,7 +25,7 @@ import java.io.IOException;
|
||||||
import org.jivesoftware.smack.SmackException;
|
import org.jivesoftware.smack.SmackException;
|
||||||
import org.jivesoftware.smack.test.util.TestUtils;
|
import org.jivesoftware.smack.test.util.TestUtils;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.EmptyValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.BasicValidateElement;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.ListRange;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.ListRange;
|
||||||
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.RangeValidateElement;
|
import org.jivesoftware.smackx.xdatavalidation.packet.ValidateElement.RangeValidateElement;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -38,7 +38,8 @@ import org.xmlpull.v1.XmlPullParserException;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class DataValidationTest {
|
public class DataValidationTest {
|
||||||
private static final String TEST_OUTPUT_MIN = "<validate xmlns='http://jabber.org/protocol/xdata-validate'></validate>";
|
private static final String TEST_INPUT_MIN = "<validate xmlns='http://jabber.org/protocol/xdata-validate'></validate>";
|
||||||
|
private static final String TEST_OUTPUT_MIN = "<validate xmlns='http://jabber.org/protocol/xdata-validate'><basic/></validate>";
|
||||||
private static final String TEST_OUTPUT_RANGE = "<validate xmlns='http://jabber.org/protocol/xdata-validate' datatype='xs:string'><range min='min-val' max='max-val'/><list-range min='111' max='999'/></validate>";
|
private static final String TEST_OUTPUT_RANGE = "<validate xmlns='http://jabber.org/protocol/xdata-validate' datatype='xs:string'><range min='min-val' max='max-val'/><list-range min='111' max='999'/></validate>";
|
||||||
private static final String TEST_OUTPUT_RANGE2 = "<validate xmlns='http://jabber.org/protocol/xdata-validate'><range/></validate>";
|
private static final String TEST_OUTPUT_RANGE2 = "<validate xmlns='http://jabber.org/protocol/xdata-validate'><range/></validate>";
|
||||||
private static final String TEST_OUTPUT_FAIL = "<validate xmlns='http://jabber.org/protocol/xdata-validate'><list-range min='1-1-1' max='999'/></validate>";
|
private static final String TEST_OUTPUT_FAIL = "<validate xmlns='http://jabber.org/protocol/xdata-validate'><list-range min='1-1-1' max='999'/></validate>";
|
||||||
|
@ -46,19 +47,19 @@ public class DataValidationTest {
|
||||||
@Test
|
@Test
|
||||||
public void testMin() throws XmlPullParserException, IOException, SmackException {
|
public void testMin() throws XmlPullParserException, IOException, SmackException {
|
||||||
|
|
||||||
ValidateElement dv = new EmptyValidateElement(null);
|
ValidateElement dv = new BasicValidateElement(null);
|
||||||
|
|
||||||
assertNotNull( dv.toXML());
|
assertNotNull( dv.toXML());
|
||||||
String output = dv.toXML().toString();
|
String output = dv.toXML().toString();
|
||||||
assertEquals(TEST_OUTPUT_MIN, output);
|
assertEquals(TEST_OUTPUT_MIN, output);
|
||||||
|
|
||||||
XmlPullParser parser = getParser(output);
|
XmlPullParser parser = getParser(TEST_INPUT_MIN);
|
||||||
|
|
||||||
dv = DataValidationProvider.parse(parser);
|
dv = DataValidationProvider.parse(parser);
|
||||||
|
|
||||||
assertNotNull(dv);
|
assertNotNull(dv);
|
||||||
assertEquals("xs:string", dv.getDatatype());
|
assertEquals("xs:string", dv.getDatatype());
|
||||||
assertTrue( dv instanceof EmptyValidateElement);
|
assertTrue( dv instanceof BasicValidateElement);
|
||||||
|
|
||||||
assertNotNull( dv.toXML());
|
assertNotNull( dv.toXML());
|
||||||
output = dv.toXML().toString();
|
output = dv.toXML().toString();
|
||||||
|
|
Loading…
Reference in a new issue