author | Michael Kaply <mozilla@kaply.com> |
Thu, 11 Oct 2018 21:28:15 +0000 | |
changeset 441478 | 9d781037111bc5c77a643be0ae23188117a71cef |
parent 441477 | 83aba42445aad36c01279a71fc4c73563991a3be |
child 441479 | 62f5e5f579e7dddadf97483f4df5db093ae3e4eb |
push id | 71082 |
push user | mozilla@kaply.com |
push date | Tue, 16 Oct 2018 15:22:31 +0000 |
treeherder | autoland@9d781037111b [default view] [failures only] |
perfherder | [talos] [build metrics] [platform microbench] (compared to previous push) |
reviewers | mikedeboer |
bugs | 1484232 |
milestone | 64.0a1 |
first release with | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
last release without | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
--- a/browser/components/search/searchplugins/google-2018.xml +++ b/browser/components/search/searchplugins/google-2018.xml @@ -4,15 +4,13 @@ <SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/"> <ShortName>Google</ShortName> <Description>Google Search</Description> <InputEncoding>UTF-8</InputEncoding> <Image width="16" height="16"></Image> <Url type="application/x-suggestions+json" method="GET" template="https://www.google.com/complete/search?client=firefox&q={searchTerms}"/> <Url type="text/html" method="GET" template="https://www.google.com/search" rel="searchform"> - <Param name="q" value="{searchTerms}"/> - <Param name="ie" value="utf-8"/> - <Param name="oe" value="utf-8"/> <MozParam name="client" condition="purpose" purpose="keyword" value="firefox-b-1-ab"/> <MozParam name="client" condition="purpose" purpose="searchbar" value="firefox-b-1"/> + <Param name="q" value="{searchTerms}"/> </Url> </SearchPlugin>
--- a/browser/components/search/searchplugins/google.xml +++ b/browser/components/search/searchplugins/google.xml @@ -4,15 +4,13 @@ <SearchPlugin xmlns="http://www.mozilla.org/2006/browser/search/"> <ShortName>Google</ShortName> <Description>Google Search</Description> <InputEncoding>UTF-8</InputEncoding> <Image width="16" height="16"></Image> <Url type="application/x-suggestions+json" method="GET" template="https://www.google.com/complete/search?client=firefox&q={searchTerms}"/> <Url type="text/html" method="GET" template="https://www.google.com/search" rel="searchform"> - <Param name="q" value="{searchTerms}"/> - <Param name="ie" value="utf-8"/> - <Param name="oe" value="utf-8"/> <MozParam name="client" condition="purpose" purpose="keyword" value="firefox-b-ab"/> <MozParam name="client" condition="purpose" purpose="searchbar" value="firefox-b"/> + <Param name="q" value="{searchTerms}"/> </Url> </SearchPlugin>
--- a/browser/components/search/test/browser_google.js +++ b/browser/components/search/test/browser_google.js @@ -6,17 +6,17 @@ */ "use strict"; let expectedEngine = { name: "Google", alias: null, description: "Google Search", - searchForm: "https://www.google.com/search?q=&ie=utf-8&oe=utf-8", + searchForm: "https://www.google.com/search?", hidden: false, wrappedJSObject: { queryCharset: "UTF-8", "_iconURL": "", _urls: [ { type: "application/x-suggestions+json", method: "GET", @@ -28,90 +28,83 @@ let expectedEngine = { method: "GET", template: "https://www.google.com/search", params: [ { "name": "q", "value": "{searchTerms}", "purpose": undefined, }, - { - "name": "ie", - "value": "utf-8", - "purpose": undefined, - }, - { - "name": "oe", - "value": "utf-8", - "purpose": undefined, - }, ], mozparams: { }, }, ], }, }; function test() { let engine = Services.search.getEngineByName("Google"); ok(engine, "Found Google search engine"); let region = Services.prefs.getCharPref("browser.search.region"); let code = ""; + let keywordCode = ""; switch (region) { case "US": code = "firefox-b-1"; break; case "DE": code = "firefox-b"; break; case "RU": // Covered by test but doesn't use a code break; } - let base = "https://www.google.com/search?q=foo&ie=utf-8&oe=utf-8"; - // Keyword uses a slightly different code - let keywordBase = base; if (code) { - let suffix = `&client=${code}`; - base += suffix; - keywordBase += `${suffix}-ab`; - expectedEngine.searchForm += suffix; + expectedEngine.searchForm += `client=${code}&`; + keywordCode = `${code}-ab`; let urlParams = expectedEngine.wrappedJSObject._urls[1].params; - urlParams.push({ - name: "client", - value: `${code}-ab`, - purpose: "keyword", - }); - urlParams.push({ + urlParams.unshift({ name: "client", value: code, purpose: "searchbar", }); + urlParams.unshift({ + name: "client", + value: keywordCode, + purpose: "keyword", + }); } + expectedEngine.searchForm += "q="; let url; // Test search URLs (including purposes). let purposes = ["", "contextmenu", "searchbar", "homepage", "newtab"]; + let urlParams; for (let purpose of purposes) { url = engine.getSubmission("foo", null, purpose).uri.spec; - is(url, base, `Check ${purpose} search URL for 'foo'`); + urlParams = new URLSearchParams(url.split("?")[1]); + is(urlParams.get("client"), code, "Check ${purpose} search URL for code"); + is(urlParams.get("q"), "foo", `Check ${purpose} search URL for 'foo'`); } url = engine.getSubmission("foo", null, "keyword").uri.spec; - is(url, keywordBase, "Check keyword search URL for 'foo'"); + urlParams = new URLSearchParams(url.split("?")[1]); + is(urlParams.get("client"), keywordCode, "Check keyword search URL for code"); + is(urlParams.get("q"), "foo", `Check keyword search URL for 'foo'`); // Check search suggestion URL. url = engine.getSubmission("foo", "application/x-suggestions+json").uri.spec; is(url, "https://www.google.com/complete/search?client=firefox&q=foo", "Check search suggestion URL for 'foo'"); // Check result parsing and alternate domains. - let alternateBase = base.replace("www.google.com", "www.google.fr"); + let base = "https://www.google.com/search?q=foo"; is(Services.search.parseSubmissionURL(base).terms, "foo", "Check result parsing"); + let alternateBase = base.replace("www.google.com", "www.google.fr"); is(Services.search.parseSubmissionURL(alternateBase).terms, "foo", "Check alternate domain"); // Check all other engine properties. isSubObjectOf(expectedEngine, engine, "Google"); }
--- a/browser/components/search/test/browser_google_behavior.js +++ b/browser/components/search/test/browser_google_behavior.js @@ -6,17 +6,16 @@ * TODO: This test is a near duplicate of browser_searchEngine_behaviors.js but * specific to Google. This is required due to bug 1315953. */ "use strict"; let searchEngineDetails = [{ alias: "g", - baseURL: "https://www.google.com/search?q=foo&ie=utf-8&oe=utf-8", codes: { context: "", keyword: "", newTab: "", submission: "", }, name: "Google", }]; @@ -29,21 +28,20 @@ switch (region) { break; case "DE": code = "firefox-b"; break; } if (code) { let codes = searchEngineDetails[0].codes; - let suffix = `&client=${code}`; - codes.context = suffix; - codes.newTab = suffix; - codes.submission = suffix; - codes.keyword = `${suffix}-ab`; + codes.context = code; + codes.newTab = code; + codes.submission = code; + codes.keyword = `${code}-ab`; } function promiseContentSearchReady(browser) { return ContentTask.spawn(browser, {}, async function(args) { return new Promise(resolve => { if (content.wrappedJSObject.gContentSearchController) { let searchController = content.wrappedJSObject.gContentSearchController; if (searchController.defaultEngine) { @@ -75,70 +73,69 @@ for (let engine of searchEngineDetails) async function testSearchEngine(engineDetails) { let engine = Services.search.getEngineByName(engineDetails.name); Assert.ok(engine, `${engineDetails.name} is installed`); Services.search.currentEngine = engine; engine.alias = engineDetails.alias; - let base = engineDetails.baseURL; - // Test search URLs (including purposes). let url = engine.getSubmission("foo").uri.spec; - Assert.equal(url, base + engineDetails.codes.submission, "Check search URL for 'foo'"); + let urlParams = new URLSearchParams(url.split("?")[1]); + Assert.equal(urlParams.get("q"), "foo", "Check search URL for 'foo'"); let engineTests = [ { name: "context menu search", - searchURL: base + engineDetails.codes.context, + code: engineDetails.codes.context, run() { // Simulate a contextmenu search // FIXME: This is a bit "low-level"... BrowserSearch._loadSearch("foo", false, "contextmenu", Services.scriptSecurityManager.getSystemPrincipal()); }, }, { name: "keyword search", - searchURL: base + engineDetails.codes.keyword, + code: engineDetails.codes.keyword, run() { gURLBar.value = "? foo"; gURLBar.focus(); EventUtils.synthesizeKey("KEY_Enter"); }, }, { name: "keyword search with alias", - searchURL: base + engineDetails.codes.keyword, + code: engineDetails.codes.keyword, run() { gURLBar.value = `${engineDetails.alias} foo`; gURLBar.focus(); EventUtils.synthesizeKey("KEY_Enter"); }, }, { name: "search bar search", - searchURL: base + engineDetails.codes.submission, + code: engineDetails.codes.submission, async preTest() { await gCUITestUtils.addSearchBar(); }, run() { let sb = BrowserSearch.searchBar; sb.focus(); sb.value = "foo"; EventUtils.synthesizeKey("KEY_Enter"); }, postTest() { BrowserSearch.searchBar.value = ""; gCUITestUtils.removeSearchBar(); }, }, { name: "new tab search", - searchURL: base + engineDetails.codes.newTab, + code: engineDetails.codes.newTab, async preTest(tab) { let browser = tab.linkedBrowser; await BrowserTestUtils.loadURI(browser, "about:newtab"); await BrowserTestUtils.browserLoaded(browser); await promiseContentSearchReady(browser); }, async run(tab) { @@ -162,17 +159,19 @@ async function testSearchEngine(engineDe } let stateChangePromise = promiseStateChangeURI(); await test.run(tab); let receivedURI = await stateChangePromise; - Assert.equal(receivedURI, test.searchURL); + let receivedURLParams = new URLSearchParams(receivedURI.split("?")[1]); + + Assert.equal(receivedURLParams.get("client"), test.code); if (test.postTest) { await test.postTest(tab); } } engine.alias = undefined; BrowserTestUtils.removeTab(tab);