infer-types
TypeScript icon, indicating that this package has built-in type declarations

0.0.2 • Public • Published

infer-types

Returns the exported inferred types from TypeScript.

This is a tool to test that the types you expect TypeScript to infer are correct - this is meant to be used in snapshot or plain tests.

Install

npm install --save-dev infer-types

How does it work?

It works by compiling the input file with TypeScript and look for every @export <name> declaration:

/** @export some-name */
const a = "hello";

The function returns an object, made from all the <name>s as keys, and types - as strings, as the object values, so in the previous example, the object would look like:

{
  "a": "string"
}

Usage

Let's say you have the following file:

// ./test-file.ts
 
function apply<T, R>(arg: T, fn: (arg: T) => R) {
  return fn(arg);
}
 
// apply is a generic function, and we'd like to know that a user that will use
// it, will get type safety and code completion, so no `any` will pop out.
//
// Let's make some test cases:
 
apply(10, /** @export number => number */ x => x + 1);
apply(10, /** @export number => string */ x => String(x));
apply("hello", /** @export string => number */ x => x.length);
 
type User = { name: string };
const user: User = { name: "Gal" };
 
apply(user, /** @export User => number */ x => x.name);

And in our testing framework of choice:

import { getTypes } from "infer-types";
 
test("infers correctly", () => {
  expect(getTypes("./test-file.ts")).toEqual({
    "number => number": "(x: number) => number",
    "number => string": "(x: number) => string",
    "string => number": "(x: string) => number",
    "User => string": "(x: User) => string"
  });
});

Readme

Keywords

Package Sidebar

Install

npm i infer-types

Weekly Downloads

1

Version

0.0.2

License

ISC

Unpacked Size

3.65 kB

Total Files

4

Last publish

Collaborators

  • schlez