Bug 1484232 - Move query to end and remove unused params. r=mikedeboer
authorMichael Kaply <mozilla@kaply.com>
Thu, 11 Oct 2018 21:28:15 +0000
changeset 499942 9d781037111bc5c77a643be0ae23188117a71cef
parent 499941 83aba42445aad36c01279a71fc4c73563991a3be
child 499943 62f5e5f579e7dddadf97483f4df5db093ae3e4eb
push id1864
push userffxbld-merge
push dateMon, 03 Dec 2018 15:51:40 +0000
treeherdermozilla-release@f040763d99ad [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersmikedeboer
bugs1484232
milestone64.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
Bug 1484232 - Move query to end and remove unused params. r=mikedeboer Differential Revision: https://phabricator.services.mozilla.com/D3630
browser/components/search/searchplugins/google-2018.xml
browser/components/search/searchplugins/google.xml
browser/components/search/test/browser_google.js
browser/components/search/test/browser_google_behavior.js
--- 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&amp;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&amp;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);