<!DOCTYPE html>
<script src="../../resources/testharness.js"></script>
<script src="../../resources/testharnessreport.js"></script>
<div>foo<input value="initial">bar</div>
<div>baz<textarea>initial</textarea>quux</div>
<div id="log"></div>
<script>
var input = document.querySelector('input');
var textarea = document.querySelector('textarea');
if (window.internals) {
internals.setSuggestedValue(input, 'suggested');
internals.setAutofilled(input, true);
internals.setSuggestedValue(textarea, 'suggested');
internals.setAutofilled(textarea, true);
}
// We should emit initial value if control is auto-filled.
test(function() {
input.select();
assert_equals(getSelection().toString(), '');
}, 'select input inner whole');
test(function() {
textarea.select();
assert_equals(getSelection().toString(), '');
}, 'select textarea inner whole');
// We should not put suggested value to toString().
test(function() {
input.setSelectionRange(2, 5);
assert_equals(getSelection().toString(), '');
}, 'select input inner');
test(function() {
textarea.setSelectionRange(2, 5);
assert_equals(getSelection().toString(), '');
}, 'select textarea inner');
// Selection should not have auto-filled value.
test(function() {
getSelection().selectAllChildren(input.parentNode);
assert_equals(getSelection().toString(), 'foobar');
}, 'select input outer');
test(function() {
getSelection().selectAllChildren(textarea.parentNode);
assert_equals(getSelection().toString(), 'bazquux');
}, 'select textarea outer');
</script>