mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
16784fc8cb
**What kind of change does this PR introduce?** This replaces the default `ng e2e` with our custom builder. In the feature it seem possible to remove the necessity of the user running the server separately and run it from the builder - that will improve the easy of use and CI of this schematic. **Did you add tests for your changes?** **If relevant, did you update the documentation?** Yes - Updated `@puppeteer/ng-schematics` README.md **Summary** We want to not see the default `ng e2e` and we want to make it easier for the user to run commands. Angular Developer are likely to also use its' CLI. **Does this PR introduce a breaking change?** Yes. Users need to delete the default and initialize the schematics again. **Other information**
187 lines
5.6 KiB
TypeScript
187 lines
5.6 KiB
TypeScript
import expect from 'expect';
|
|
import sinon from 'sinon';
|
|
import https from 'https';
|
|
import {join} from 'path';
|
|
import {
|
|
SchematicTestRunner,
|
|
UnitTestTree,
|
|
} from '@angular-devkit/schematics/testing/schematic-test-runner';
|
|
import {JsonObject} from '@angular-devkit/core';
|
|
|
|
const WORKSPACE_OPTIONS = {
|
|
name: 'workspace',
|
|
newProjectRoot: 'projects',
|
|
version: '14.0.0',
|
|
};
|
|
|
|
const APPLICATION_OPTIONS = {
|
|
name: 'sandbox',
|
|
};
|
|
|
|
function getProjectFile(file: string): string {
|
|
return `/${WORKSPACE_OPTIONS.newProjectRoot}/${APPLICATION_OPTIONS.name}/${file}`;
|
|
}
|
|
|
|
function getAngularJsonScripts(tree: UnitTestTree): Record<string, any> {
|
|
const angularJson = tree.readJson('angular.json') as any;
|
|
return angularJson['projects']?.[APPLICATION_OPTIONS.name]?.['architect'];
|
|
}
|
|
|
|
function getPackageJson(tree: UnitTestTree): {
|
|
scripts: Record<string, string>;
|
|
devDependencies: string[];
|
|
} {
|
|
const packageJson = tree.readJson('package.json') as JsonObject;
|
|
return {
|
|
scripts: packageJson['scripts'] as any,
|
|
devDependencies: Object.keys(
|
|
packageJson['devDependencies'] as Record<string, string>
|
|
),
|
|
};
|
|
}
|
|
|
|
async function buildTestingTree(userOptions?: Record<string, any>) {
|
|
const runner = new SchematicTestRunner(
|
|
'schematics',
|
|
join(__dirname, '../../lib/schematics/collection.json')
|
|
);
|
|
const options = {
|
|
exportConfig: false,
|
|
testingFramework: 'jasmine',
|
|
...userOptions,
|
|
};
|
|
let workingTree: UnitTestTree;
|
|
|
|
// Build workspace
|
|
workingTree = await runner
|
|
.runExternalSchematicAsync(
|
|
'@schematics/angular',
|
|
'workspace',
|
|
WORKSPACE_OPTIONS
|
|
)
|
|
.toPromise();
|
|
// Build dummy application
|
|
workingTree = await runner
|
|
.runExternalSchematicAsync(
|
|
'@schematics/angular',
|
|
'application',
|
|
APPLICATION_OPTIONS,
|
|
workingTree
|
|
)
|
|
.toPromise();
|
|
|
|
return await runner
|
|
.runSchematicAsync('ng-add', options, workingTree)
|
|
.toPromise();
|
|
}
|
|
|
|
describe('@puppeteer/ng-schematics: ng-add', () => {
|
|
// Stop outgoing Request for version fetching
|
|
before(() => {
|
|
const httpsGetStub = sinon.stub(https, 'get');
|
|
httpsGetStub.returns({
|
|
on: (_: any, callback: () => void) => {
|
|
callback();
|
|
},
|
|
} as any);
|
|
});
|
|
|
|
after(() => {
|
|
sinon.restore();
|
|
});
|
|
|
|
it('should create base files and update to "package.json"', async () => {
|
|
const tree = await buildTestingTree();
|
|
const {devDependencies, scripts} = getPackageJson(tree);
|
|
const {e2e} = getAngularJsonScripts(tree);
|
|
|
|
expect(tree.files).toContain(getProjectFile('e2e/tsconfig.json'));
|
|
expect(tree.files).toContain(getProjectFile('e2e/tests/app.e2e.ts'));
|
|
expect(devDependencies).toContain('puppeteer');
|
|
expect(scripts['e2e']).toBe('ng e2e');
|
|
expect(e2e.builder).toBe('@puppeteer/ng-schematics:puppeteer');
|
|
});
|
|
|
|
it('should create Puppeteer config', async () => {
|
|
const {files} = await buildTestingTree({
|
|
exportConfig: true,
|
|
});
|
|
|
|
expect(files).toContain(getProjectFile('.puppeteerrc.cjs'));
|
|
});
|
|
|
|
it('should not create Puppeteer config', async () => {
|
|
const {files} = await buildTestingTree({
|
|
exportConfig: false,
|
|
});
|
|
|
|
expect(files).not.toContain(getProjectFile('.puppeteerrc.cjs'));
|
|
});
|
|
|
|
it('should create Jasmine files and update "package.json"', async () => {
|
|
const tree = await buildTestingTree({
|
|
testingFramework: 'jasmine',
|
|
});
|
|
const {devDependencies} = getPackageJson(tree);
|
|
const {e2e} = getAngularJsonScripts(tree);
|
|
|
|
expect(tree.files).toContain(getProjectFile('e2e/support/jasmine.json'));
|
|
expect(tree.files).toContain(getProjectFile('e2e/helpers/babel.js'));
|
|
expect(devDependencies).toContain('jasmine');
|
|
expect(devDependencies).toContain('@babel/core');
|
|
expect(devDependencies).toContain('@babel/register');
|
|
expect(devDependencies).toContain('@babel/preset-typescript');
|
|
expect(e2e.options.commands).toEqual([
|
|
[`jasmine`, '--config=./e2e/support/jasmine.json'],
|
|
]);
|
|
});
|
|
|
|
it('should create Jest files and update "package.json"', async () => {
|
|
const tree = await buildTestingTree({
|
|
testingFramework: 'jest',
|
|
});
|
|
const {devDependencies} = getPackageJson(tree);
|
|
const {e2e} = getAngularJsonScripts(tree);
|
|
|
|
expect(tree.files).toContain(getProjectFile('e2e/jest.config.js'));
|
|
expect(devDependencies).toContain('jest');
|
|
expect(devDependencies).toContain('@types/jest');
|
|
expect(devDependencies).toContain('ts-jest');
|
|
expect(e2e.options.commands).toEqual([
|
|
[`jest`, '-c', 'e2e/jest.config.js'],
|
|
]);
|
|
});
|
|
|
|
it('should create Mocha files and update "package.json"', async () => {
|
|
const tree = await buildTestingTree({
|
|
testingFramework: 'mocha',
|
|
});
|
|
const {devDependencies} = getPackageJson(tree);
|
|
const {e2e} = getAngularJsonScripts(tree);
|
|
|
|
expect(tree.files).toContain(getProjectFile('e2e/.mocharc.js'));
|
|
expect(tree.files).toContain(getProjectFile('e2e/babel.js'));
|
|
expect(devDependencies).toContain('mocha');
|
|
expect(devDependencies).toContain('@types/mocha');
|
|
expect(devDependencies).toContain('@babel/core');
|
|
expect(devDependencies).toContain('@babel/register');
|
|
expect(devDependencies).toContain('@babel/preset-typescript');
|
|
expect(e2e.options.commands).toEqual([
|
|
[`mocha`, '--config=./e2e/.mocharc.js'],
|
|
]);
|
|
});
|
|
|
|
it('should create Node files"', async () => {
|
|
const tree = await buildTestingTree({
|
|
testingFramework: 'node',
|
|
});
|
|
const {e2e} = getAngularJsonScripts(tree);
|
|
|
|
expect(tree.files).toContain(getProjectFile('e2e/.gitignore'));
|
|
expect(e2e.options.commands).toEqual([
|
|
[`tsc`, '-p', 'e2e/tsconfig.json'],
|
|
['node', '--test', 'e2e/'],
|
|
]);
|
|
});
|
|
});
|