2467b7139b
* napi procedural macro for basic rust/JavaScript types * introduce the `compat-mode` for `napi` and `napi-derive` crates for backward compatible * remove #[inline] and let compiler to decide the inline behavior * cli now can produce the `.d.ts` file for native binding * many tests and example for the new procedural macro Co-authored-by: LongYinan <lynweklm@gmail.com>
23 lines
549 B
TypeScript
23 lines
549 B
TypeScript
import test from 'ava'
|
|
|
|
import { napiVersion } from '../napi-version'
|
|
|
|
const bindings = require('../../index.node')
|
|
|
|
test('should call callback with the first arguments as an Error', async (t) => {
|
|
if (napiVersion < 4) {
|
|
t.is(bindings.testTsfnError, undefined)
|
|
return
|
|
}
|
|
await new Promise<void>((resolve, reject) => {
|
|
bindings.testTsfnError((err: Error) => {
|
|
try {
|
|
t.is(err instanceof Error, true)
|
|
t.is(err.message, 'invalid')
|
|
resolve()
|
|
} catch (err) {
|
|
reject(err)
|
|
}
|
|
})
|
|
})
|
|
})
|