TSCheck is a tool for finding bugs in hand-written TypeScript type definitions (.d.ts
files). It works by comparing the type definitions to the actual JavaScript library implementation.
- Install node.js if you don't already have it.
npm install -g tscheck
To check foo.d.ts
against the library foo.js
, run the command:
tscheck foo.js foo.d.ts
Or simply:
tscheck foo
Run tscheck -h
for a list of options.
TSCheck prints a series of warnings, one warning per line, in no particular order.
The warnings have the format foo.bar.baz: expected X but found Y
. This means the value one would get by evaluating the pseudo-expression foo.bar.baz
was expected to have type X
, but tscheck found something of type Y
instead.
If there is no output, it means tscheck found no bugs in your .d.ts
file. This does not guarantee that the type definitions are actually correct, it just means that tscheck could not find anything wrong.
In some cases, tscheck may get confused and report "false warnings", complaining about type definitions that are actually correct. TSCheck apologizes for the inconvenience.
Pass --missing
to tscheck and it will suggest parts of the API that are not yet documented in the .d.ts
file. This is a useful way to check if you missed any parts of the API.
TSCheck cannot deduce the types for these features so it cannot write the .d.ts
file for you.
TSCheck can take several minutes to complete. If you are impatient, pass the flag --no-analysis
, this will perform a much faster check, but it will also find fewer bugs.
If you wish to check a specific part of the API, you can pass the flag --path foo
to only check paths that contain the string foo
; this will typically speed things up a lot.
If tscheck seems to get stuck, try passing --expose-gc
to the node process. This alleviates a problem with the v8 garbage collector.
Note that even for tiny .d.ts
files, tscheck still has a warm-up time of a few seconds due to parsing TypeScript's lib.d.ts
file.
The JavaScript library must be compiled to a single .js
file; so try to get the unminified compiled version of the library you are using. If you are testing a plug-in you should concatenate it with the base library (and use the --path
argument if possible, to only test the plug-in).
Please run tsc
on your .d.ts
file before running tscheck. tscheck assumes that your .d.ts
passes some well-formedness checks performed by the TypeScript compiler, and will react violently otherwise.
TSCheck will leave a .jsnap
file next to your .js
file. It contains a snapshot created with jsnap. Feel free to delete it; tscheck will regenerate it if necessary, although it speeds things up a bit if you leave it there.
Created by Asger Feldthaus as part of a research project at CASA, Aarhus University.
Programming language enthusiasts: consider looking at jsnap and tscore.