83 lines
2.2 KiB
HTML
83 lines
2.2 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<script src="../../../resources/js-test-pre.js"></script>
|
|
</head>
|
|
<body>
|
|
<p id="description"></p>
|
|
<div id="console"></div>
|
|
<script>
|
|
description('This test aims to check for typeMismatch flag with type=month input fields');
|
|
var i = document.createElement('input');
|
|
i.type = 'month';
|
|
|
|
function check(value, disabled)
|
|
{
|
|
i.value = value;
|
|
i.disabled = !!disabled;
|
|
|
|
if (i.validity.typeMismatch)
|
|
testFailed('"' + value + '" had typeMismatch. This should not happen with sanitization.');
|
|
}
|
|
|
|
function shouldBeValid(value)
|
|
{
|
|
check(value);
|
|
if ((value === '' && i.value === '') || (value !== '' && i.value !== ""))
|
|
testPassed('"' + value + '" is a correct valid month string.');
|
|
else
|
|
testFailed('"' + value + '" is a valid month string that failed to be set on the input.');
|
|
}
|
|
|
|
function shouldBeInvalid(value, disabled)
|
|
{
|
|
check(value, disabled);
|
|
if (i.value === '')
|
|
testPassed('"' + value + '" is an invalid month string and was sanitized' + (disabled ? ' while disabled' : '') + '.');
|
|
else
|
|
testFailed('"' + value + '" is an invalid month string and was not sanitized' + (disabled ? ' while disabled' : '') + '.');
|
|
}
|
|
|
|
// Valid values
|
|
shouldBeValid('');
|
|
shouldBeValid('0001-01');
|
|
shouldBeValid('9999-12');
|
|
shouldBeValid('275760-09');
|
|
shouldBeValid('2009-01');
|
|
shouldBeValid('2009-02');
|
|
shouldBeValid('2009-03');
|
|
shouldBeValid('2009-04');
|
|
shouldBeValid('2009-05');
|
|
shouldBeValid('2009-06');
|
|
shouldBeValid('2009-07');
|
|
shouldBeValid('2009-08');
|
|
shouldBeValid('2009-09');
|
|
shouldBeValid('2009-10');
|
|
shouldBeValid('2009-11');
|
|
shouldBeValid('2009-12');
|
|
|
|
// Invalid values
|
|
shouldBeInvalid(' 2009-09 ');
|
|
shouldBeInvalid('a');
|
|
shouldBeInvalid('-1-09');
|
|
shouldBeInvalid('0000-12');
|
|
shouldBeInvalid('2147483648-12');
|
|
shouldBeInvalid('275760-10');
|
|
shouldBeInvalid('2009/09');
|
|
shouldBeInvalid('200909');
|
|
shouldBeInvalid('2009--2');
|
|
shouldBeInvalid('2009-00');
|
|
shouldBeInvalid('2009-13');
|
|
shouldBeInvalid('2009-');
|
|
shouldBeInvalid('2009-9');
|
|
shouldBeInvalid('2009-009');
|
|
shouldBeInvalid('2009-xx');
|
|
shouldBeInvalid('2009');
|
|
|
|
// Disabled
|
|
shouldBeInvalid('invalid', true);
|
|
</script>
|
|
<script src="../../../resources/js-test-post.js"></script>
|
|
</body>
|
|
</html>
|