forked from mirrors/gecko-dev
		
	 79a4e43a84
			
		
	
	
		79a4e43a84
		
	
	
	
	
		
			
			This allows keyboard shortcuts containing both "Ctrl" and "Alt" in the manifest of webextensions (in the "commands" -> "suggested_key" key), rather than just one of these modifiers. The equivalent combinations on MacOS (any two of "Command", "Alt" and "MacCtrl") are also allowed. Non-sensical combinations (such as "Ctrl+Command" or "Ctrl+Ctrl") are forbidden. MozReview-Commit-ID: 59tC2efLm5q --HG-- extra : rebase_source : 5a9375116aab6b3c4abe96c4850e4ff857d93532 extra : intermediate-source : 507b35de0e93baccb54f83e8bce6cedfe9754dd9 extra : source : 115c5332fadc1d52940f8356f6273f0e9680657f
		
			
				
	
	
		
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
 | |
| /* vim: set sts=2 sw=2 et tw=80: */
 | |
| "use strict";
 | |
| 
 | |
| 
 | |
| add_task(async function test_manifest_commands() {
 | |
|   const validShortcuts = ["Ctrl+Y", "MacCtrl+Y", "Command+Y", "Alt+Shift+Y", "Ctrl+Alt+Y", "F1", "MediaNextTrack"];
 | |
|   const invalidShortcuts = ["Shift+Y", "Y", "Ctrl+Ctrl+Y", "Ctrl+Command+Y"];
 | |
| 
 | |
|   async function validateShortcut(shortcut, isValid) {
 | |
|     let normalized = await ExtensionTestUtils.normalizeManifest({
 | |
|       "commands": {
 | |
|         "toggle-feature": {
 | |
|           "suggested_key": {"default": shortcut},
 | |
|           "description": "Send a 'toggle-feature' event to the extension",
 | |
|         },
 | |
|       },
 | |
|     });
 | |
|     if (isValid) {
 | |
|       ok(!normalized.error,
 | |
|          "There should be no manifest errors.");
 | |
|     } else {
 | |
|       let expectedError = (
 | |
|         String.raw`Error processing commands.toggle-feature.suggested_key.default: Error: ` +
 | |
|           String.raw`Value "${shortcut}" must consist of ` +
 | |
|           String.raw`either a combination of one or two modifiers, including ` +
 | |
|           String.raw`a mandatory primary modifier and a key, separated by '+', ` +
 | |
|           String.raw`or a media key. For details see: ` +
 | |
|           String.raw`https://developer.mozilla.org/en-US/Add-ons/WebExtensions/manifest.json/commands#Key_combinations`
 | |
|       );
 | |
| 
 | |
|       ok(normalized.error.includes(expectedError),
 | |
|          `The manifest error ${JSON.stringify(normalized.error)} must contain ${JSON.stringify(expectedError)}`);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   for (let shortcut of validShortcuts) {
 | |
|     validateShortcut(shortcut, true);
 | |
|   }
 | |
|   for (let shortcut of invalidShortcuts) {
 | |
|     validateShortcut(shortcut, false);
 | |
|   }
 | |
| });
 |