feat(docs-infra): add support for custom test commands in cli-based docs examples (#28020)
Previously, cli-based docs examples were tested using `yarn e2e ...`. In some cases, it might make sense to run different or additional checks for a docs example (when running `yarn example-e2e` in `aio/`). Currently, the only option is to define a custom project type and overwrite the `e2e` yarn script in `package.json`. Doing so (in addition to being cumbersome and verbose) would also end up in the `.zip` archive that users can download to run the example locally. This would be confusing, if these custom tests are specific to our CI needs. This commit adds support for defining a custom list of commands per example. These commands (if specified) would be run instead of the default `yarn e2e ...`, when testing the docs examples on CI (via `yarn example-e2e`). (This feature will be used to verify that the `service-worker-getting-started` example is set up correctly in a subsequent commit, but can be useful in other cases as well.) PR Close #28020
This commit is contained in:
parent
18ccfc6d73
commit
76104f395f
|
@ -204,20 +204,22 @@ function runProtractorAoT(appDir, outputFile) {
|
||||||
// CLI version
|
// CLI version
|
||||||
function runE2eTestsCLI(appDir, outputFile) {
|
function runE2eTestsCLI(appDir, outputFile) {
|
||||||
console.log(`\n\n=========== Running aio example tests for: ${appDir}`);
|
console.log(`\n\n=========== Running aio example tests for: ${appDir}`);
|
||||||
// `--preserve-symlinks` is needed due the symlinked `node_modules/` in each example.
|
|
||||||
// `--no-webdriver-update` is needed to preserve the ChromeDriver version already installed.
|
// `--no-webdriver-update` is needed to preserve the ChromeDriver version already installed.
|
||||||
const args = ['e2e', '--no-webdriver-update'];
|
const config = loadExampleConfig(appDir);
|
||||||
const e2eSpawn = spawnExt('yarn', args, { cwd: appDir });
|
const commands = config.e2e || [{ cmd: 'yarn', args: ['e2e', '--no-webdriver-update'] }];
|
||||||
return e2eSpawn.promise.then(
|
|
||||||
function () {
|
const e2eSpawnPromise = commands.reduce((prevSpawnPromise, { cmd, args }) => {
|
||||||
fs.appendFileSync(outputFile, `Passed: ${appDir}\n\n`);
|
return prevSpawnPromise.then(() => {
|
||||||
return finish(e2eSpawn.proc.pid, true);
|
const currSpawn = spawnExt(cmd, args, { cwd: appDir });
|
||||||
},
|
return currSpawn.promise.then(
|
||||||
function () {
|
() => Promise.resolve(finish(currSpawn.proc.pid, true)),
|
||||||
fs.appendFileSync(outputFile, `Failed: ${appDir}\n\n`);
|
() => Promise.reject(finish(currSpawn.proc.pid, false)));
|
||||||
return finish(e2eSpawn.proc.pid, false);
|
});
|
||||||
}
|
}, Promise.resolve());
|
||||||
);
|
|
||||||
|
return e2eSpawnPromise.then(
|
||||||
|
() => { fs.appendFileSync(outputFile, `Passed: ${appDir}\n\n`); return true; },
|
||||||
|
() => { fs.appendFileSync(outputFile, `Failed: ${appDir}\n\n`); return false; });
|
||||||
}
|
}
|
||||||
|
|
||||||
// Report final status.
|
// Report final status.
|
||||||
|
|
Loading…
Reference in New Issue