schangxiang@126.com
2025-06-13 f10d68fe7b934ba7ad8e8393f36f20878ed8155d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# espower-typescript
 
> power-assert instrumentor for TypeScript
 
[![npm version][npm-image]][npm-url]
![Node.js Version Support][node-version]
[![build status][travis-image]][travis-url]
[![Dependency Status][deps-image]][deps-url]
![License][license]
 
## TypeScript versions
 
espower-typescript v9.x is compatible with TypeScript v2.4+
 
## Usage (zero-config mode)
 
NOTE: If you use older version than v9, see [older document](https://github.com/power-assert-js/espower-typescript/blob/v8.1.4/README.md).
 
Install
 
```console
$ npm install -D espower-typescript power-assert mocha typescript @types/node @types/mocha
```
 
Create a test file (intensionally failed)
 
```typescript
// test/test.ts
import assert = require('assert');
 
describe('Array#join', () => {
  it('joins all elements into a string with separator', () => {
    assert(['a', 'b', 'c'].join(':') === 'a:b:c:');
  });
});
```
 
Run test
 
```console
$ ./node_modules/.bin/mocha --require espower-typescript/guess "test/**/*.ts"
```
 
Output
 
```
  1) Array#join
       joins all elements into a string with separator:
 
      AssertionError [ERR_ASSERTION]:   # test.ts:6
 
  assert(['a','b','c'].join(':') === 'a:b:c:')
         |             |         |
         ["a","b","c"] "a:b:c"   false
```
 
### CAUTION: don't use `import 'assert' from 'assert'`
 
Just use old style `import 'assert' = require('assert')` for assert module.
This is limitation.
 
## Configure
 
### If your tests are not in `test` directory
 
You can set test directory in your `package.json`
 
```json
{
    "name": "your-module",
    "description": "Your module",
    "version": "0.0.1",
    "directories": {
        "test": "spec/"
    },
...
}
```
 
Then, run mocha with `--require espower-typescript/guess`
 
```console
$ ./node_modules/.bin/mocha --require espower-typescript/guess "spec/**/*.ts"
```
 
Note: `'espower-typescript/guess'` is inspired by [intelli-espower-loader](https://github.com/azu/intelli-espower-loader)
 
### ts-node and `tsconfig.json`
 
espower-typescript uses [ts-node](https://github.com/TypeStrong/ts-node) internally.
It loads your [tsconfig.json](https://github.com/Microsoft/TypeScript/wiki/tsconfig.json) automatically.
 
### Disable type check (transpile only)
 
Use `TS_NODE_TRANSPILE_ONLY` env of ts-node
 
```console
$ TS_NODE_TRANSPILE_ONLY=1 ./node_modules/.bin/mocha --require espower-typescript/guess "test/**/*.ts"
```
 
### JSX/React
 
`.tsx` files are supported.
 
### `allowJs`
 
If `allowJs: true` in your `tsconfig.json`, assertions in `test/**/*.(js|jsx)` are empowered.
 
## License
 
- MIT License: Teppei Sato <teppeis@gmail.com>
- Includes [yosuke-furukawa/espower-traceur](https://github.com/yosuke-furukawa/espower-traceur)
- Includes [azu/espower-babel](https://github.com/azu/espower-babel)
 
[npm-image]: https://img.shields.io/npm/v/espower-typescript.svg
[npm-url]: https://npmjs.org/package/espower-typescript
[travis-image]: https://travis-ci.org/power-assert-js/espower-typescript.svg?branch=master
[travis-url]: https://travis-ci.org/power-assert-js/espower-typescript
[deps-image]: https://david-dm.org/power-assert-js/espower-typescript.svg
[deps-url]: https://david-dm.org/power-assert-js/espower-typescript
[node-version]: https://img.shields.io/badge/Node.js%20support-v6,v8,v10-brightgreen.svg
[license]: https://img.shields.io/npm/l/espower-typescript.svg