diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /layout/base/tests/test_reftests_with_caret.html | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'layout/base/tests/test_reftests_with_caret.html')
-rw-r--r-- | layout/base/tests/test_reftests_with_caret.html | 341 |
1 files changed, 341 insertions, 0 deletions
diff --git a/layout/base/tests/test_reftests_with_caret.html b/layout/base/tests/test_reftests_with_caret.html new file mode 100644 index 000000000..d9b5d4a6c --- /dev/null +++ b/layout/base/tests/test_reftests_with_caret.html @@ -0,0 +1,341 @@ +<!DOCTYPE HTML> +<html> +<head> + <title>Reftests with caret drawing</title> + <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> + <script type="text/javascript" src="/tests/SimpleTest/EventUtils.js"></script> + <script type="text/javascript" src="/tests/SimpleTest/WindowSnapshot.js"></script> + <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> + <style> + iframe { + border: none; + width: 600px; + height: 400px; + } + </style> +<script type="text/javascript"> + +SimpleTest.waitForExplicitFinish(); +SimpleTest.requestLongerTimeout(2); + +var iframes = []; +function callbackTestIframe(iframe) +{ + iframes.push(iframe); + + if (iframes.length != 2) + return; + + var result = iframes[0]; + var reference = iframes[1]; + + // Using assertSnapshots is important to get the data-URIs of failing tests + // dumped into the log in a format that reftest-analyzer.xhtml can process. + var passed = assertSnapshots(result.snapshot, reference.snapshot, true, + null /*no fuzz*/, result.src, reference.src); + + // Remove the iframes if the test was successful + if (passed) { + result.parentNode.removeChild(result); + reference.parentNode.removeChild(reference); + } + + iframes = []; + SimpleTest.waitForFocus(nextTest); +} + +function doSnapShot(iframe) { + iframe.snapshot = snapshotWindow(iframe.contentWindow, true); + callbackTestIframe(iframe); +}; + +function remotePageLoaded(callback) { + var iframe = this; + setTimeout(function(){ + doSnapShot(iframe); + callback(); + }, 0); +}; + +const MAX_ITERATIONS = 1000; + +function createIframe(url,next) { + var iframe = document.createElement("iframe"); + iframe.src = url; + iframe.remotePageLoaded = remotePageLoaded; + var me = this; + var currentIteration = 0; + function iframeLoadCompleted() { + var docEl = iframe.contentDocument.documentElement; + if (docEl.className.indexOf("reftest-wait") >= 0) { + if (currentIteration++ > MAX_ITERATIONS) { + ok(false, "iframe load for " + url + " timed out"); + endTest(); + } else { + setTimeout(iframeLoadCompleted, 0); + } + return; + } + iframe.remotePageLoaded(function() { + if (next) { + setTimeout(function(){createIframe(next,null);}, 0) + } + }); + } + iframe.addEventListener("load", iframeLoadCompleted, false); + window.document.body.appendChild(iframe); + iframe.focus(); +}; + +function refTest(test,ref) { + createIframe(test,ref); +}; + +var caretBlinkTime = null; +function endTest() { + var parentDoc = window.parent.document; + parentDoc.styleSheets[parentDoc.styleSheets.length-1].deleteRule(0); + // finish(), yet let the test actually end first, to be safe. + SimpleTest.executeSoon(SimpleTest.finish); +} + +var tests = [ + [ 'bug106855-1.html' , 'bug106855-1-ref.html' ] , + [ 'bug106855-2.html' , 'bug106855-1-ref.html' ] , + [ 'bug389321-2.html' , 'bug389321-2-ref.html' ] , + [ 'bug613807-1.html' , 'bug613807-1-ref.html' ] , + [ 'bug1082486-1.html', 'bug1082486-1-ref.html'] , + [ 'bug1082486-2.html', 'bug1082486-2-ref.html'] , + // The following test cases are all involving with one sending + // synthesizeKey(), the other without. They fail when accessiblecaret + // is enabled. Test them with the preference off. + function() {SpecialPowers.pushPrefEnv({'set': [['layout.accessiblecaret.enabled', false]]}, nextTest);} , + [ 'bug240933-1.html' , 'bug240933-1-ref.html' ] , + [ 'bug240933-2.html' , 'bug240933-1-ref.html' ] , + [ 'bug389321-1.html' , 'bug389321-1-ref.html' ] , + [ 'bug389321-3.html' , 'bug389321-3-ref.html' ] , + [ 'bug482484.html' , 'bug482484-ref.html' ] , + [ 'bug503399.html' , 'bug503399-ref.html' ] , + [ 'bug585922.html' , 'bug585922-ref.html' ] , + [ 'bug597519-1.html' , 'bug597519-1-ref.html' ] , + [ 'bug602141-1.html' , 'bug602141-1-ref.html' ] , + [ 'bug602141-2.html' , 'bug602141-2-ref.html' ] , + [ 'bug602141-3.html' , 'bug602141-3-ref.html' ] , + [ 'bug602141-4.html' , 'bug602141-4-ref.html' ] , + [ 'bug612271-1.html' , 'bug612271-ref.html' ] , + [ 'bug612271-2.html' , 'bug612271-ref.html' ] , + [ 'bug612271-3.html' , 'bug612271-ref.html' ] , + [ 'bug613433-1.html' , 'bug613433-ref.html' ] , + [ 'bug613433-2.html' , 'bug613433-ref.html' ] , + [ 'bug613433-3.html' , 'bug613433-ref.html' ] , + [ 'bug632215-1.html' , 'bug632215-ref.html' ] , + [ 'bug632215-2.html' , 'bug632215-ref.html' ] , + [ 'bug633044-1.html' , 'bug633044-1-ref.html' ] , + [ 'bug634406-1.html' , 'bug634406-1-ref.html' ] , + [ 'bug644428-1.html' , 'bug644428-1-ref.html' ] , + [ 'input-maxlength-valid-before-change.html', 'input-valid-ref.html'] , + [ 'input-maxlength-valid-change.html', 'input-valid-ref.html'] , + [ 'input-maxlength-invalid-change.html', 'input-invalid-ref.html'] , + [ 'input-minlength-valid-before-change.html', 'input-valid-ref.html'] , + [ 'input-minlength-valid-change.html', 'input-valid-ref.html'] , + [ 'input-minlength-invalid-change.html', 'input-invalid-ref.html'] , + [ 'input-maxlength-ui-valid-change.html', 'input-valid-ref.html'] , + [ 'input-maxlength-ui-invalid-change.html', 'input-invalid-ref.html'] , + [ 'input-minlength-ui-valid-change.html', 'input-valid-ref.html'] , + [ 'input-minlength-ui-invalid-change.html', 'input-invalid-ref.html'] , + [ 'textarea-maxlength-valid-before-change.html', 'textarea-valid-ref.html'] , + [ 'textarea-maxlength-valid-change.html', 'textarea-valid-ref.html'] , + [ 'textarea-maxlength-invalid-change.html', 'textarea-invalid-ref.html'] , + [ 'textarea-minlength-valid-before-change.html', 'textarea-valid-ref.html'] , + [ 'textarea-minlength-valid-change.html', 'textarea-valid-ref.html'] , + [ 'textarea-minlength-invalid-change.html', 'textarea-invalid-ref.html'] , + [ 'textarea-maxlength-ui-valid-change.html', 'textarea-valid-ref.html'] , + [ 'textarea-maxlength-ui-invalid-change.html', 'textarea-invalid-ref.html'] , + [ 'textarea-minlength-ui-valid-change.html', 'textarea-valid-ref.html'] , + [ 'textarea-minlength-ui-invalid-change.html', 'textarea-invalid-ref.html'] , + function() {SpecialPowers.pushPrefEnv({'set': [['bidi.browser.ui', true]]}, nextTest);} , + [ 'bug646382-1.html' , 'bug646382-1-ref.html' ] , + [ 'bug646382-2.html' , 'bug646382-2-ref.html' ] , + [ 'bug664087-1.html' , 'bug664087-1-ref.html' ] , + [ 'bug664087-2.html' , 'bug664087-2-ref.html' ] , + [ 'bug682712-1.html' , 'bug682712-1-ref.html' ] , + function() {SpecialPowers.pushPrefEnv({'clear': [['bidi.browser.ui']]}, nextTest);} , + [ 'bug746993-1.html' , 'bug746993-1-ref.html' ] , + [ 'bug956530-1.html' , 'bug956530-1-ref.html' ] , + [ 'bug989012-1.html' , 'bug989012-1-ref.html' ] , + [ 'bug989012-2.html' , 'bug989012-2-ref.html' ] , + [ 'bug989012-3.html' , 'bug989012-3-ref.html' ] , + [ 'bug1007065-1.html' , 'bug1007065-1-ref.html' ] , + [ 'bug1007067-1.html' , 'bug1007067-1-ref.html' ] , + [ 'bug1061468.html' , 'bug1061468-ref.html' ] , + [ 'bug1097242-1.html', 'bug1097242-1-ref.html'] , + [ 'bug1109968-1.html', 'bug1109968-1-ref.html'] , + [ 'bug1109968-2.html', 'bug1109968-2-ref.html'] , + // [ 'bug1123067-1.html' , 'bug1123067-ref.html' ] , TODO: bug 1129205 + [ 'bug1123067-2.html' , 'bug1123067-ref.html' ] , + [ 'bug1123067-3.html' , 'bug1123067-ref.html' ] , + [ 'bug1132768-1.html' , 'bug1132768-1-ref.html'] , + [ 'bug1237236-1.html' , 'bug1237236-1-ref.html' ] , + [ 'bug1237236-2.html' , 'bug1237236-2-ref.html' ] , + [ 'bug1258308-2.html' , 'bug1258308-2-ref.html' ] , + [ 'bug1259949-1.html' , 'bug1259949-1-ref.html'] , + [ 'bug1259949-2.html' , 'bug1259949-2-ref.html'] , + [ 'bug1263288.html' , 'bug1263288-ref.html'] , + [ 'bug1263357-1.html' , 'bug1263357-1-ref.html'] , + [ 'bug1263357-2.html' , 'bug1263357-2-ref.html'] , + [ 'bug1263357-3.html' , 'bug1263357-3-ref.html'] , + [ 'bug1263357-4.html' , 'bug1263357-4-ref.html'] , + [ 'bug1263357-5.html' , 'bug1263357-5-ref.html'] , + function() {SpecialPowers.pushPrefEnv({'clear': [['layout.accessiblecaret.enabled']]}, nextTest);} , +]; + +if (navigator.appVersion.indexOf("Android") == -1 && + SpecialPowers.Services.appinfo.name != "B2G") { + tests.push([ 'bug512295-1.html' , 'bug512295-1-ref.html' ]); + tests.push([ 'bug512295-2.html' , 'bug512295-2-ref.html' ]); + tests.push([ 'bug923376.html' , 'bug923376-ref.html' ]); + tests.push(function() {SpecialPowers.pushPrefEnv({'set': [['layout.css.overflow-clip-box.enabled', true]]}, nextTest);}); + tests.push([ 'bug966992-1.html' , 'bug966992-1-ref.html' ]); + tests.push([ 'bug966992-2.html' , 'bug966992-2-ref.html' ]); + tests.push([ 'bug966992-3.html' , 'bug966992-3-ref.html' ]); + tests.push(function() {SpecialPowers.pushPrefEnv({'clear': [['layout.css.overflow-clip-box.enabled']]}, nextTest);}); + tests.push([ 'bug1258308-1.html' , 'bug1258308-1-ref.html' ]); // maybe VK_END doesn't work on Android? +} else { + is(SpecialPowers.getIntPref("layout.spellcheckDefault"), 0, "Spellcheck should be turned off for this platform or this if..else check removed"); +} + +if (navigator.platform.indexOf("Linux") >= 0 && + SpecialPowers.Services.appinfo.name != "B2G") { + tests = tests.concat([ + // eDirPrevious, Shift+click + [ 'multi-range-user-select.html#prev1S_' , 'multi-range-user-select-ref.html#prev1S_' ] , + [ 'multi-range-user-select.html#prev2S_' , 'multi-range-user-select-ref.html#prev2S_' ] , + [ 'multi-range-user-select.html#prev3S_' , 'multi-range-user-select-ref.html#prev3S_' ] , + [ 'multi-range-user-select.html#prev4S_' , 'multi-range-user-select-ref.html#prev4S_' ] , + [ 'multi-range-user-select.html#prev5S_' , 'multi-range-user-select-ref.html#prev5S_' ] , + [ 'multi-range-user-select.html#prev6S_' , 'multi-range-user-select-ref.html#prev6S_' ] , + [ 'multi-range-user-select.html#prev7S_' , 'multi-range-user-select-ref.html#prev7S_' ] , + // eDirPrevious, Shift+Accel+click + [ 'multi-range-user-select.html#prev1SA' , 'multi-range-user-select-ref.html#prev1SA' ] , + [ 'multi-range-user-select.html#prev2SA' , 'multi-range-user-select-ref.html#prev2SA' ] , + [ 'multi-range-user-select.html#prev3SA' , 'multi-range-user-select-ref.html#prev3SA' ] , + [ 'multi-range-user-select.html#prev4SA' , 'multi-range-user-select-ref.html#prev4SA' ] , + [ 'multi-range-user-select.html#prev5SA' , 'multi-range-user-select-ref.html#prev5SA' ] , + [ 'multi-range-user-select.html#prev6SA' , 'multi-range-user-select-ref.html#prev6SA' ] , + [ 'multi-range-user-select.html#prev7SA' , 'multi-range-user-select-ref.html#prev7SA' ] , + // eDirPrevious, Accel+drag-select (adding an additional range) + [ 'multi-range-user-select.html#prev1AD' , 'multi-range-user-select-ref.html#prev1AD' ] , + [ 'multi-range-user-select.html#prev7AD' , 'multi-range-user-select-ref.html#prev7AD' ] , + // eDirPrevious, Accel+drag-select (bug 1128722) + [ 'multi-range-user-select.html#prev8AD' , 'multi-range-user-select-ref.html#prev8AD' ] , + // eDirPrevious, VK_RIGHT / LEFT + [ 'multi-range-user-select.html#prev1SR' , 'multi-range-user-select-ref.html#prev1SR' ] , + [ 'multi-range-user-select.html#prev1SL' , 'multi-range-user-select-ref.html#prev1SL' ] , + // eDirNext, Shift+click + [ 'multi-range-user-select.html#next1S_' , 'multi-range-user-select-ref.html#next1S_' ] , + [ 'multi-range-user-select.html#next2S_' , 'multi-range-user-select-ref.html#next2S_' ] , + [ 'multi-range-user-select.html#next3S_' , 'multi-range-user-select-ref.html#next3S_' ] , + [ 'multi-range-user-select.html#next4S_' , 'multi-range-user-select-ref.html#next4S_' ] , + [ 'multi-range-user-select.html#next5S_' , 'multi-range-user-select-ref.html#next5S_' ] , + [ 'multi-range-user-select.html#next6S_' , 'multi-range-user-select-ref.html#next6S_' ] , + [ 'multi-range-user-select.html#next7S_' , 'multi-range-user-select-ref.html#next7S_' ] , + // eDirNext, Shift+Accel+click + [ 'multi-range-user-select.html#next1SA' , 'multi-range-user-select-ref.html#next1SA' ] , + [ 'multi-range-user-select.html#next2SA' , 'multi-range-user-select-ref.html#next2SA' ] , + [ 'multi-range-user-select.html#next3SA' , 'multi-range-user-select-ref.html#next3SA' ] , + [ 'multi-range-user-select.html#next4SA' , 'multi-range-user-select-ref.html#next4SA' ] , + [ 'multi-range-user-select.html#next5SA' , 'multi-range-user-select-ref.html#next5SA' ] , + [ 'multi-range-user-select.html#next6SA' , 'multi-range-user-select-ref.html#next6SA' ] , + [ 'multi-range-user-select.html#next7SA' , 'multi-range-user-select-ref.html#next7SA' ] , + // eDirNext, Accel+drag-select (adding an additional range) + [ 'multi-range-user-select.html#next1AD' , 'multi-range-user-select-ref.html#next1AD' ] , + [ 'multi-range-user-select.html#next7AD' , 'multi-range-user-select-ref.html#next7AD' ] , + // eDirNext, Accel+drag-select (bug 1128722) + [ 'multi-range-user-select.html#next8AD' , 'multi-range-user-select-ref.html#next8AD' ] , + // eDirNext, VK_RIGHT / LEFT + [ 'multi-range-user-select.html#next1SR' , 'multi-range-user-select-ref.html#next1SR' ] , + [ 'multi-range-user-select.html#next1SL' , 'multi-range-user-select-ref.html#next1SL' ] , + // eDirPrevious, Shift+click + [ 'multi-range-script-select.html#prev1S_' , 'multi-range-script-select-ref.html#prev1S_' ] , + [ 'multi-range-script-select.html#prev2S_' , 'multi-range-script-select-ref.html#prev2S_' ] , + [ 'multi-range-script-select.html#prev3S_' , 'multi-range-script-select-ref.html#prev3S_' ] , + [ 'multi-range-script-select.html#prev4S_' , 'multi-range-script-select-ref.html#prev4S_' ] , + [ 'multi-range-script-select.html#prev5S_' , 'multi-range-script-select-ref.html#prev5S_' ] , + [ 'multi-range-script-select.html#prev6S_' , 'multi-range-script-select-ref.html#prev6S_' ] , + [ 'multi-range-script-select.html#prev7S_' , 'multi-range-script-select-ref.html#prev7S_' ] , + // eDirPrevious, Shift+Accel+click + [ 'multi-range-script-select.html#prev1SA' , 'multi-range-script-select-ref.html#prev1SA' ] , + [ 'multi-range-script-select.html#prev2SA' , 'multi-range-script-select-ref.html#prev2SA' ] , + [ 'multi-range-script-select.html#prev3SA' , 'multi-range-script-select-ref.html#prev3SA' ] , + [ 'multi-range-script-select.html#prev4SA' , 'multi-range-script-select-ref.html#prev4SA' ] , + [ 'multi-range-script-select.html#prev5SA' , 'multi-range-script-select-ref.html#prev5SA' ] , + [ 'multi-range-script-select.html#prev6SA' , 'multi-range-script-select-ref.html#prev6SA' ] , + [ 'multi-range-script-select.html#prev7SA' , 'multi-range-script-select-ref.html#prev7SA' ] , + // eDirPrevious, Accel+drag-select (adding an additional range) + [ 'multi-range-script-select.html#prev1AD' , 'multi-range-script-select-ref.html#prev1AD' ] , + [ 'multi-range-script-select.html#prev7AD' , 'multi-range-script-select-ref.html#prev7AD' ] , + // eDirPrevious, VK_RIGHT / LEFT + [ 'multi-range-script-select.html#prev1SR' , 'multi-range-script-select-ref.html#prev1SR' ] , + [ 'multi-range-script-select.html#prev1SL' , 'multi-range-script-select-ref.html#prev1SL' ] , + // eDirNext, Shift+click + [ 'multi-range-script-select.html#next1S_' , 'multi-range-script-select-ref.html#next1S_' ] , + [ 'multi-range-script-select.html#next2S_' , 'multi-range-script-select-ref.html#next2S_' ] , + [ 'multi-range-script-select.html#next3S_' , 'multi-range-script-select-ref.html#next3S_' ] , + [ 'multi-range-script-select.html#next4S_' , 'multi-range-script-select-ref.html#next4S_' ] , + [ 'multi-range-script-select.html#next5S_' , 'multi-range-script-select-ref.html#next5S_' ] , + [ 'multi-range-script-select.html#next6S_' , 'multi-range-script-select-ref.html#next6S_' ] , + [ 'multi-range-script-select.html#next7S_' , 'multi-range-script-select-ref.html#next7S_' ] , + // eDirNext, Shift+Accel+click + [ 'multi-range-script-select.html#next1SA' , 'multi-range-script-select-ref.html#next1SA' ] , + [ 'multi-range-script-select.html#next2SA' , 'multi-range-script-select-ref.html#next2SA' ] , + [ 'multi-range-script-select.html#next3SA' , 'multi-range-script-select-ref.html#next3SA' ] , + [ 'multi-range-script-select.html#next4SA' , 'multi-range-script-select-ref.html#next4SA' ] , + [ 'multi-range-script-select.html#next5SA' , 'multi-range-script-select-ref.html#next5SA' ] , + [ 'multi-range-script-select.html#next6SA' , 'multi-range-script-select-ref.html#next6SA' ] , + [ 'multi-range-script-select.html#next7SA' , 'multi-range-script-select-ref.html#next7SA' ] , + // eDirNext, Accel+drag-select (adding an additional range) + [ 'multi-range-script-select.html#next1AD' , 'multi-range-script-select-ref.html#next1AD' ] , + [ 'multi-range-script-select.html#next7AD' , 'multi-range-script-select-ref.html#next7AD' ] , + // eDirNext, VK_RIGHT / LEFT + [ 'multi-range-script-select.html#next1SR' , 'multi-range-script-select-ref.html#next1SR' ] , + [ 'multi-range-script-select.html#next1SL' , 'multi-range-script-select-ref.html#next1SL' ] , + ]); +} + +var testIndex = 0; + +function nextTest() { + if (testIndex < tests.length) { + if (typeof(tests[testIndex]) == 'function') { + tests[testIndex](); + } else { + refTest(tests[testIndex][0],tests[testIndex][1]); + } + ++testIndex; + } else { + endTest(); + } +} +function runTests() { + try { + if (window.parent) { + var parentDoc = window.parent.document; + extraCSSRule = parentDoc.styleSheets[parentDoc.styleSheets.length-1] + .insertRule("iframe#testframe{width:600px;height:400px}",0); + } + try { + caretBlinkTime = SpecialPowers.getIntPref("ui.caretBlinkTime"); + } catch (e) {} + SpecialPowers.pushPrefEnv({'set': [['ui.caretBlinkTime', -1]]}, nextTest); + } catch(e) { + endTest(); + } +} + +SimpleTest.waitForFocus(runTests); + +</script> +</head> +<body> +</body> +</html> |