docs(core): remove v10 mention from @Injectable warning (#37383)
In v9, we started showing a console warning when instantiating a token that inherited its @Injectable decorator rather than providing its own. This warning said that the pattern would become an error in v10. However, we have decided to wait until at least v11 to throw in this case, so this commit updates the warning to be less prescriptive about the exact version when the pattern will no longer be supported. PR Close #37383
This commit is contained in:
parent
561c0f81a0
commit
17e98198f4
|
@ -217,8 +217,8 @@ function getOwnDefinition<T>(type: any, def: ɵɵInjectableDef<T>): ɵɵInjectab
|
||||||
*
|
*
|
||||||
* @param type A type which may have `ɵprov`, via inheritance.
|
* @param type A type which may have `ɵprov`, via inheritance.
|
||||||
*
|
*
|
||||||
* @deprecated Will be removed in v10, where an error will occur in the scenario if we find the
|
* @deprecated Will be removed in a future version of Angular, where an error will occur in the
|
||||||
* `ɵprov` on an ancestor only.
|
* scenario if we find the `ɵprov` on an ancestor only.
|
||||||
*/
|
*/
|
||||||
export function getInheritedInjectableDef<T>(type: any): ɵɵInjectableDef<T>|null {
|
export function getInheritedInjectableDef<T>(type: any): ɵɵInjectableDef<T>|null {
|
||||||
// See `jit/injectable.ts#compileInjectable` for context on NG_PROV_DEF_FALLBACK.
|
// See `jit/injectable.ts#compileInjectable` for context on NG_PROV_DEF_FALLBACK.
|
||||||
|
@ -233,7 +233,8 @@ export function getInheritedInjectableDef<T>(type: any): ɵɵInjectableDef<T>|nu
|
||||||
console.warn(
|
console.warn(
|
||||||
`DEPRECATED: DI is instantiating a token "${
|
`DEPRECATED: DI is instantiating a token "${
|
||||||
typeName}" that inherits its @Injectable decorator but does not provide one itself.\n` +
|
typeName}" that inherits its @Injectable decorator but does not provide one itself.\n` +
|
||||||
`This will become an error in v10. Please add @Injectable() to the "${typeName}" class.`);
|
`This will become an error in a future version of Angular. Please add @Injectable() to the "${
|
||||||
|
typeName}" class.`);
|
||||||
return def;
|
return def;
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -46,7 +46,7 @@ export function compileInjectable(type: Type<any>, srcMeta?: Injectable): void {
|
||||||
// undecorated parent class. We work around it by defining a method which should be used
|
// undecorated parent class. We work around it by defining a method which should be used
|
||||||
// as a fallback. This should only be a problem in JIT mode, because in AOT TypeScript
|
// as a fallback. This should only be a problem in JIT mode, because in AOT TypeScript
|
||||||
// seems to have a workaround for static properties. When inheriting from an undecorated
|
// seems to have a workaround for static properties. When inheriting from an undecorated
|
||||||
// parent is no longer supported in v10, this can safely be removed.
|
// parent is no longer supported (v11 or later), this can safely be removed.
|
||||||
if (!type.hasOwnProperty(NG_PROV_DEF_FALLBACK)) {
|
if (!type.hasOwnProperty(NG_PROV_DEF_FALLBACK)) {
|
||||||
(type as any)[NG_PROV_DEF_FALLBACK] = () => (type as any)[NG_PROV_DEF];
|
(type as any)[NG_PROV_DEF_FALLBACK] = () => (type as any)[NG_PROV_DEF];
|
||||||
}
|
}
|
||||||
|
|
|
@ -1030,7 +1030,7 @@ describe('di', () => {
|
||||||
if (ivyEnabled) {
|
if (ivyEnabled) {
|
||||||
expect(warnSpy).toHaveBeenCalledWith(
|
expect(warnSpy).toHaveBeenCalledWith(
|
||||||
`DEPRECATED: DI is instantiating a token "SubSubClass" that inherits its @Injectable decorator but does not provide one itself.\n` +
|
`DEPRECATED: DI is instantiating a token "SubSubClass" that inherits its @Injectable decorator but does not provide one itself.\n` +
|
||||||
`This will become an error in v10. Please add @Injectable() to the "SubSubClass" class.`);
|
`This will become an error in a future version of Angular. Please add @Injectable() to the "SubSubClass" class.`);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1061,7 +1061,7 @@ describe('di', () => {
|
||||||
if (ivyEnabled) {
|
if (ivyEnabled) {
|
||||||
expect(warnSpy).toHaveBeenCalledWith(
|
expect(warnSpy).toHaveBeenCalledWith(
|
||||||
`DEPRECATED: DI is instantiating a token "MyRootService" that inherits its @Injectable decorator but does not provide one itself.\n` +
|
`DEPRECATED: DI is instantiating a token "MyRootService" that inherits its @Injectable decorator but does not provide one itself.\n` +
|
||||||
`This will become an error in v10. Please add @Injectable() to the "MyRootService" class.`);
|
`This will become an error in a future version of Angular. Please add @Injectable() to the "MyRootService" class.`);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue