2018-04-03 17:52:33 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2018-04-03 17:52:33 -04:00
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
*/
|
|
|
|
import {SchematicTestRunner, UnitTestTree} from '@angular-devkit/schematics/testing';
|
|
|
|
import * as path from 'path';
|
|
|
|
|
|
|
|
import {Schema as ElementsOptions} from './schema';
|
|
|
|
|
|
|
|
// tslint:disable:max-line-length
|
|
|
|
describe('Elements Schematics', () => {
|
|
|
|
const schematicRunner = new SchematicTestRunner(
|
2020-04-13 19:40:21 -04:00
|
|
|
'@angular/elements',
|
|
|
|
path.join(__dirname, '../test-collection.json'),
|
|
|
|
);
|
2019-11-11 03:27:36 -05:00
|
|
|
const defaultOptions: ElementsOptions = {project: 'elements', skipPackageJson: false};
|
2018-04-03 17:52:33 -04:00
|
|
|
|
|
|
|
let appTree: UnitTestTree;
|
|
|
|
|
|
|
|
// tslint:disable-next-line:no-any
|
|
|
|
const workspaceOptions: any = {
|
|
|
|
name: 'workspace',
|
|
|
|
newProjectRoot: 'projects',
|
|
|
|
version: '6.0.0',
|
|
|
|
};
|
|
|
|
|
|
|
|
// tslint:disable-next-line:no-any
|
|
|
|
const appOptions: any = {
|
|
|
|
name: 'elements',
|
|
|
|
inlineStyle: false,
|
|
|
|
inlineTemplate: false,
|
|
|
|
routing: false,
|
|
|
|
style: 'css',
|
|
|
|
skipTests: false,
|
|
|
|
};
|
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
beforeEach(async () => {
|
2019-11-11 03:27:36 -05:00
|
|
|
appTree = await schematicRunner
|
|
|
|
.runExternalSchematicAsync('@schematics/angular', 'workspace', workspaceOptions)
|
|
|
|
.toPromise();
|
|
|
|
appTree =
|
|
|
|
await schematicRunner
|
|
|
|
.runExternalSchematicAsync('@schematics/angular', 'application', appOptions, appTree)
|
|
|
|
.toPromise();
|
2018-04-03 17:52:33 -04:00
|
|
|
});
|
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
it('should run the ng-add schematic', async () => {
|
2019-05-30 06:43:18 -04:00
|
|
|
const tree =
|
|
|
|
await schematicRunner.runSchematicAsync('ng-add', defaultOptions, appTree).toPromise();
|
2019-11-11 03:27:36 -05:00
|
|
|
expect(tree.readContent('/projects/elements/src/polyfills.ts'))
|
|
|
|
.toContain(`import 'document-register-element';`);
|
|
|
|
});
|
|
|
|
|
2020-04-13 19:40:21 -04:00
|
|
|
it('should add polyfill as a dependency in package.json', async () => {
|
2019-11-11 03:27:36 -05:00
|
|
|
const tree =
|
|
|
|
await schematicRunner.runSchematicAsync('ng-add', defaultOptions, appTree).toPromise();
|
|
|
|
const pkgJsonText = tree.readContent('/package.json');
|
|
|
|
const pkgJson = JSON.parse(pkgJsonText);
|
|
|
|
const {dependencies} = pkgJson;
|
|
|
|
expect(dependencies['document-register-element']).toBeDefined();
|
2018-04-03 17:52:33 -04:00
|
|
|
});
|
|
|
|
});
|