test(compiler-cli): fix i18n error tests (#40026)
Refactors the i18n error tests to be unit tests in ngtsc_spec.ts. There is two reasons for doing this. First is that the tests in compliace_old expected an expection to be be thrown but did not fail the test if no exception was thrown. That means that this test could miss catching a bug. It is also a big hacky to call compile directly and expect an exception to be thrown for diagnostics. Also, this can easily be unit tested and an end-to-end test is not necessary since we are not making use of the goldfiles for these tests. It is easier to maintain and less hacky to validate that we get helpful error messages when nesting i18n sections by calling getDiagnostics directly. PR Close #40026
This commit is contained in:
parent
973bb403a5
commit
9dedb62494
|
@ -1 +0,0 @@
|
||||||
|
|
|
@ -1,62 +0,0 @@
|
||||||
{
|
|
||||||
"$schema": "../../test_case_schema.json",
|
|
||||||
"cases": [
|
|
||||||
{
|
|
||||||
"description": "should throw on nested i18n sections",
|
|
||||||
"inputFiles": [
|
|
||||||
"nested_i18n_msg.ts"
|
|
||||||
],
|
|
||||||
"compilationModeFilter": [
|
|
||||||
"full compile"
|
|
||||||
],
|
|
||||||
"expectations": [
|
|
||||||
{
|
|
||||||
"expectedErrors": [
|
|
||||||
{
|
|
||||||
"message": "Cannot mark an element as translatable inside of a translatable section\\. Please remove the nested i18n marker\\.",
|
|
||||||
"location": "nested_i18n_msg\\.ts \\(7,5\\)"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "should throw on nested i18n sections with tags in between",
|
|
||||||
"inputFiles": [
|
|
||||||
"nested_i18n_msg_with_tags.ts"
|
|
||||||
],
|
|
||||||
"compilationModeFilter": [
|
|
||||||
"full compile"
|
|
||||||
],
|
|
||||||
"expectations": [
|
|
||||||
{
|
|
||||||
"expectedErrors": [
|
|
||||||
{
|
|
||||||
"message": "Cannot mark an element as translatable inside of a translatable section\\. Please remove the nested i18n marker\\.",
|
|
||||||
"location": "nested_i18n_msg_with_tags\\.ts \\(8,7\\)"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "should throw on nested i18n sections represented with <ng-container>s",
|
|
||||||
"inputFiles": [
|
|
||||||
"nested_i18n_msg_with_ng-containers.ts"
|
|
||||||
],
|
|
||||||
"compilationModeFilter": [
|
|
||||||
"full compile"
|
|
||||||
],
|
|
||||||
"expectations": [
|
|
||||||
{
|
|
||||||
"expectedErrors": [
|
|
||||||
{
|
|
||||||
"message": "Cannot mark an element as translatable inside of a translatable section\\. Please remove the nested i18n marker\\.",
|
|
||||||
"location": "nested_i18n_msg_with_ng-containers\\.ts \\(8,7\\)"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
|
@ -1,16 +0,0 @@
|
||||||
import {Component, NgModule} from '@angular/core';
|
|
||||||
|
|
||||||
@Component({
|
|
||||||
selector: 'my-component',
|
|
||||||
template: `
|
|
||||||
<div i18n>
|
|
||||||
<div i18n>Some content</div>
|
|
||||||
</div>
|
|
||||||
`,
|
|
||||||
})
|
|
||||||
export class MyComponent {
|
|
||||||
}
|
|
||||||
|
|
||||||
@NgModule({declarations: [MyComponent]})
|
|
||||||
export class MyModule {
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import {Component, NgModule} from '@angular/core';
|
|
||||||
|
|
||||||
@Component({
|
|
||||||
selector: 'my-component',
|
|
||||||
template: `
|
|
||||||
<ng-container i18n>
|
|
||||||
<div>
|
|
||||||
<ng-container i18n>Some content</ng-container>
|
|
||||||
</div>
|
|
||||||
</ng-container>
|
|
||||||
`,
|
|
||||||
})
|
|
||||||
export class MyComponent {
|
|
||||||
}
|
|
||||||
|
|
||||||
@NgModule({declarations: [MyComponent]})
|
|
||||||
export class MyModule {
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import {Component, NgModule} from '@angular/core';
|
|
||||||
|
|
||||||
@Component({
|
|
||||||
selector: 'my-component',
|
|
||||||
template: `
|
|
||||||
<div i18n>
|
|
||||||
<div>
|
|
||||||
<div i18n>Some content</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
`,
|
|
||||||
})
|
|
||||||
export class MyComponent {
|
|
||||||
}
|
|
||||||
|
|
||||||
@NgModule({declarations: [MyComponent]})
|
|
||||||
export class MyModule {
|
|
||||||
}
|
|
|
@ -3325,61 +3325,6 @@ $` + String.raw`{$I18N_4$}:ICU:\`;
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('errors', () => {
|
|
||||||
const verifyNestedSectionsError = (errorThrown: any, expectedErrorText: string) => {
|
|
||||||
expect(errorThrown.ngParseErrors.length).toBe(1);
|
|
||||||
const msg = errorThrown.ngParseErrors[0].toString();
|
|
||||||
expect(msg).toContain(
|
|
||||||
'Cannot mark an element as translatable inside of a translatable section. Please remove the nested i18n marker.');
|
|
||||||
expect(msg).toContain(expectedErrorText);
|
|
||||||
expect(msg).toMatch(/app\/spec\.ts\@\d+\:\d+/);
|
|
||||||
};
|
|
||||||
|
|
||||||
it('should throw on nested i18n sections', () => {
|
|
||||||
const files = getAppFilesWithTemplate(`
|
|
||||||
<div i18n>
|
|
||||||
<div i18n>Some content</div>
|
|
||||||
</div>
|
|
||||||
`);
|
|
||||||
try {
|
|
||||||
compile(files, angularFiles);
|
|
||||||
} catch (error) {
|
|
||||||
verifyNestedSectionsError(error, '[ERROR ->]<div i18n>Some content</div>');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should throw on nested i18n sections with tags in between', () => {
|
|
||||||
const files = getAppFilesWithTemplate(`
|
|
||||||
<div i18n>
|
|
||||||
<div>
|
|
||||||
<div i18n>Some content</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
`);
|
|
||||||
try {
|
|
||||||
compile(files, angularFiles);
|
|
||||||
} catch (error) {
|
|
||||||
verifyNestedSectionsError(error, '[ERROR ->]<div i18n>Some content</div>');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should throw on nested i18n sections represented with <ng-container>s', () => {
|
|
||||||
const files = getAppFilesWithTemplate(`
|
|
||||||
<ng-container i18n>
|
|
||||||
<div>
|
|
||||||
<ng-container i18n>Some content</ng-container>
|
|
||||||
</div>
|
|
||||||
</ng-container>
|
|
||||||
`);
|
|
||||||
try {
|
|
||||||
compile(files, angularFiles);
|
|
||||||
} catch (error) {
|
|
||||||
verifyNestedSectionsError(
|
|
||||||
error, '[ERROR ->]<ng-container i18n>Some content</ng-container>');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('namespaces', () => {
|
describe('namespaces', () => {
|
||||||
it('should handle namespaces inside i18n blocks', () => {
|
it('should handle namespaces inside i18n blocks', () => {
|
||||||
const input = `
|
const input = `
|
||||||
|
|
|
@ -7601,6 +7601,74 @@ export const Foo = Foo__PRE_R3__;
|
||||||
expect(getDiagnosticSourceCode(diags[0])).toBe('\'');
|
expect(getDiagnosticSourceCode(diags[0])).toBe('\'');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('i18n errors', () => {
|
||||||
|
it('should report helpful error message on nested i18n sections', () => {
|
||||||
|
env.write('test.ts', `
|
||||||
|
import {Component} from '@angular/core';
|
||||||
|
@Component({
|
||||||
|
selector: 'test-component',
|
||||||
|
template: '<div i18n><div i18n>Content</div></div>'
|
||||||
|
})
|
||||||
|
class TestComponent {}
|
||||||
|
`);
|
||||||
|
|
||||||
|
const diags = env.driveDiagnostics();
|
||||||
|
|
||||||
|
expect(diags.length).toEqual(1);
|
||||||
|
expect(diags[0].messageText)
|
||||||
|
.toEqual(
|
||||||
|
'Cannot mark an element as translatable inside of a translatable section.' +
|
||||||
|
' Please remove the nested i18n marker.');
|
||||||
|
expect(diags[0].file?.fileName).toEqual(absoluteFrom('/test.ts'));
|
||||||
|
expect(diags[0].file?.text.substr(diags[0].start!, diags[0].length))
|
||||||
|
.toEqual('<div i18n>Content</div>');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('report a diagnostic on nested i18n sections with tags in between', () => {
|
||||||
|
env.write('test.ts', `
|
||||||
|
import {Component} from '@angular/core';
|
||||||
|
@Component({
|
||||||
|
selector: 'test-component',
|
||||||
|
template: '<div i18n><div><div i18n>Content</div></div></div>'
|
||||||
|
})
|
||||||
|
class TestComponent {}
|
||||||
|
`);
|
||||||
|
|
||||||
|
const diags = env.driveDiagnostics();
|
||||||
|
|
||||||
|
expect(diags.length).toEqual(1);
|
||||||
|
expect(diags[0].messageText)
|
||||||
|
.toEqual(
|
||||||
|
'Cannot mark an element as translatable inside of a translatable section.' +
|
||||||
|
' Please remove the nested i18n marker.');
|
||||||
|
expect(diags[0].file?.fileName).toEqual(absoluteFrom('/test.ts'));
|
||||||
|
expect(diags[0].file?.text.substr(diags[0].start!, diags[0].length))
|
||||||
|
.toEqual('<div i18n>Content</div>');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('report a diagnostic on nested i18n sections represented with <ng-continers>s', () => {
|
||||||
|
env.write('test.ts', `
|
||||||
|
import {Component} from '@angular/core';
|
||||||
|
@Component({
|
||||||
|
selector: 'test-component',
|
||||||
|
template: '<div i18n><div><ng-container i18n>Content</ng-container></div></div>'
|
||||||
|
})
|
||||||
|
class TestComponent {}
|
||||||
|
`);
|
||||||
|
|
||||||
|
const diags = env.driveDiagnostics();
|
||||||
|
|
||||||
|
expect(diags.length).toEqual(1);
|
||||||
|
expect(diags[0].messageText)
|
||||||
|
.toEqual(
|
||||||
|
'Cannot mark an element as translatable inside of a translatable section.' +
|
||||||
|
' Please remove the nested i18n marker.');
|
||||||
|
expect(diags[0].file?.fileName).toEqual(absoluteFrom('/test.ts'));
|
||||||
|
expect(diags[0].file?.text.substr(diags[0].start!, diags[0].length))
|
||||||
|
.toEqual('<ng-container i18n>Content</ng-container>');
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue