UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

157 lines 8.98 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const testing_1 = require("@angular-devkit/schematics/testing"); const schema_1 = require("@schematics/angular/component/schema"); const node_test_1 = require("node:test"); const test_app_1 = require("../testing/test-app"); const appOptions = { name: 'ng-zorro', inlineStyle: false, inlineTemplate: false, routing: false, style: schema_1.Style.Less, skipTests: false, skipPackageJson: false }; const defaultOptions = { name: 'test', inlineStyle: false, inlineTemplate: false, changeDetection: schema_1.ChangeDetection.Default, style: schema_1.Style.Less, skipTests: false, module: undefined, export: false, standalone: true, project: 'ng-zorro' }; (0, node_test_1.describe)('ng-component schematic', () => { let runner; let appTree; beforeEach(() => __awaiter(void 0, void 0, void 0, function* () { runner = new testing_1.SchematicTestRunner('schematics', require.resolve('../collection.json')); appTree = yield (0, test_app_1.createTestApp)(runner, Object.assign({}, appOptions)); })); it('should create a component', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign({}, defaultOptions); const tree = yield runner.runSchematic('component', options, appTree); const files = tree.files; expect(files).toEqual(jasmine.arrayContaining([ '/projects/ng-zorro/src/app/test/test.component.less', '/projects/ng-zorro/src/app/test/test.component.html', '/projects/ng-zorro/src/app/test/test.component.spec.ts', '/projects/ng-zorro/src/app/test/test.component.ts' ])); })); (0, node_test_1.describe)('style', () => { it('should create specified style', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { style: schema_1.Style.Sass }); const tree = yield runner.runSchematic('component', options, appTree); const files = tree.files.filter(file => file.startsWith('/projects/ng-zorro/src/app/test/')); expect(files).toEqual(jasmine.arrayContaining([ '/projects/ng-zorro/src/app/test/test.component.sass', '/projects/ng-zorro/src/app/test/test.component.html', '/projects/ng-zorro/src/app/test/test.component.spec.ts', '/projects/ng-zorro/src/app/test/test.component.ts' ])); })); it('should not create style file when inlineStyle is true', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { inlineStyle: true }); const tree = yield runner.runSchematic('component', options, appTree); const files = tree.files.filter(file => file.startsWith('/projects/ng-zorro/src/app/test/')); expect(files.length).toEqual(3); expect(files).toEqual(jasmine.arrayContaining([ '/projects/ng-zorro/src/app/test/test.component.html', '/projects/ng-zorro/src/app/test/test.component.spec.ts', '/projects/ng-zorro/src/app/test/test.component.ts' ])); })); it('should not create style file when style is none', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { style: schema_1.Style.None }); const tree = yield runner.runSchematic('component', options, appTree); const files = tree.files.filter(file => file.startsWith('/projects/ng-zorro/src/app/test/')); expect(files.length).toEqual(3); expect(files).toEqual(jasmine.arrayContaining([ '/projects/ng-zorro/src/app/test/test.component.html', '/projects/ng-zorro/src/app/test/test.component.spec.ts', '/projects/ng-zorro/src/app/test/test.component.ts' ])); })); }); (0, node_test_1.describe)('displayBlock', () => { it('should add display block styles to the component', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { displayBlock: true }); const tree = yield runner.runSchematic('component', options, appTree); const content = tree.readContent('/projects/ng-zorro/src/app/test/test.component.less'); expect(content).toMatch(/display: block/); })); it('should add display block styles to the component when inlineStyle is true', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { displayBlock: true, inlineStyle: true }); const tree = yield runner.runSchematic('component', options, appTree); const content = tree.readContent('/projects/ng-zorro/src/app/test/test.component.ts'); expect(content).toMatch(/display: block/); })); }); (0, node_test_1.describe)('flat', () => { it('should create a flat component', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { flat: true }); const tree = yield runner.runSchematic('component', options, appTree); const files = tree.files; expect(files).toEqual(jasmine.arrayContaining([ '/projects/ng-zorro/src/app/test.component.less', '/projects/ng-zorro/src/app/test.component.html', '/projects/ng-zorro/src/app/test.component.spec.ts', '/projects/ng-zorro/src/app/test.component.ts' ])); })); }); (0, node_test_1.describe)('classnameWithModule', () => { it('should find the closest module', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { standalone: false }); const closestModule = '/projects/ng-zorro/src/app/test/test.module.ts'; appTree.create(closestModule, ` import { NgModule } from '@angular/core'; @NgModule({ imports: [], declarations: [] }) export class ClosestModule { } `); const tree = yield runner.runSchematic('component', options, appTree); const fooModuleContent = tree.readContent(closestModule); expect(fooModuleContent).toMatch(/import { TestComponent } from '.\/test.component'/); })); it('should set classname with the closest module', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { classnameWithModule: true, standalone: false }); const testModule = '/projects/ng-zorro/src/app/test/test.module.ts'; appTree.create(testModule, ` import { NgModule } from '@angular/core'; @NgModule({ imports: [], declarations: [] }) export class TestModule { } `); const tree = yield runner.runSchematic('component', options, appTree); const fooModuleContent = tree.readContent(testModule); expect(fooModuleContent).toMatch(/import { TestTestComponent } from '.\/test.component'/); })); it('should set classname with the specified module', () => __awaiter(void 0, void 0, void 0, function* () { const options = Object.assign(Object.assign({}, defaultOptions), { classnameWithModule: true, module: 'app.module.ts', standalone: false }); const app = yield (0, test_app_1.createTestApp)(runner, Object.assign(Object.assign({}, appOptions), { standalone: false })); const tree = yield runner.runSchematic('component', options, app); const appComponentContent = tree.readContent('/projects/ng-zorro/src/app/app.module.ts'); expect(appComponentContent).toMatch(/import { AppTestComponent } from '.\/test\/test.component'/); })); }); }); //# sourceMappingURL=index.spec.js.map