tizen beta release
[profile/ivi/webkit-efl.git] / LayoutTests / fast / forms / time / ValidityState-rangeOverflow-time.html
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <script src="../../js/resources/js-test-pre.js"></script>
5 </head>
6 <body>
7 <p id="description"></p>
8 <div id="console"></div>
9 <script>
10 description('This test aims to check for rangeOverflow flag with time input fields');
11
12 var input = document.createElement('input');
13
14 function checkOverflow(value, max, disabled)
15 {
16     input.value = value;
17     input.max = max;
18     input.disabled = !!disabled;
19     var overflow = input.validity.rangeOverflow;
20     var resultText = 'The value "' + input.value + '" ' +
21         (overflow ? 'overflows' : 'doesn\'t overflow') +
22         ' the maximum value "' + input.max + '"' + (disabled ? ' when disabled.' : '.');
23     if (overflow)
24         testPassed(resultText);
25     else
26         testFailed(resultText);
27 }
28
29 function checkNotOverflow(value, max, disabled)
30 {
31     input.value = value;
32     input.max = max;
33     input.disabled = !!disabled;
34     var overflow = input.validity.rangeOverflow;
35     var resultText = 'The value "' + input.value + '" ' +
36         (overflow ? 'overflows' : 'doesn\'t overflow') +
37         ' the maximum value "' + input.max + '"' + (disabled ? ' when disabled.' : '.');
38     if (overflow)
39         testFailed(resultText);
40     else
41         testPassed(resultText);
42 }
43
44 input.type = 'time';
45 input.min = '';
46 // No overflow cases
47 checkNotOverflow('13:16', null);
48 checkNotOverflow('13:16', '');
49 checkNotOverflow('13:16', 'foo');
50 checkNotOverflow('13:16', '13:16');
51 checkNotOverflow('13:16', '13:17');
52 checkNotOverflow('13:16', '14:15');
53 checkNotOverflow('foo', '13:16');
54
55 // Overflow cases
56 checkOverflow('13:16', '13:15');
57 checkOverflow('23:59:59.999', '13:16');
58 input.min = '14:00';  // value < min && value > max
59 checkOverflow('13:16', '12:00');
60
61 // Disabled
62 checkNotOverflow('23:59:59.999', '13:16', true);
63 </script>
64 <script src="../../js/resources/js-test-post.js"></script>
65 </body>
66 </html>