diff options
author | Artur Signell <artur@vaadin.com> | 2012-08-30 17:24:36 +0300 |
---|---|---|
committer | Artur Signell <artur@vaadin.com> | 2012-08-30 17:24:36 +0300 |
commit | 7b25b3886ea95bc6495506fbe9472e45fcbde684 (patch) | |
tree | 0b93cb65dab437feb46720659a63b8f1ef48f7f4 /uitest/src/com/vaadin/tests/tickets/Ticket1900.java | |
parent | 8941056349e302e687e40e94c13709e75f256d73 (diff) | |
download | vaadin-framework-7b25b3886ea95bc6495506fbe9472e45fcbde684.tar.gz vaadin-framework-7b25b3886ea95bc6495506fbe9472e45fcbde684.zip |
Renamed tests -> uitest and tests/testbench -> uitest/src (#9299)
Diffstat (limited to 'uitest/src/com/vaadin/tests/tickets/Ticket1900.java')
-rw-r--r-- | uitest/src/com/vaadin/tests/tickets/Ticket1900.java | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/uitest/src/com/vaadin/tests/tickets/Ticket1900.java b/uitest/src/com/vaadin/tests/tickets/Ticket1900.java new file mode 100644 index 0000000000..136af23474 --- /dev/null +++ b/uitest/src/com/vaadin/tests/tickets/Ticket1900.java @@ -0,0 +1,74 @@ +package com.vaadin.tests.tickets; + +import com.vaadin.Application; +import com.vaadin.data.Property; +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Validator; +import com.vaadin.ui.UI.LegacyWindow; +import com.vaadin.ui.TextField; + +public class Ticket1900 extends Application.LegacyApplication { + + TextField f[] = new TextField[5]; + LegacyWindow main = new LegacyWindow("#1900 test"); + + @Override + public void init() { + + setMainWindow(main); + + for (int i = 0; i < 5; i++) { + final int j = i; + f[i] = new TextField("Testcase " + i); + f[i].setImmediate(true); + f[i].setRequired(true); + main.addComponent(f[i]); + f[i].addListener(new Property.ValueChangeListener() { + @Override + public void valueChange(ValueChangeEvent event) { + main.showNotification("Validity test", "Testcase " + j + + " is " + (f[j].isValid() ? "valid" : "invalid")); + } + }); + f[i].addValidator(new ContainsValidator("1")); + f[i].addValidator(new ContainsValidator("2")); + + } + + f[0].setDescription("Field is empty, requiredError(null): *"); + + f[1].setDescription("Field is empty, requiredError(\"foo\"): * (popup shows the validation error)"); + f[1].setRequiredError("The field must not be empty"); + + f[2].setDescription("Field is non-empty, validators do not give validation error: *"); + f[2].setValue("valid 12"); + + f[3].setDescription("Field is non-empty, requiredError(null), validators " + + "give validation error: * ! (popup shows the validation error)"); + f[3].setValue("invalid"); + + f[4].setDescription("Field is non-empty, requiredError(\"foo\"), validators " + + "give validation error: * ! (popup shows the validation error)"); + f[4].setValue("invalid"); + f[4].setRequiredError("The field must not be empty"); + + } + + static class ContainsValidator implements Validator { + private final String c; + + public ContainsValidator(String c) { + this.c = c; + } + + @Override + public void validate(Object value) throws InvalidValueException { + if (value == null || !value.toString().contains(c)) { + throw new InvalidValueException("Value does not contain " + c); + } + + } + + } + +} |