forked from mirrors/gecko-dev
		
	 67039cecb0
			
		
	
	
		67039cecb0
		
	
	
	
	
		
			
			This also avoids sending an engine-update Glean event for the default engine by not handling the engine-icon-update notification in the update tracking code. Differential Revision: https://phabricator.services.mozilla.com/D210838
		
			
				
	
	
		
			91 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* Any copyright is dedicated to the Public Domain.
 | |
|    http://creativecommons.org/publicdomain/zero/1.0/ */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| add_setup(async function () {
 | |
|   let server = useHttpServer();
 | |
|   server.registerContentType("sjs", "sjs");
 | |
|   await AddonTestUtils.promiseStartupManager();
 | |
|   await Services.search.init();
 | |
| });
 | |
| 
 | |
| const ICON_TESTS = [
 | |
|   {
 | |
|     name: "Big Icon",
 | |
|     image: "bigIcon.ico",
 | |
|     expected: "data:image/png;base64,",
 | |
|   },
 | |
|   {
 | |
|     name: "Remote Icon",
 | |
|     image: "remoteIcon.ico",
 | |
|     expected: "data:image/x-icon;base64,",
 | |
|   },
 | |
|   {
 | |
|     name: "SVG Icon",
 | |
|     image: "svgIcon.svg",
 | |
|     expected: "data:image/svg+xml;base64,",
 | |
|   },
 | |
| ];
 | |
| 
 | |
| add_task(async function test_icon_types() {
 | |
|   for (let test of ICON_TESTS) {
 | |
|     info(`Testing ${test.name}`);
 | |
| 
 | |
|     let promiseEngineAdded = SearchTestUtils.promiseSearchNotification(
 | |
|       SearchUtils.MODIFIED_TYPE.ADDED,
 | |
|       SearchUtils.TOPIC_ENGINE_MODIFIED
 | |
|     );
 | |
|     let promiseIconChanged = SearchTestUtils.promiseSearchNotification(
 | |
|       SearchUtils.MODIFIED_TYPE.ICON_CHANGED,
 | |
|       SearchUtils.TOPIC_ENGINE_MODIFIED
 | |
|     );
 | |
|     const engineData = {
 | |
|       baseURL: gDataUrl,
 | |
|       image: test.image,
 | |
|       name: test.name,
 | |
|       method: "GET",
 | |
|     };
 | |
|     // The easiest way to test adding the icon is via a generated xml, otherwise
 | |
|     // we have to somehow insert the address of the server into it.
 | |
|     SearchTestUtils.installOpenSearchEngine({
 | |
|       url: `${gDataUrl}engineMaker.sjs?${JSON.stringify(engineData)}`,
 | |
|     });
 | |
|     let engine = await promiseEngineAdded;
 | |
|     // Ensure this is a nsISearchEngine.
 | |
|     engine.QueryInterface(Ci.nsISearchEngine);
 | |
|     await promiseIconChanged;
 | |
| 
 | |
|     Assert.ok(await engine.getIconURL(), `${test.name} engine has an icon`);
 | |
|     Assert.ok(
 | |
|       (await engine.getIconURL()).startsWith(test.expected),
 | |
|       `${test.name} iconURI starts with the expected information`
 | |
|     );
 | |
|   }
 | |
| });
 | |
| 
 | |
| add_task(async function test_multiple_icons_in_file() {
 | |
|   let engine = await SearchTestUtils.installOpenSearchEngine({
 | |
|     url: `${gDataUrl}engineImages.xml`,
 | |
|   });
 | |
| 
 | |
|   Assert.ok((await engine.getIconURL()).includes("ico16"));
 | |
|   Assert.ok((await engine.getIconURL(16)).includes("ico16"));
 | |
|   Assert.ok((await engine.getIconURL(32)).includes("ico32"));
 | |
|   Assert.ok((await engine.getIconURL(74)).includes("ico74"));
 | |
| 
 | |
|   info("Invalid dimensions should return null until bug 1655070 is fixed.");
 | |
|   Assert.equal(null, await engine.getIconURL(50));
 | |
| });
 | |
| 
 | |
| add_task(async function test_icon_not_in_opensearch_file() {
 | |
|   let engineUrl = gDataUrl + "engine-fr.xml";
 | |
|   let engine = await Services.search.addOpenSearchEngine(
 | |
|     engineUrl,
 | |
|     "data:image/x-icon;base64,ico16"
 | |
|   );
 | |
| 
 | |
|   // Even though the icon wasn't specified inside the XML file, it should be
 | |
|   // available.
 | |
|   Assert.ok((await engine.getIconURL(16)).includes("ico16"));
 | |
| });
 |