Open
Description
This may be working as intended but the error message is at least unclear for this case. It's not obvious why explicit annotation with a Union is different than explicit annotation with a class type.
TypeScript Version: 3.9.4
Search Terms:
- assertion function union
- assertion function
Code
type Pet = Cat | Dog;
type Filter<V extends Pet, T extends 'dog' | 'cat' > = V extends { type: T } ? V : never
abstract class Base {
abstract type: 'dog' | 'cat'
assert<T extends 'dog' | 'cat'>(this: Pet, type: T): asserts this is Filter<Pet, T> {
if (this.type === type) return
throw new Error('nope')
}
}
class Dog extends Base {
type = 'dog' as const
bark() { }
}
class Cat extends Base {
type = 'cat' as const
meow() { }
}
const a: Pet = new Dog() as any
const b: Dog = new Dog() as any
a.assert('dog')
a.bark()
b.assert('dog')
b.bark()
Expected behavior:
a.assert()
to narrow the type and not complain about an explicit type annotation
Actual behavior:
a.asserts
is marked as implicitly typed
Playground Link:
Related Issues: