Source code

Revision control

Copy as Markdown

Other Tools

<?xml version="1.0"?>
<!-- This Source Code Form is subject to the terms of the Mozilla Public
- License, v. 2.0. If a copy of the MPL was not distributed with this
- file, You can obtain one at http://mozilla.org/MPL/2.0/. -->
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
<?xml-stylesheet
type="text/css"?>
<window id="FindbarTest"
width="600"
height="600"
onload="onLoad();"
title="findbar test">
<script type="application/javascript"><![CDATA[
const {AppConstants} = ChromeUtils.importESModule(
"resource://gre/modules/AppConstants.sys.mjs"
);
const {BrowserTestUtils} = ChromeUtils.importESModule(
);
const SAMPLE_URL = "http://www.mozilla.org/";
const SAMPLE_TEXT = "Some text in a text field.";
const SEARCH_TEXT = "Text Test (δοκιμή)";
const NOT_FOUND_TEXT = "This text is not on the page."
const ITERATOR_TIMEOUT = Services.prefs.getIntPref("findbar.iteratorTimeout");
var gFindBar = null;
var gBrowser;
var gHasFindClipboard = Services.clipboard.isClipboardTypeSupported(Services.clipboard.kFindClipboard);
var gStatusText;
var gXULBrowserWindow = {
QueryInterface: ChromeUtils.generateQI(["nsIXULBrowserWindow"]),
setOverLink(aStatusText) {
gStatusText = aStatusText;
},
onBeforeLinkTraversal() { }
};
var SimpleTest = window.arguments[0].SimpleTest;
var ok = window.arguments[0].ok;
var is = window.arguments[0].is;
var info = window.arguments[0].info;
SimpleTest.requestLongerTimeout(2);
function onLoad() {
(async function() {
window.docShell
.treeOwner
.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsIAppWindow)
.XULBrowserWindow = gXULBrowserWindow;
gFindBar = document.getElementById("FindToolbar");
for (let browserId of ["content", "content-remote"]) {
await startTestWithBrowser(browserId);
}
})().then(() => {
window.close();
SimpleTest.finish();
});
}
async function startTestWithBrowser(browserId) {
info("Starting test with browser '" + browserId + "'");
gBrowser = document.getElementById(browserId);
// Tests delays the loading of a document for one second.
await new Promise(resolve => setTimeout(resolve, 1000));
let promise = BrowserTestUtils.browserLoaded(gBrowser);
BrowserTestUtils.startLoadingURIString(gBrowser, "data:text/html;charset=utf-8,<h2 id='h2'>" + SEARCH_TEXT +
"</h2><h2><a href='" + SAMPLE_URL + "'>Link Test</a></h2><input id='text' type='text' value='" +
SAMPLE_TEXT + "'></input><input id='button' type='button'></input><img id='img' width='50' height='50'/>",
{ triggeringPrincipal: window.document.nodePrincipal });
await promise;
gFindBar.browser = gBrowser;
await onDocumentLoaded();
}
async function onDocumentLoaded() {
await testNormalFind();
gFindBar.close();
ok(gFindBar.hidden, "Failed to close findbar after testNormalFind");
await openFindbar();
await testNormalFindWithComposition();
gFindBar.close();
ok(gFindBar.hidden, "findbar should be hidden after testNormalFindWithComposition");
await openFindbar();
await testAutoCaseSensitivityUI();
await testQuickFindText();
gFindBar.close();
ok(gFindBar.hidden, "Failed to close findbar after testQuickFindText");
// TODO: `testFindWithHighlight` tests fastFind integrity, which can not
// be accessed with RemoteFinder. We're skipping it for now.
if (gFindBar._browser.finder._fastFind) {
await testFindWithHighlight();
gFindBar.close();
ok(gFindBar.hidden, "Failed to close findbar after testFindWithHighlight");
}
await testFindbarSelection();
ok(gFindBar.hidden, "Failed to close findbar after testFindbarSelection");
// TODO: I don't know how to drop a content element on a chrome input.
if (!gBrowser.hasAttribute("remote"))
testDrop();
await testQuickFindLink();
if (gHasFindClipboard) {
await testStatusText();
}
if (!AppConstants.DEBUG) {
await testFindCountUI();
gFindBar.close();
ok(gFindBar.hidden, "Failed to close findbar after testFindCountUI");
await testFindCountUI(true);
gFindBar.close();
ok(gFindBar.hidden, "Failed to close findbar after testFindCountUI - linksOnly");
}
await openFindbar();
await testFindAfterCaseChanged();
gFindBar.close();
await openFindbar();
await testFailedStringReset();
gFindBar.close();
await testQuickFindClose();
// TODO: This doesn't seem to work when the findbar is connected to a
// remote browser element.
if (!gBrowser.hasAttribute("remote"))
await testFindAgainNotFound();
await testToggleEntireWord();
}
async function testFindbarSelection() {
function checkFindbarState(aTestName, aExpSelection) {
ok(!gFindBar.hidden, "testFindbarSelection: failed to open findbar: " + aTestName);
ok(document.commandDispatcher.focusedElement == gFindBar._findField,
"testFindbarSelection: find field is not focused: " + aTestName);
if (!gHasFindClipboard) {
ok(gFindBar._findField.value == aExpSelection,
"Incorrect selection in testFindbarSelection: " + aTestName +
". Selection: " + gFindBar._findField.value);
}
// Clear the value, close the findbar.
gFindBar._findField.value = "";
gFindBar.close();
}
// Test normal selected text.
await SpecialPowers.spawn(gBrowser, [], async function() {
let document = content.document;
let cH2 = document.getElementById("h2");
let cSelection = content.getSelection();
let cRange = document.createRange();
cRange.setStart(cH2, 0);
cRange.setEnd(cH2, 1);
cSelection.removeAllRanges();
cSelection.addRange(cRange);
});
await openFindbar();
checkFindbarState("plain text", SEARCH_TEXT);
// Test editable element with selection.
await SpecialPowers.spawn(gBrowser, [], async function() {
let textInput = content.document.getElementById("text");
textInput.focus();
textInput.select();
});
await openFindbar();
checkFindbarState("text input", SAMPLE_TEXT);
// Test non-editable input element (type="button").
await SpecialPowers.spawn(gBrowser, [], async function() {
content.document.getElementById("button").focus();
});
await openFindbar();
checkFindbarState("button", "");
}
function testDrop() {
gFindBar.open();
// use an dummy image to start the drag so it doesn't get interrupted by a selection
var img = gBrowser.contentDocument.getElementById("img");
synthesizeDrop(img, gFindBar._findField, [[ {type: "text/plain", data: "Rabbits" } ]], "copy", window);
is(gFindBar._findField.value, "Rabbits", "drop on findbar");
gFindBar.close();
}
function testQuickFindClose() {
return new Promise(resolve => {
var _isClosedCallback = function() {
ok(gFindBar.hidden,
"_isClosedCallback: Failed to auto-close quick find bar after " +
gFindBar._quickFindTimeoutLength + "ms");
resolve();
};
setTimeout(_isClosedCallback, gFindBar._quickFindTimeoutLength + 100);
});
}
function testStatusText() {
return new Promise(resolve => {
var _delayedCheckStatusText = function() {
ok(gStatusText == SAMPLE_URL, "testStatusText: Failed to set status text of found link");
resolve();
};
setTimeout(_delayedCheckStatusText, 100);
});
}
function promiseFindResult(expectedString) {
return new Promise(resolve => {
let listener = {
onFindResult(result) {
if (expectedString && result.searchString != expectedString) {
return;
}
gFindBar.browser.finder.removeResultListener(listener);
resolve(result);
},
};
gFindBar.browser.finder.addResultListener(listener);
});
}
function promiseMatchesCountResult(expectedString) {
return new Promise(resolve => {
let listener = {
onMatchesCountResult(result) {
if (expectedString && result.searchString != expectedString)
return;
gFindBar.browser.finder.removeResultListener(listener);
resolve();
},
};
gFindBar.browser.finder.addResultListener(listener);
// Make sure we resolve _at least_ after five times the find iterator timeout.
setTimeout(resolve, (ITERATOR_TIMEOUT * 5) + 20);
});
}
function promiseHighlightFinished(expectedString) {
return new Promise(resolve => {
let listener = {
onHighlightFinished(result) {
if (expectedString && result.searchString != expectedString)
return;
gFindBar.browser.finder.removeResultListener(listener);
resolve();
}
};
gFindBar.browser.finder.addResultListener(listener);
});
}
var enterStringIntoFindField = async function(str, waitForResult = true) {
for (let promise, i = 0; i < str.length; i++) {
if (waitForResult) {
promise = promiseFindResult();
}
let event = new KeyboardEvent("keypress", {
bubbles: true,
cancelable: true,
view: null,
keyCode: 0,
charCode: str.charCodeAt(i),
});
gFindBar._findField.dispatchEvent(event);
if (waitForResult) {
await promise;
}
}
};
function promiseExpectRangeCount(rangeCount) {
return SpecialPowers.spawn(gBrowser, [{ rangeCount }], async function(args) {
let controller = docShell.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsISelectionDisplay)
.QueryInterface(Ci.nsISelectionController);
let sel = controller.getSelection(Ci.nsISelectionController.SELECTION_FIND);
Assert.equal(sel.rangeCount, args.rangeCount,
"Expected the correct amount of ranges inside the Find selection");
});
}
// also test match-case
async function testNormalFind() {
document.getElementById("cmd_find").doCommand();
ok(!gFindBar.hidden, "testNormalFind: failed to open findbar");
ok(document.commandDispatcher.focusedElement == gFindBar._findField,
"testNormalFind: find field is not focused");
let promise;
let matchCaseCheckbox = gFindBar.getElement("find-case-sensitive");
if (!matchCaseCheckbox.hidden && matchCaseCheckbox.checked) {
promise = promiseFindResult();
matchCaseCheckbox.click();
await promise;
}
var searchStr = "text tes";
await enterStringIntoFindField(searchStr);
let sel = await SpecialPowers.spawn(gBrowser, [{ searchStr }], async function(args) {
let sel = content.getSelection().toString();
Assert.equal(sel.toLowerCase(), args.searchStr,
"testNormalFind: failed to find '" + args.searchStr + "'");
return sel;
});
testClipboardSearchString(sel);
if (!matchCaseCheckbox.hidden) {
promise = promiseFindResult();
matchCaseCheckbox.click();
await promise;
enterStringIntoFindField("t");
await SpecialPowers.spawn(gBrowser, [{ searchStr }], async function(args) {
Assert.notEqual(content.getSelection().toString(), args.searchStr,
"testNormalFind: Case-sensitivy is broken '" + args.searchStr + "'");
});
promise = promiseFindResult();
matchCaseCheckbox.click();
await promise;
}
}
function openFindbar() {
document.getElementById("cmd_find").doCommand();
return gFindBar._startFindDeferred && gFindBar._startFindDeferred.promise;
}
async function testNormalFindWithComposition() {
ok(!gFindBar.hidden, "testNormalFindWithComposition: findbar should be open");
ok(document.commandDispatcher.focusedElement == gFindBar._findField,
"testNormalFindWithComposition: find field should be focused");
var matchCaseCheckbox = gFindBar.getElement("find-case-sensitive");
var clicked = false;
if (!matchCaseCheckbox.hidden & matchCaseCheckbox.checked) {
matchCaseCheckbox.click();
clicked = true;
}
gFindBar._findField.focus();
var searchStr = "text";
synthesizeCompositionChange(
{ "composition":
{ "string": searchStr,
"clauses":
[
{ "length": searchStr.length, "attr": COMPOSITION_ATTR_RAW_CLAUSE }
]
},
"caret": { "start": searchStr.length, "length": 0 }
});
await SpecialPowers.spawn(gBrowser, [{ searchStr }], async function(args) {
Assert.notEqual(content.getSelection().toString().toLowerCase(), args.searchStr,
"testNormalFindWithComposition: text shouldn't be found during composition");
});
synthesizeComposition({ type: "compositioncommitasis" });
let sel = await SpecialPowers.spawn(gBrowser, [{ searchStr }], async function(args) {
let sel = content.getSelection().toString();
Assert.equal(sel.toLowerCase(), args.searchStr,
"testNormalFindWithComposition: text should be found after committing composition");
return sel;
});
testClipboardSearchString(sel);
if (clicked) {
matchCaseCheckbox.click();
}
}
async function testAutoCaseSensitivityUI() {
var matchCaseCheckbox = gFindBar.getElement("find-case-sensitive");
var matchCaseLabel = gFindBar.getElement("match-case-status");
ok(!matchCaseCheckbox.hidden, "match case box is hidden in manual mode");
ok(matchCaseLabel.hidden, "match case label is visible in manual mode");
await changeCase(2);
ok(matchCaseCheckbox.hidden,
"match case box is visible in automatic mode");
ok(!matchCaseLabel.hidden,
"match case label is hidden in automatic mode");
await enterStringIntoFindField("a");
ok(matchCaseLabel.hidden,
"match case label is hidden in automatic mode with lower-case input");
await enterStringIntoFindField("A");
ok(!matchCaseLabel.hidden,
"match case label is visible in automatic mode with upper-case input");
gFindBar.onFindAgainCommand();
ok(matchCaseCheckbox.hidden && !matchCaseLabel.hidden,
"bug 365551: case sensitivity UI is broken after find-again");
await changeCase(0);
gFindBar.close();
}
async function clearFocus() {
document.commandDispatcher.focusedElement = null;
document.commandDispatcher.focusedWindow = null;
await SpecialPowers.spawn(gBrowser, [], async function() {
content.focus();
});
}
async function testQuickFindLink() {
await clearFocus();
await SpecialPowers.spawn(gBrowser, [], async function() {
let event = new content.window.KeyboardEvent("keypress", {
bubbles: true,
cancelable: true,
view: null,
keyCode: 0,
charCode: "'".charCodeAt(0),
});
content.document.documentElement.dispatchEvent(event);
});
ok(!gFindBar.hidden, "testQuickFindLink: failed to open findbar");
ok(document.commandDispatcher.focusedElement == gFindBar._findField,
"testQuickFindLink: find field is not focused");
var searchStr = "Link Test";
await enterStringIntoFindField(searchStr);
await SpecialPowers.spawn(gBrowser, [{ searchStr }], async function(args) {
Assert.equal(content.getSelection().toString(), args.searchStr,
"testQuickFindLink: failed to find sample link");
});
testClipboardSearchString(searchStr);
}
// See bug 963925 for more details on this test.
async function testFindWithHighlight() {
gFindBar._findField.value = "";
// For this test, we want to closely control the selection. The easiest
// way to do so is to replace the implementation of
// Finder.getInitialSelection with a no-op and call the findbar's callback
// (onCurrentSelection(..., true)) ourselves with our hand-picked
// selection.
let oldGetInitialSelection = gFindBar.browser.finder.getInitialSelection;
let searchStr;
gFindBar.browser.finder.getInitialSelection = function(){};
let findCommand = document.getElementById("cmd_find");
findCommand.doCommand();
gFindBar.onCurrentSelection("", true);
searchStr = "e";
await enterStringIntoFindField(searchStr);
let a = gFindBar._findField.value;
let b = gFindBar._browser.finder._fastFind.searchString;
let c = gFindBar._browser.finder.searchString;
ok(a == b && b == c, "testFindWithHighlight 1: " + a + ", " + b + ", " + c + ".");
searchStr = "t";
findCommand.doCommand();
gFindBar.onCurrentSelection(searchStr, true);
gFindBar.browser.finder.getInitialSelection = oldGetInitialSelection;
a = gFindBar._findField.value;
b = gFindBar._browser.finder._fastFind.searchString;
c = gFindBar._browser.finder.searchString;
ok(a == searchStr && b == c, "testFindWithHighlight 2: " + searchStr +
", " + a + ", " + b + ", " + c + ".");
let highlightButton = gFindBar.getElement("highlight");
highlightButton.click();
ok(highlightButton.checked, "testFindWithHighlight 3: Highlight All should be checked.");
a = gFindBar._findField.value;
b = gFindBar._browser.finder._fastFind.searchString;
c = gFindBar._browser.finder.searchString;
ok(a == searchStr && b == c, "testFindWithHighlight 4: " + a + ", " + b + ", " + c + ".");
gFindBar.onFindAgainCommand();
a = gFindBar._findField.value;
b = gFindBar._browser.finder._fastFind.searchString;
c = gFindBar._browser.finder.searchString;
ok(a == b && b == c, "testFindWithHighlight 5: " + a + ", " + b + ", " + c + ".");
highlightButton.click();
ok(!highlightButton.checked, "testFindWithHighlight: Highlight All should be unchecked.");
// Regression test for bug 1316515.
searchStr = "e";
gFindBar.clear();
await enterStringIntoFindField(searchStr);
await promiseExpectRangeCount(0);
highlightButton.click();
ok(highlightButton.checked, "testFindWithHighlight: Highlight All should be checked.");
await promiseHighlightFinished(searchStr);
await promiseExpectRangeCount(3);
synthesizeKey("KEY_Backspace");
await promiseExpectRangeCount(0);
// Regression test for bug 1316513.
highlightButton.click();
ok(!highlightButton.checked, "testFindWithHighlight - 1316513: Highlight All should be unchecked.");
await enterStringIntoFindField(searchStr);
highlightButton.click();
ok(highlightButton.checked, "testFindWithHighlight - 1316513: Highlight All should be checked.");
await promiseHighlightFinished(searchStr);
await promiseExpectRangeCount(3);
let promise = BrowserTestUtils.browserLoaded(gBrowser);
gBrowser.reload();
await promise;
ok(highlightButton.checked, "testFindWithHighlight - 1316513: Highlight All " +
"should still be checked after a reload.");
synthesizeKey("KEY_Enter");
await promiseHighlightFinished(searchStr);
await promiseExpectRangeCount(3);
// Uncheck at test end to not interfere with other test functions that are
// run after this one.
highlightButton.click();
}
async function testQuickFindText() {
await clearFocus();
await SpecialPowers.spawn(gBrowser, [], async function() {
let event = new content.window.KeyboardEvent("keypress", {
bubbles: true,
cancelable: true,
view: null,
keyCode: 0,
charCode: "/".charCodeAt(0),
});
content.document.documentElement.dispatchEvent(event);
});
ok(!gFindBar.hidden, "testQuickFindText: failed to open findbar");
ok(document.commandDispatcher.focusedElement == gFindBar._findField,
"testQuickFindText: find field is not focused");
await enterStringIntoFindField(SEARCH_TEXT);
await SpecialPowers.spawn(gBrowser, [{ SEARCH_TEXT }], async function(args) {
Assert.equal(content.getSelection().toString(), args.SEARCH_TEXT,
"testQuickFindText: failed to find '" + args.SEARCH_TEXT + "'");
});
testClipboardSearchString(SEARCH_TEXT);
}
async function testFindCountUI(linksOnly = false) {
await clearFocus();
if (linksOnly) {
await SpecialPowers.spawn(gBrowser, [], async function() {
let event = new content.window.KeyboardEvent("keypress", {
bubbles: true,
cancelable: true,
view: null,
keyCode: 0,
charCode: "'".charCodeAt(0),
});
content.document.documentElement.dispatchEvent(event);
});
} else {
document.getElementById("cmd_find").doCommand();
}
ok(!gFindBar.hidden, "testFindCountUI: failed to open findbar");
ok(document.commandDispatcher.focusedElement == gFindBar._findField,
"testFindCountUI: find field is not focused");
let promise;
let matchCase = gFindBar.getElement("find-case-sensitive");
if (matchCase.checked) {
promise = promiseFindResult();
matchCase.click();
await new Promise(resolve => setTimeout(resolve, ITERATOR_TIMEOUT + 20));
await promise;
}
let foundMatches = gFindBar._foundMatches;
let tests = [{
text: "t",
current: linksOnly ? 1 : 5,
total: linksOnly ? 2 : 10,
}, {
text: "te",
current: linksOnly ? 1 : 3,
total: linksOnly ? 1 : 5,
}, {
text: "tes",
current: 1,
total: linksOnly ? 1 : 2,
}, {
text: "texxx",
current: 0,
total: 0
}];
function assertMatches(aTest) {
const matches = JSON.parse(foundMatches.dataset.l10nArgs);
is(matches.current, aTest.current,
`${linksOnly ? "[Links-only] " : ""}Currently highlighted match should be at ${aTest.current} for '${aTest.text}'`);
is(matches.total, aTest.total,
`${linksOnly ? "[Links-only] " : ""}Total amount of matches should be ${aTest.total} for '${aTest.text}'`);
}
for (let test of tests) {
gFindBar._findField.select();
gFindBar._findField.focus();
let timeout = ITERATOR_TIMEOUT;
if (test.text.length == 1)
timeout *= 4;
else if (test.text.length == 2)
timeout *= 2;
timeout += 20;
await new Promise(resolve => setTimeout(resolve, timeout));
await enterStringIntoFindField(test.text, false);
await promiseMatchesCountResult(test.text);
if (!test.total) {
ok(!foundMatches.dataset.l10nId, "No message should be shown when 0 matches are expected");
} else {
assertMatches(test);
for (let i = 1; i < test.total; i++) {
await new Promise(resolve => setTimeout(resolve, timeout));
gFindBar.onFindAgainCommand();
await promiseMatchesCountResult(test.text);
// test.current + 1, test.current + 2, ..., test.total, 1, ..., test.current
let current = (test.current + i - 1) % test.total + 1;
assertMatches({
text: test.text,
current,
total: test.total
});
}
}
}
}
// See bug 1051187.
async function testFindAfterCaseChanged() {
// Search to set focus on "Text Test" so that searching for "t" selects first
// (upper case!) "T".
await enterStringIntoFindField(SEARCH_TEXT);
gFindBar.clear();
// Case-insensitive should already be the current value.
Services.prefs.setIntPref("accessibility.typeaheadfind.casesensitive", 0);
await enterStringIntoFindField("t");
await SpecialPowers.spawn(gBrowser, [], async function() {
Assert.equal(content.getSelection().toString(), "T", "First T should be selected.");
});
await changeCase(1);
await SpecialPowers.spawn(gBrowser, [], async function() {
Assert.equal(content.getSelection().toString(), "t", "First t should be selected.");
});
}
// Make sure that _findFailedString is cleared:
// 1. Do a search that fails with case sensitivity but matches with no case sensitivity.
// 2. Uncheck case sensitivity button to match the string.
async function testFailedStringReset() {
Services.prefs.setIntPref("accessibility.typeaheadfind.casesensitive", 1);
let promise = promiseFindResult(gBrowser.hasAttribute("remote") ? SEARCH_TEXT.toUpperCase() : "");
await enterStringIntoFindField(SEARCH_TEXT.toUpperCase(), false);
await promise;
await SpecialPowers.spawn(gBrowser, [], async function() {
Assert.equal(content.getSelection().toString(), "", "Not found.");
});
await changeCase(0);
await SpecialPowers.spawn(gBrowser, [{ SEARCH_TEXT }], async function(args) {
Assert.equal(content.getSelection().toString(), args.SEARCH_TEXT,
"Search text should be selected.");
});
}
function testClipboardSearchString(aExpected) {
if (!gHasFindClipboard)
return;
if (!aExpected)
aExpected = "";
var searchStr = gFindBar.browser.finder.clipboardSearchString;
ok(searchStr.toLowerCase() == aExpected.toLowerCase(),
"testClipboardSearchString: search string not set to '" + aExpected +
"', instead found '" + searchStr + "'");
}
// See bug 967982.
async function testFindAgainNotFound() {
await openFindbar();
await enterStringIntoFindField(NOT_FOUND_TEXT, false);
gFindBar.close();
ok(gFindBar.hidden, "The findbar is closed.");
let promise = promiseFindResult();
gFindBar.onFindAgainCommand();
await promise;
ok(!gFindBar.hidden, "Unsuccessful Find Again opens the find bar.");
await enterStringIntoFindField(SEARCH_TEXT);
gFindBar.close();
ok(gFindBar.hidden, "The findbar is closed.");
promise = promiseFindResult();
gFindBar.onFindAgainCommand();
await promise;
ok(gFindBar.hidden, "Successful Find Again leaves the find bar closed.");
}
async function testToggleDiacriticMatching() {
await openFindbar();
let promise = promiseFindResult();
await enterStringIntoFindField("δοκιμη", false);
let result = await promise;
is(result.result, Ci.nsITypeAheadFind.FIND_FOUND, "Text should be found");
await new Promise(resolve => setTimeout(resolve, ITERATOR_TIMEOUT + 20));
promise = promiseFindResult();
let check = gFindBar.getElement("find-match-diacritics");
check.click();
result = await promise;
is(result.result, Ci.nsITypeAheadFind.FIND_NOTFOUND, "Text should NOT be found");
check.click();
gFindBar.close(true);
}
async function testToggleEntireWord() {
await openFindbar();
let promise = promiseFindResult();
await enterStringIntoFindField("Tex", false);
let result = await promise;
is(result.result, Ci.nsITypeAheadFind.FIND_FOUND, "Text should be found");
await new Promise(resolve => setTimeout(resolve, ITERATOR_TIMEOUT + 20));
promise = promiseFindResult();
let check = gFindBar.getElement("find-entire-word");
check.click();
result = await promise;
is(result.result, Ci.nsITypeAheadFind.FIND_NOTFOUND, "Text should NOT be found");
check.click();
gFindBar.close(true);
}
function changeCase(value) {
let promise = gBrowser.hasAttribute("remote") ? promiseFindResult() : Promise.resolve();
Services.prefs.setIntPref("accessibility.typeaheadfind.casesensitive", value);
return promise;
}
]]></script>
<commandset>
<command id="cmd_find" oncommand="document.getElementById('FindToolbar').onFindCommand();"/>
</commandset>
<browser type="content" primary="true" flex="1" id="content" messagemanagergroup="test" src="about:blank"/>
<browser type="content" primary="true" flex="1" id="content-remote" remote="true" messagemanagergroup="test" src="about:blank"/>
<findbar id="FindToolbar" browserid="content"/>
</window>