Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(758)

Side by Side Diff: LayoutTests/fast/forms/number/number-valueasnumber.html

Issue 172223003: Input type Number maximum value increase (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 <!DOCTYPE html> 1 <!DOCTYPE html>
2 <html> 2 <html>
3 <head> 3 <head>
4 <script src="../../../resources/js-test.js"></script> 4 <script src="../../../resources/js-test.js"></script>
5 </head> 5 </head>
6 <body> 6 <body>
7 <script> 7 <script>
8 description('Tests for .valueAsNumber with &lt;input type=number>.'); 8 description('Tests for .valueAsNumber with &lt;input type=number>.');
9 9
10 var input = document.createElement('input'); 10 var input = document.createElement('input');
(...skipping 12 matching lines...) Expand all
23 shouldBe('valueAsNumberFor("0")', '0'); 23 shouldBe('valueAsNumberFor("0")', '0');
24 shouldBe('valueAsNumberFor("0.2")', '0.2'); 24 shouldBe('valueAsNumberFor("0.2")', '0.2');
25 shouldBe('valueAsNumberFor(".2")', '0.2'); 25 shouldBe('valueAsNumberFor(".2")', '0.2');
26 shouldBe('valueAsNumberFor("10")', '10'); 26 shouldBe('valueAsNumberFor("10")', '10');
27 shouldBe('valueAsNumberFor("01")', '1'); 27 shouldBe('valueAsNumberFor("01")', '1');
28 shouldBe('valueAsNumberFor("-0")', '0'); // "-0" is 0 in HTML5. 28 shouldBe('valueAsNumberFor("-0")', '0'); // "-0" is 0 in HTML5.
29 shouldBe('valueAsNumberFor("-1.2")', '-1.2'); 29 shouldBe('valueAsNumberFor("-1.2")', '-1.2');
30 shouldBe('valueAsNumberFor("1.2E10")', '1.2E10'); 30 shouldBe('valueAsNumberFor("1.2E10")', '1.2E10');
31 shouldBe('valueAsNumberFor("1.2E-10")', '1.2E-10'); 31 shouldBe('valueAsNumberFor("1.2E-10")', '1.2E-10');
32 shouldBe('valueAsNumberFor("1.2E+10")', '1.2E10'); 32 shouldBe('valueAsNumberFor("1.2E+10")', '1.2E10');
33 shouldBe('valueAsNumberFor("123456789012345678901234567890123456789")', '1.23456 78901234568E+38'); 33 shouldBe('valueAsNumberFor("1234567890123456789012345678901234567890123456789012 34567890123456789012345678901234567890123456789012345678901234567890123456789012 34567890123456789012345678901234567890123456789012345678901234567890123456789012 34567890123456789012345678901234567890123456789012345678901234567890123456789012 34567890123456789")', '1.2345678901234568E+308');
34 shouldBe('valueAsNumberFor("0.12345678901234567890123456789012345678901234567890 ")', '0.123456789012345678'); 34 shouldBe('valueAsNumberFor("0.12345678901234567890123456789012345678901234567890 ")', '0.123456789012345678');
35 35
36 debug('valueAsNumber for invalid string values:'); 36 debug('valueAsNumber for invalid string values:');
37 shouldBeTrue('isNaN(valueAsNumberFor(""))'); 37 shouldBeTrue('isNaN(valueAsNumberFor(""))');
38 shouldBeTrue('isNaN(valueAsNumberFor("abc"))'); 38 shouldBeTrue('isNaN(valueAsNumberFor("abc"))');
39 shouldBeTrue('isNaN(valueAsNumberFor("0xff"))'); 39 shouldBeTrue('isNaN(valueAsNumberFor("0xff"))');
40 shouldBeTrue('isNaN(valueAsNumberFor("+1"))'); 40 shouldBeTrue('isNaN(valueAsNumberFor("+1"))');
41 shouldBeTrue('isNaN(valueAsNumberFor(" 10"))'); 41 shouldBeTrue('isNaN(valueAsNumberFor(" 10"))');
42 shouldBeTrue('isNaN(valueAsNumberFor("10 "))'); 42 shouldBeTrue('isNaN(valueAsNumberFor("10 "))');
43 shouldBeTrue('isNaN(valueAsNumberFor("."))'); 43 shouldBeTrue('isNaN(valueAsNumberFor("."))');
44 shouldBeTrue('isNaN(valueAsNumberFor("1E"))'); 44 shouldBeTrue('isNaN(valueAsNumberFor("1E"))');
45 shouldBeTrue('isNaN(valueAsNumberFor("NaN"))'); 45 shouldBeTrue('isNaN(valueAsNumberFor("NaN"))');
46 shouldBeTrue('isNaN(valueAsNumberFor("nan"))'); 46 shouldBeTrue('isNaN(valueAsNumberFor("nan"))');
47 shouldBeTrue('isNaN(valueAsNumberFor("Inf"))'); 47 shouldBeTrue('isNaN(valueAsNumberFor("Inf"))');
48 shouldBeTrue('isNaN(valueAsNumberFor("inf"))'); 48 shouldBeTrue('isNaN(valueAsNumberFor("inf"))');
49 shouldBeTrue('isNaN(valueAsNumberFor("Infinity"))'); 49 shouldBeTrue('isNaN(valueAsNumberFor("Infinity"))');
50 shouldBeTrue('isNaN(valueAsNumberFor("infinity"))'); 50 shouldBeTrue('isNaN(valueAsNumberFor("infinity"))');
51 51
52 debug('Too huge exponent to support'); 52 debug('Too huge exponent to support');
53 shouldBeTrue('isNaN(valueAsNumberFor("1.2E65535"))'); 53 shouldBeTrue('isNaN(valueAsNumberFor("1.2E65535"))');
54 54
55 debug('Tests for the valueAsNumber setter:'); 55 debug('Tests for the valueAsNumber setter:');
56 shouldBeEqualToString('setValueAsNumberAndGetValue(0)', '0'); 56 shouldBeEqualToString('setValueAsNumberAndGetValue(0)', '0');
57 shouldBeEqualToString('setValueAsNumberAndGetValue(10)', '10'); 57 shouldBeEqualToString('setValueAsNumberAndGetValue(10)', '10');
58 shouldBeEqualToString('setValueAsNumberAndGetValue(01)', '1'); 58 shouldBeEqualToString('setValueAsNumberAndGetValue(01)', '1');
59 shouldBeEqualToString('setValueAsNumberAndGetValue(-0)', '0'); 59 shouldBeEqualToString('setValueAsNumberAndGetValue(-0)', '0');
60 shouldBeEqualToString('setValueAsNumberAndGetValue(-1.2)', '-1.2'); 60 shouldBeEqualToString('setValueAsNumberAndGetValue(-1.2)', '-1.2');
61 shouldBeEqualToString('setValueAsNumberAndGetValue(1.2e10)', '12000000000'); 61 shouldBeEqualToString('setValueAsNumberAndGetValue(1.2e10)', '12000000000');
62 shouldBeEqualToString('setValueAsNumberAndGetValue(1.2e-10)', '1.2e-10'); 62 shouldBeEqualToString('setValueAsNumberAndGetValue(1.2e-10)', '1.2e-10');
63 shouldBeEqualToString('setValueAsNumberAndGetValue(1.2345678901234567e+38)', '1. 2345678901234567e+38'); 63 shouldBeEqualToString('setValueAsNumberAndGetValue(1.2345678901234567e+308)', '1 .2345678901234567e+308');
64 shouldBeEqualToString('setValueAsNumberAndGetValue("-3.40282346e+38")', '-3.4028 2346e+38'); 64 shouldBeEqualToString('setValueAsNumberAndGetValue("-1.797693134862315e+308")', '-1.797693134862315e+308');
65 shouldThrow('setValueAsNumberAndGetValue("-3.40282348e+38")', '"InvalidStateErro r: Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The val ue provided (-3.40282e+38) is outside the range (-3.40282e+38, 3.40282e+38)."'); 65 shouldThrow('setValueAsNumberAndGetValue("-1.797693134862316e+308")', '"TypeErro r: Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The val ue provided is infinite."');
66 shouldBe('setValueAsNumberAndGetValue("3.40282346e+38")', '"3.40282346e+38"'); 66 shouldBe('setValueAsNumberAndGetValue("1.797693134862315e+308")', '"1.7976931348 62315e+308"');
67 shouldThrow('setValueAsNumberAndGetValue("3.40282348e+38")', '"InvalidStateError : Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The valu e provided (3.40282e+38) is outside the range (-3.40282e+38, 3.40282e+38)."'); 67 shouldThrow('setValueAsNumberAndGetValue("1.797693134862316e+308")', '"TypeError : Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The valu e provided is infinite."');
68 68
69 debug('Tests to set invalid values to valueAsNumber:'); 69 debug('Tests to set invalid values to valueAsNumber:');
70 shouldBeEqualToString('setValueAsNumberAndGetValue(null)', '0'); 70 shouldBeEqualToString('setValueAsNumberAndGetValue(null)', '0');
71 shouldBeEqualToString('setValueAsNumberAndGetValue("foo")', ''); 71 shouldBeEqualToString('setValueAsNumberAndGetValue("foo")', '');
72 shouldBeEqualToString('setValueAsNumberAndGetValue(NaN)', ''); 72 shouldBeEqualToString('setValueAsNumberAndGetValue(NaN)', '');
73 shouldBeEqualToString('setValueAsNumberAndGetValue(Number.NaN)', ''); 73 shouldBeEqualToString('setValueAsNumberAndGetValue(Number.NaN)', '');
74 shouldThrow('setValueAsNumberAndGetValue(Infinity)', '"TypeError: Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The value provided is in finite."'); 74 shouldThrow('setValueAsNumberAndGetValue(Infinity)', '"TypeError: Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The value provided is in finite."');
75 shouldThrow('setValueAsNumberAndGetValue(Number.POSITIVE_INFINITY)', '"TypeError : Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The valu e provided is infinite."'); 75 shouldThrow('setValueAsNumberAndGetValue(Number.POSITIVE_INFINITY)', '"TypeError : Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The valu e provided is infinite."');
76 shouldThrow('setValueAsNumberAndGetValue(Number.NEGATIVE_INFINITY)', '"TypeError : Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The valu e provided is infinite."'); 76 shouldThrow('setValueAsNumberAndGetValue(Number.NEGATIVE_INFINITY)', '"TypeError : Failed to set the \'valueAsNumber\' property on \'HTMLInputElement\': The valu e provided is infinite."');
77 </script> 77 </script>
78 </body> 78 </body>
79 </html> 79 </html>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698