fix(typescript-types): Handle union types when filtering

This commit is contained in:
T. R. Bernstein
2025-07-16 11:23:11 +02:00
parent 3997eaa864
commit 8d51cb778c
2 changed files with 14 additions and 10 deletions

View File

@@ -4,6 +4,7 @@ import { expect } from 'tstyche'
interface ExampleObject {
nullvalue: null
simplevalue: string
optionalKey?: string
config: {
nullvalue: null
simplevalue: string
@@ -12,19 +13,20 @@ interface ExampleObject {
expect<KeyPaths<ExampleObject>>().type.toBe<'simplevalue' | 'config.simplevalue'>()
expect<KeyPaths<ExampleObject, never>>().type.toBe<
'nullvalue' | 'simplevalue' | 'config.nullvalue' | 'config.simplevalue'
'nullvalue' | 'simplevalue' | 'optionalKey' | 'config.nullvalue' | 'config.simplevalue'
>()
expect<KeyPaths<ExampleObject, null>>().type.toBe<'simplevalue' | 'config.simplevalue'>()
expect<KeyPaths<ExampleObject, null>>().type.toBe<'simplevalue' | 'optionalKey' | 'config.simplevalue'>()
expect<KeyPaths<ExampleObject, string>>().type.toBe<'nullvalue' | 'config.nullvalue'>()
expect<KeyPaths<ExampleObject, null, { separator: '-' }>>().type.toBe<'simplevalue' | 'config-simplevalue'>()
expect<KeyPaths<ExampleObject, null, { separator: '-' }>>().type.toBe<
'simplevalue' | 'optionalKey' | 'config-simplevalue'
>()
expect<KeyPaths<ExampleObject, null, { leavesOnly: false }>>().type.toBe<
'simplevalue' | 'config' | 'config.simplevalue'
'simplevalue' | 'optionalKey' | 'config' | 'config.simplevalue'
>()
expect<KeyPaths<any, string>>().type.toBe<unknown>()
expect<KeyPaths<any, never>>().type.toBe<unknown>()
expect<KeyPaths<any, string>>().type.toBeAssignableTo<never>()
expect<KeyPaths<any, never>>().type.toBeAssignableTo<never>()
expect<KeyPaths<ExampleObject, any>>().type.toBeAssignableTo<never>()
expect<KeyPaths<ExampleObject, unknown>>().type.toBeAssignableTo<never>()
expect<KeyPaths<any, any>>().type.toBeAssignableTo<never>()