chore: add sandbox to ng-schematics (#9816)

This commit is contained in:
Nikolay Vitkov 2023-03-09 14:19:40 +01:00 committed by GitHub
parent cefc4eab47
commit 2335770aee
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 4381 additions and 4016 deletions

8242
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,22 +1,3 @@
# Outputs # Sandbox
src/**/*.js sandbox/
src/**/*.js.map
src/**/*.d.ts
# Keep files that serve as template
!src/**/files/**/*
# IDEs
.idea/
jsconfig.json
.vscode/
# Misc
node_modules/
npm-debug.log*
yarn-error.log*
# Mac OSX Finder files.
**/.DS_Store
.DS_Store

View File

@ -42,6 +42,22 @@ When adding schematics to your project you can to provide following options:
Check out our [contributing guide](https://pptr.dev/contributing) to get an overview of what you need to develop in the Puppeteer repo. Check out our [contributing guide](https://pptr.dev/contributing) to get an overview of what you need to develop in the Puppeteer repo.
### Sandbox
For easier development we provide a script to auto-generate the Angular project to test against. Simply run:
```bash
npm run sandbox -- --init
```
After that to run `@puppeteer/ng-schematics` against the Sandbox Angular project run:
```bash
npm run sandbox
# or to auto-build and then run schematics
npm run sandbox -- --build
```
### Unit Testing ### Unit Testing
The schematics utilize `@angular-devkit/schematics/testing` for verifying correct file creation and `package.json` updates. To execute the test suit: The schematics utilize `@angular-devkit/schematics/testing` for verifying correct file creation and `package.json` updates. To execute the test suit:

View File

@ -8,7 +8,8 @@
"clean": "tsc -b --clean && rm -rf lib && rm -rf test/build", "clean": "tsc -b --clean && rm -rf lib && rm -rf test/build",
"dev:test": "npm run test --watch", "dev:test": "npm run test --watch",
"dev": "npm run build --watch", "dev": "npm run build --watch",
"test": "wireit" "test": "wireit",
"sandbox": "node tools/sandbox.js"
}, },
"wireit": { "wireit": {
"build": { "build": {
@ -31,11 +32,13 @@
"files": [ "files": [
"**/tsconfig.*.json", "**/tsconfig.*.json",
"**/tsconfig.json", "**/tsconfig.json",
"src/**/*.ts" "src/**/*.ts",
"!src/**/files/**"
], ],
"output": [ "output": [
"lib/**/*.{ts,js}", "lib/**/*.{ts,js}",
"lib/**/*.{ts,js}.map" "lib/**/*.{ts,js}.map",
"!lib/**/files/**"
] ]
}, },
"test": { "test": {
@ -66,7 +69,8 @@
}, },
"devDependencies": { "devDependencies": {
"@types/node": "^14.15.0", "@types/node": "^14.15.0",
"@schematics/angular": "^14.2.8" "@schematics/angular": "^14.2.8",
"@angular/cli": "^15.2.2"
}, },
"files": [ "files": [
"lib", "lib",

View File

@ -0,0 +1,104 @@
/**
* 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.
*/
const {spawn} = require('child_process');
const {readFile, writeFile} = require('fs/promises');
const {join} = require('path');
const {cwd} = require('process');
const isInit = process.argv.indexOf('--init') !== -1;
const isBuild = process.argv.indexOf('--build') !== -1;
const commands = {
build: ['npm run build'],
createSandbox: ['npx ng new sandbox --defaults'],
runSchematics: [
{
command: 'npm run schematics',
options: {
cwd: join(cwd(), '/sandbox/'),
},
},
],
};
const scripts = {
// 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: 'npm run delete:file && schematics ../:ng-add --dry-run=false',
};
/**
*
* @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(message);
reject(message);
});
createProcess.on('exit', code => {
if (code === 0) {
resolve(true);
} else {
reject();
}
});
});
}
}
async function main() {
if (isInit) {
await executeCommand(commands.createSandbox);
const packageJsonFile = join(cwd(), '/sandbox/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);
}
await executeCommand(commands.runSchematics);
}
}
main().catch(() => {
console.log('\n');
});