- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.1k
Closed
Description
π Search Terms
switch exhaustiveness literals
π Version & Regression Information
This is mostly related with the new capabilities from #56941, so I'd say TS 5.8.
β― Playground Link
π» Code
type Payload =
  | { _tag: "auth"; username: string; password: string }
  | { _tag: "cart"; items: Array<{ id: string; quantity: number }> }
  | { _tag: "person"; name: string; age: number };
type PayloadContent = {
  [P in Payload as P["_tag"]]: Omit<P, "_tag">;
};
function mockPayload<P_TAG extends Payload["_tag"]>(
  str: P_TAG,
): PayloadContent[P_TAG] {
  switch (str) {
    case "auth":
      return { username: "test", password: "admin" };
    case "cart":
      return { items: [{ id: "123", quantity: 123 }] };
    case "person":
      return { name: "andrea", age: 27 };
    // default:
      // throw new Error("unknown tag");
  }
}π Actual behavior
Error: Function lacks ending return statement and return type does not include 'undefined'.
π Expected behavior
The exhaustiveness check should understand that there is no missing case to handle, so the default case should be optional.
Additional information about the issue
It's the companion issue for PR #60644 that will fix this if merged.
Metadata
Metadata
Assignees
Labels
No labels