From 4d5e97d8c8c766947b68361677e5fb628fc70256 Mon Sep 17 00:00:00 2001 From: Chris Manson Date: Mon, 29 May 2023 11:19:54 +0100 Subject: [PATCH] add tests for commonjs --- package.json | 1 + test-modules.mjs | 89 ++++++++++++++++++++++++++++++++++++++++++++++++ tests/test.cjs | 62 +++++++++++++++++++++++++++++++++ 3 files changed, 152 insertions(+) create mode 100644 test-modules.mjs create mode 100644 tests/test.cjs diff --git a/package.json b/package.json index 6a53203..fd00723 100644 --- a/package.json +++ b/package.json @@ -12,6 +12,7 @@ "start": "tsc --watch", "test": "concurrently --no-color \"npm:test:*\" --names \"test:\"", "test:ts": "node --loader ts-node/esm node_modules/.bin/qunit --require ts-node/register tests/test.ts", + "test:cjs": "qunit tests/test.cjs", "test:mjs": "qunit tests/test.mjs", "docs": "typedoc index.ts --out typedoc/", "docs:watch": "yarn docs -- --watch", diff --git a/test-modules.mjs b/test-modules.mjs new file mode 100644 index 0000000..1257fd6 --- /dev/null +++ b/test-modules.mjs @@ -0,0 +1,89 @@ +import { Project } from 'fixturify-project'; +import { Scenarios } from './index.js'; +import Qunit from 'qunit'; +import child_process from 'child_process'; + +function hello1(project) { + project.linkDependency('hello', { + baseDir: './fixtures', + resolveName: 'hello1', + }); +} + +function hello2(project) { + project.linkDependency('hello', { + baseDir: './fixtures', + resolveName: 'hello', + }); +} + +const scenarios = Scenarios.fromDir('./fixtures/app').expand({ + hello1, + hello2, +}); + +scenarios.forEachScenario((scenario) => { + Qunit.module(scenario.name, (hooks) => { + hooks.before(async function ({ app }) { + this.app = await scenario.prepare(); + }); + + Qunit.test( + 'yarn test', + async function (assert) { + const result = await this.app.execute('yarn --silent test'); + assert.equal( + result.stdout, + `TAP version 13 +ok 1 project > createHello +1..1 +# pass 1 +# skip 0 +# todo 0 +# fail 0 +` + ); + } + ); + + Qunit.test( + 'yarn bin inside app', + async function (assert) { + let result = await this.app.execute('yarn --silent bin'); + const yarnBin = result.stdout.trimRight(); + assert.ok(yarnBin.startsWith(this.app.dir)); + result = await this.app.execute('yarn --silent exec which qunit'); + assert.ok(result.stdout.startsWith(yarnBin)); + } + ); + + Qunit.test( + 'check scenario', + async function (assert) { + let result = await this.app.execute( + `node -p 'require("./index").polyfilled'` + ); + assert.equal( + result.stdout.trim(), + ('hello1' === scenario.name).toString() + ); + } + ); + }); +}); + +Qunit.module('cli', () => { + Qunit.test('list', (assert) => { + assert.deepEqual( + child_process + .execFileSync( + process.execPath, + ['cli.js', 'list', '--files', 'test-modules.mjs', '--matrix'], + { encoding: 'utf8' } + ) + .trimRight() + .split('\n'), + ['hello1', 'hello2'] + ); + }); +}); diff --git a/tests/test.cjs b/tests/test.cjs new file mode 100644 index 0000000..54ed450 --- /dev/null +++ b/tests/test.cjs @@ -0,0 +1,62 @@ +"use strict"; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const index_js_1 = require("./index.js"); +const qunit_1 = __importDefault(require("qunit")); +const child_process_1 = __importDefault(require("child_process")); +function hello1(project) { + project.linkDependency('hello', { + baseDir: './fixtures', + resolveName: 'hello1', + }); +} +function hello2(project) { + project.linkDependency('hello', { + baseDir: './fixtures', + resolveName: 'hello', + }); +} +const scenarios = index_js_1.Scenarios.fromDir('./fixtures/app').expand({ + hello1, + hello2, +}); +scenarios.forEachScenario((scenario) => { + qunit_1.default.module(scenario.name, (hooks) => { + hooks.before(async function () { + this.app = await scenario.prepare(); + }); + qunit_1.default.test('yarn test', async function (assert) { + const result = await this.app.execute('yarn --silent test'); + assert.equal(result.stdout, `TAP version 13 +ok 1 project > createHello +1..1 +# pass 1 +# skip 0 +# todo 0 +# fail 0 +`); + }); + qunit_1.default.test('yarn bin inside app', async function (assert) { + let result = await this.app.execute('yarn --silent bin'); + const yarnBin = result.stdout.trimRight(); + assert.ok(yarnBin.startsWith(this.app.dir)); + result = await this.app.execute('yarn --silent exec which qunit'); + assert.ok(result.stdout.startsWith(yarnBin)); + }); + qunit_1.default.test('check scenario', async function (assert) { + let result = await this.app.execute(`node -p 'require("./index").polyfilled'`); + assert.equal(result.stdout.trim(), ('hello1' === scenario.name).toString()); + }); + }); +}); +qunit_1.default.module('cli', () => { + qunit_1.default.test('list', (assert) => { + assert.deepEqual(child_process_1.default + .execFileSync(process.execPath, ['cli.js', 'list', '--files', 'test.js', '--matrix'], { encoding: 'utf8' }) + .trimRight() + .split('\n'), ['hello1', 'hello2']); + }); +}); +//# sourceMappingURL=test.js.map \ No newline at end of file