chore: update smoke.mjs for ng-schematics (#11544)

This commit is contained in:
Nikolay Vitkov 2023-12-18 15:55:52 +01:00 committed by GitHub
parent 1d52b86db7
commit 4805417a64
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 893 additions and 894 deletions

View File

@ -164,7 +164,7 @@ module.exports = {
// Brackets keep code readable and `return` intentions clear.
'arrow-body-style': ['error', 'always'],
// Error if comments do not adhere to `tsdoc`.
'tsdoc/syntax': 'error',
'tsdoc/syntax': 'warn',
// Keeps array types simple only when they are simple for readability.
'@typescript-eslint/array-type': ['error', {default: 'array-simple'}],
'no-unused-vars': 'off',

View File

@ -466,8 +466,17 @@ jobs:
run: npm ci
env:
PUPPETEER_SKIP_DOWNLOAD: true
- name: Setup cache for Chrome binary
uses: actions/cache@704facf57e6136b1bc63b828d79edcd491f0ee84 # v3.3.2
with:
path: ~/.cache/puppeteer/chrome
key: ${{ runner.os }}-Chrome-${{ hashFiles('packages/puppeteer-core/src/revisions.ts') }}-${{ hashFiles('packages/puppeteer/src/node/install.ts') }}
- name: Install Chrome
run: npm run postinstall
- name: Build Schematics
run: npm run build -w @puppeteer/ng-schematics
- name: Run tests
run: npm run test:smoke
run: node tools/smoke.mjs
working-directory: ./packages/ng-schematics
ng-schematics-smoke-tests-required:

1367
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -7,10 +7,7 @@
"clean": "../../tools/clean.js",
"dev:test": "npm run test --watch",
"dev": "npm run build --watch",
"sandbox:test": "node tools/sandbox.js --test",
"sandbox": "node tools/sandbox.mjs",
"test": "wireit",
"test:smoke": "wireit"
"test": "wireit"
},
"wireit": {
"build": {
@ -33,12 +30,6 @@
"dependencies": [
"build"
]
},
"test:smoke": {
"command": "node ./tools/smoke.mjs",
"dependencies": [
"build"
]
}
},
"keywords": [
@ -56,14 +47,14 @@
"node": ">=16.13.2"
},
"dependencies": {
"@angular-devkit/architect": "^0.1700.6",
"@angular-devkit/core": "^17.0.6",
"@angular-devkit/schematics": "^17.0.6"
"@angular-devkit/architect": "^0.1700.7",
"@angular-devkit/core": "^17.0.7",
"@angular-devkit/schematics": "^17.0.7"
},
"devDependencies": {
"@types/node": "^16.18.61",
"@schematics/angular": "^17.0.6",
"@angular/cli": "^17.0.6",
"@schematics/angular": "^17.0.7",
"@angular/cli": "^17.0.7",
"rxjs": "7.8.1"
},
"files": [

View File

@ -0,0 +1,143 @@
/**
* @license
* Copyright 2023 Google Inc.
* SPDX-License-Identifier: Apache-2.0
*/
import {spawn} from 'child_process';
import {randomUUID} from 'crypto';
import {readFile, writeFile} from 'fs/promises';
import {join} from 'path';
import {cwd} from 'process';
class AngularProject {
static ports = new Set();
static randomPort() {
const min = 4000;
const max = 9876;
return Math.floor(Math.random() * (max - min + 1) + min);
}
static port() {
const port = AngularProject.randomPort();
if (AngularProject.ports.has(port)) {
return AngularProject.port();
}
return port;
}
static #scripts = {
// Builds the ng-schematics before running them
'build:schematics': 'npm run --prefix ../../ build',
// Deletes all files created by Puppeteer Ng-Schematics to avoid errors
'delete:file':
'rm -f .puppeteerrc.cjs && rm -f tsconfig.e2e.json && rm -R -f e2e/',
// Runs the Puppeteer Ng-Schematics against the sandbox
schematics: 'schematics ../../:ng-add --dry-run=false',
'schematics:e2e': 'schematics ../../:e2e --dry-run=false',
'schematics:config': 'schematics ../../:config --dry-run=false',
'schematics:smoke':
'schematics ../../:ng-add --dry-run=false --test-runner="node" && ng e2e',
};
#name;
constructor(name) {
this.#name = name ?? randomUUID();
}
get name() {
return this.#name;
}
async executeCommand(command, options) {
const [executable, ...args] = command.split(' ');
await new Promise((resolve, reject) => {
const createProcess = spawn(executable, args, {
stdio: 'inherit',
shell: true,
...options,
});
createProcess.on('error', message => {
console.error(`Running ${command} exited with error:`, message);
reject(message);
});
createProcess.on('exit', code => {
if (code === 0) {
resolve(true);
} else {
reject();
}
});
});
}
async create() {
await this.createProject();
await this.updatePackageJson();
}
async updatePackageJson() {
const packageJsonFile = join(cwd(), `/sandbox/${this.#name}/package.json`);
const packageJson = JSON.parse(await readFile(packageJsonFile));
packageJson['scripts'] = {
...packageJson['scripts'],
...AngularProject.#scripts,
};
await writeFile(packageJsonFile, JSON.stringify(packageJson, null, 2));
}
get commandOptions() {
return {
...process.env,
cwd: join(cwd(), `/sandbox/${this.#name}/`),
};
}
async runNpmScripts(command) {
await this.executeCommand(`npm run ${command}`, this.commandOptions);
}
async runSchematics() {
await this.runNpmScripts('schematics');
}
async runSchematicsE2E() {
await this.runNpmScripts('schematics:e2e');
}
async runSchematicsConfig() {
await this.runNpmScripts('schematics:config');
}
async runSmoke() {
await this.runNpmScripts(
`schematics:smoke -- --port=${AngularProject.port()}`
);
}
}
export class AngularProjectSingle extends AngularProject {
async createProject() {
await this.executeCommand(
`ng new ${this.name} --directory=sandbox/${this.name} --defaults --skip-git`
);
}
}
export class AngularProjectMulti extends AngularProject {
async createProject() {
await this.executeCommand(
`ng new ${this.name} --create-application=false --directory=sandbox/${this.name} --skip-git`
);
await this.executeCommand(
`ng generate application core --style=css --routing=true`,
this.commandOptions
);
await this.executeCommand(
`ng generate application admin --style=css --routing=false`,
this.commandOptions
);
}
}

View File

@ -1,209 +0,0 @@
/**
* Copyright 2023 Google Inc. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import {spawn} from 'child_process';
import {readFile, writeFile} from 'fs/promises';
import {join} from 'path';
import {cwd} from 'process';
const commands = {
build: ['npm run build'],
createSandbox: ['npx ng new sandbox --defaults'],
createMultiWorkspace: [
'ng new sandbox --create-application=false --directory=multi',
],
createMultiProjects: [
{
command: 'ng generate application core --style=css --routing=true',
options: {
cwd: join(cwd(), '/multi/'),
},
},
{
command: 'ng generate application admin --style=css --routing=false',
options: {
cwd: join(cwd(), '/multi/'),
},
},
],
/**
* @param {Boolean} isMulti
*/
runSchematics: isMulti => {
return [
{
command: 'npm run schematics',
options: {
cwd: join(cwd(), isMulti ? '/multi/' : '/sandbox/'),
},
},
];
},
/**
* @param {Boolean} isMulti
*/
runSchematicsE2E: isMulti => {
return [
{
command: 'npm run schematics:e2e',
options: {
cwd: join(cwd(), isMulti ? '/multi/' : '/sandbox/'),
},
},
];
},
/**
* @param {Boolean} isMulti
*/
runSchematicsConfig: isMulti => {
return [
{
command: 'npm run schematics:config',
options: {
cwd: join(cwd(), isMulti ? '/multi/' : '/sandbox/'),
},
},
];
},
runSchematicsSmoke: isMulti => {
return [
{
command: 'npm run schematics:smoke',
options: {
cwd: join(cwd(), isMulti ? '/multi/' : '/sandbox/'),
},
},
];
},
};
const scripts = {
// Builds the ng-schematics before running them
'build:schematics': 'npm run --prefix ../ build',
// Deletes all files created by Puppeteer Ng-Schematics to avoid errors
'delete:file':
'rm -f .puppeteerrc.cjs && rm -f tsconfig.e2e.json && rm -R -f e2e/',
// Runs the Puppeteer Ng-Schematics against the sandbox
schematics: 'schematics ../:ng-add --dry-run=false',
'schematics:e2e': 'schematics ../:e2e --dry-run=false',
'schematics:config': 'schematics ../:config --dry-run=false',
'schematics:smoke':
'schematics ../:ng-add --dry-run=false --test-runner="node" && ng e2e',
};
/**
*
* @param {string | object} toExecute
* @returns {Promise<boolean>}
*/
async function executeCommand(commands) {
for (const toExecute of commands) {
let executable;
let args;
let options = {};
if (typeof toExecute === 'string') {
[executable, ...args] = toExecute.split(' ');
} else {
[executable, ...args] = toExecute.command.split(' ');
options = toExecute.options ?? {};
}
await new Promise((resolve, reject) => {
const createProcess = spawn(executable, args, {
stdio: 'inherit',
shell: true,
...options,
});
createProcess.on('error', message => {
console.error(`Running ${toExecute} exited with error:`, message);
reject(message);
});
createProcess.on('exit', code => {
if (code === 0) {
resolve(true);
} else {
reject();
}
});
});
}
}
/**
*
* @param {*} param0
*/
export async function runNgSchematicsSandbox({
isInit,
isMulti,
isBuild,
isE2E,
isConfig,
isSmoke,
}) {
if (isInit) {
if (isMulti) {
await executeCommand(commands.createMultiWorkspace);
await executeCommand(commands.createMultiProjects);
} else {
await executeCommand(commands.createSandbox);
}
const directory = isMulti ? 'multi' : 'sandbox';
const packageJsonFile = join(cwd(), `/${directory}/package.json`);
const packageJson = JSON.parse(await readFile(packageJsonFile));
packageJson['scripts'] = {
...packageJson['scripts'],
...scripts,
};
await writeFile(packageJsonFile, JSON.stringify(packageJson, null, 2));
} else {
if (isBuild) {
await executeCommand(commands.build);
}
if (isE2E) {
await executeCommand(commands.runSchematicsE2E(isMulti));
} else if (isConfig) {
await executeCommand(commands.runSchematicsConfig(isMulti));
} else if (isSmoke) {
await executeCommand(commands.runSchematicsSmoke(isMulti));
} else {
await executeCommand(commands.runSchematics(isMulti));
}
}
}
async function main() {
const options = {
isInit: process.argv.indexOf('--init') !== -1,
isMulti: process.argv.indexOf('--multi') !== -1,
isBuild: process.argv.indexOf('--build') !== -1,
isE2E: process.argv.indexOf('--e2e') !== -1,
isConfig: process.argv.indexOf('--config') !== -1,
};
const isShell = Object.values(options).some(value => {
return value;
});
if (isShell) {
await runNgSchematicsSandbox(options).catch(error => {
console.log('Something went wrong');
console.error(error);
});
}
}
main();

View File

@ -1,29 +1,21 @@
/**
* @license
* Copyright 2023 Google Inc.
* SPDX-License-Identifier: Apache-2.0
*/
import {execSync} from 'child_process';
import {runNgSchematicsSandbox} from './sandbox.mjs';
import {AngularProjectMulti, AngularProjectSingle} from './projects.mjs';
if (process.env.CI) {
// Need to install in CI
execSync('npm install -g @angular/cli@latest');
execSync('npm install -g @angular-devkit/schematics-cli');
}
await Promise.all([
runNgSchematicsSandbox({
isMulti: false,
isInit: true,
}),
runNgSchematicsSandbox({
isMulti: true,
isInit: true,
}),
]);
const single = new AngularProjectSingle();
const multi = new AngularProjectMulti();
await runNgSchematicsSandbox({
isMulti: false,
isSmoke: true,
});
await runNgSchematicsSandbox({
isMulti: true,
isSmoke: true,
});
await Promise.all([single.create(), multi.create()]);
await Promise.all([single.runSmoke(), multi.runSmoke()]);