diff options
-rw-r--r-- | test/test-workers.js (renamed from test/test-sw.js) | 69 |
1 files changed, 42 insertions, 27 deletions
diff --git a/test/test-sw.js b/test/test-workers.js index 498a0a32..9f9c4d13 100644 --- a/test/test-sw.js +++ b/test/test-workers.js @@ -22,6 +22,15 @@ const {VM} = require('../dev/vm'); const assert = require('assert'); +function loadEslint() { + return JSON.parse(fs.readFileSync(path.join(__dirname, '..', '.eslintrc.json'), {encoding: 'utf8'})); +} + +function filterScriptPaths(scriptPaths) { + const extDirName = 'ext'; + return scriptPaths.filter((src) => !src.startsWith('/lib/')).map((src) => `${extDirName}${src}`); +} + function getAllHtmlScriptPaths(fileName) { const domSource = fs.readFileSync(fileName, {encoding: 'utf8'}); const dom = new JSDOM(domSource); @@ -43,38 +52,44 @@ function convertBackgroundScriptsToServiceWorkerScripts(scripts) { scripts[index] = '/js/dom/simple-dom-parser.js'; } -function main() { - try { - // Verify that sw.js scripts match background.html scripts - const rootDir = path.join(__dirname, '..'); - const extDirName = 'ext'; - const extDir = path.join(rootDir, extDirName); +function getImportedScripts(scriptPath, fields) { + const importedScripts = []; - const scripts = getAllHtmlScriptPaths(path.join(extDir, 'background.html')); - convertBackgroundScriptsToServiceWorkerScripts(scripts); - const importedScripts = []; + const importScripts = (...scripts) => { + importedScripts.push(...scripts); + }; - const importScripts = (...scripts2) => { - importedScripts.push(...scripts2); - }; + const vm = new VM(Object.assign({importScripts}, fields)); + vm.context.self = vm.context; + vm.execute([scriptPath]); - const vm = new VM({importScripts}); - vm.context.self = vm.context; - vm.execute(['sw.js']); + return importedScripts; +} + +function testServiceWorker() { + // Verify that sw.js scripts match background.html scripts + const extDir = path.join(__dirname, '..', 'ext'); + const scripts = getAllHtmlScriptPaths(path.join(extDir, 'background.html')); + convertBackgroundScriptsToServiceWorkerScripts(scripts); + const importedScripts = getImportedScripts('sw.js', {}); + assert.deepStrictEqual(scripts, importedScripts); - vm.assert.deepStrictEqual(scripts, importedScripts); + // Verify that eslint config lists files correctly + const expectedSwRulesFiles = filterScriptPaths(scripts); + const eslintConfig = loadEslint(); + const swRules = eslintConfig.overrides.find((item) => ( + typeof item.env === 'object' && + item.env !== null && + item.env.serviceworker === true + )); + assert.ok(typeof swRules !== 'undefined'); + assert.ok(Array.isArray(swRules.files)); + assert.deepStrictEqual(swRules.files, expectedSwRulesFiles); +} - // Verify that eslint config lists files correctly - const expectedSwRulesFiles = scripts.filter((src) => !src.startsWith('/lib/')).map((src) => `${extDirName}${src}`); - const eslintConfig = JSON.parse(fs.readFileSync(path.join(rootDir, '.eslintrc.json'), {encoding: 'utf8'})); - const swRules = eslintConfig.overrides.find((item) => ( - typeof item.env === 'object' && - item.env !== null && - item.env.serviceworker === true - )); - assert.ok(typeof swRules !== 'undefined'); - assert.ok(Array.isArray(swRules.files)); - assert.deepStrictEqual(swRules.files, expectedSwRulesFiles); +function main() { + try { + testServiceWorker(); } catch (e) { console.error(e); process.exit(-1); |