diff options
author | Matt A. Tobin <email@mattatobin.com> | 2018-04-17 07:31:18 -0400 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2018-04-17 07:31:18 -0400 |
commit | 0bdaa97892ead4977d69382a2bfe8f00a7dbac82 (patch) | |
tree | 91a1539a0d5602bab94ca6d2357f63e2ae2839fb /toolkit/components/autocomplete/tests/unit/test_popupSelectionVsDefaultCompleteValue.js | |
parent | e719d7b3be222dfafad78c71761bad2bafb1243d (diff) | |
download | UXP-0bdaa97892ead4977d69382a2bfe8f00a7dbac82.tar UXP-0bdaa97892ead4977d69382a2bfe8f00a7dbac82.tar.gz UXP-0bdaa97892ead4977d69382a2bfe8f00a7dbac82.tar.lz UXP-0bdaa97892ead4977d69382a2bfe8f00a7dbac82.tar.xz UXP-0bdaa97892ead4977d69382a2bfe8f00a7dbac82.zip |
Restore typeAheadResult support in autocomplete
Diffstat (limited to 'toolkit/components/autocomplete/tests/unit/test_popupSelectionVsDefaultCompleteValue.js')
-rw-r--r-- | toolkit/components/autocomplete/tests/unit/test_popupSelectionVsDefaultCompleteValue.js | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/toolkit/components/autocomplete/tests/unit/test_popupSelectionVsDefaultCompleteValue.js b/toolkit/components/autocomplete/tests/unit/test_popupSelectionVsDefaultCompleteValue.js new file mode 100644 index 000000000..fb4153355 --- /dev/null +++ b/toolkit/components/autocomplete/tests/unit/test_popupSelectionVsDefaultCompleteValue.js @@ -0,0 +1,71 @@ +/* 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/. */ + +function AutoCompleteTypeAheadResult(aValues, aFinalCompleteValues) { + this._values = aValues; + this._finalCompleteValues = aFinalCompleteValues; + this.defaultIndex = 0; + this._typeAheadResult = true; +} +AutoCompleteTypeAheadResult.prototype = Object.create(AutoCompleteResultBase.prototype); + +function AutoCompleteResult(aValues) { + this._values = aValues; +} +AutoCompleteResult.prototype = Object.create(AutoCompleteResultBase.prototype); + +function AutoCompleteInput(aSearches) { + this.searches = aSearches; + this.popupOpen = true; + this.completeDefaultIndex = true; + this.completeSelectedIndex = true; +} +AutoCompleteInput.prototype = Object.create(AutoCompleteInputBase.prototype); + +function run_test() { + run_next_test(); +} + +add_test(function test_handleEnter() { + doSearch("moz", function(aController) { + do_check_eq(aController.input.textValue, "mozilla.com"); + aController.handleEnter(true); + do_check_eq(aController.input.textValue, "mozilla.org"); + }); +}); + +function doSearch(aSearchString, aOnCompleteCallback) { + let typeAheadSearch = new AutoCompleteSearchBase( + "typeAheadSearch", + new AutoCompleteTypeAheadResult([ "mozilla.com" ], [ "http://www.mozilla.com" ]) + ); + registerAutoCompleteSearch(typeAheadSearch); + + let search = new AutoCompleteSearchBase( + "search", + new AutoCompleteResult([ "mozilla.org" ]) + ); + registerAutoCompleteSearch(search); + + let controller = Cc["@mozilla.org/autocomplete/controller;1"]. + getService(Ci.nsIAutoCompleteController); + + // Make an AutoCompleteInput that uses our searches and confirms results. + let input = new AutoCompleteInput([ typeAheadSearch.name, search.name ]); + input.textValue = aSearchString; + + // Caret must be at the end for autofill to happen. + let strLen = aSearchString.length; + input.selectTextRange(strLen, strLen); + controller.input = input; + controller.startSearch(aSearchString); + + input.onSearchComplete = function onSearchComplete() { + aOnCompleteCallback(controller); + + // Clean up. + unregisterAutoCompleteSearch(search); + run_next_test(); + }; +} |