diff --git a/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-styles.spec.ts b/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-styles.spec.ts index 12e992d8e751..37fb9d9cde75 100644 --- a/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-styles.spec.ts +++ b/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-styles.spec.ts @@ -1,6 +1,11 @@ import {createTestApp, patchDevkitTreeToExposeTypeScript} from '@angular/cdk/schematics/testing'; import {SchematicTestRunner, UnitTestTree} from '@angular-devkit/schematics/testing'; -import {createNewTestRunner, migrateComponents, THEME_FILE} from '../test-setup-helper'; +import { + APP_MODULE_FILE, + createNewTestRunner, + migrateComponents, + THEME_FILE, +} from '../test-setup-helper'; describe('card styles', () => { let runner: SchematicTestRunner; @@ -215,5 +220,31 @@ describe('card styles', () => { `, ); }); + + it('should migrate inline styles', async () => { + const oldContent = ` + import {Component} from '@angular/core'; + + @Component({ + template: '', + styles: ['.mat-card { color: red; }'], + }) + export class MyComp {} + `; + + const newContent = ` + import {Component} from '@angular/core'; + + @Component({ + template: '', + styles: ['.mat-mdc-card { color: red; }'], + }) + export class MyComp {} + `; + + cliAppTree.overwrite(APP_MODULE_FILE, oldContent); + const tree = await migrateComponents(['card'], runner, cliAppTree); + expect(tree.readContent(APP_MODULE_FILE)).toBe(newContent); + }); }); }); diff --git a/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-template.spec.ts b/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-template.spec.ts index 902d44a295ac..5e2311e2ce59 100644 --- a/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-template.spec.ts +++ b/src/material/schematics/ng-generate/mdc-migration/rules/components/card/card-template.spec.ts @@ -1,6 +1,11 @@ import {createTestApp, patchDevkitTreeToExposeTypeScript} from '@angular/cdk/schematics/testing'; import {SchematicTestRunner, UnitTestTree} from '@angular-devkit/schematics/testing'; -import {createNewTestRunner, migrateComponents, TEMPLATE_FILE} from '../test-setup-helper'; +import { + APP_MODULE_FILE, + createNewTestRunner, + migrateComponents, + TEMPLATE_FILE, +} from '../test-setup-helper'; describe('card template migrator', () => { let runner: SchematicTestRunner; @@ -110,4 +115,28 @@ describe('card template migrator', () => { `, ); }); + + it('should migrate inline templates', async () => { + const oldContent = ` + import {Component} from '@angular/core'; + + @Component({ + template: '' + }) + export class MyComp {} + `; + + const newContent = ` + import {Component} from '@angular/core'; + + @Component({ + template: '' + }) + export class MyComp {} + `; + + cliAppTree.overwrite(APP_MODULE_FILE, oldContent); + const tree = await migrateComponents(['card'], runner, cliAppTree); + expect(tree.readContent(APP_MODULE_FILE)).toBe(newContent); + }); }); diff --git a/src/material/schematics/ng-generate/mdc-migration/rules/template-migration.ts b/src/material/schematics/ng-generate/mdc-migration/rules/template-migration.ts index 9aeb15f7f2f9..d7362c07ecdc 100644 --- a/src/material/schematics/ng-generate/mdc-migration/rules/template-migration.ts +++ b/src/material/schematics/ng-generate/mdc-migration/rules/template-migration.ts @@ -16,7 +16,10 @@ export class TemplateMigration extends Migration