napi-rs/examples/napi-compat-mode/__test__/napi8/async-cleanup.spec.ts
forehalo 2467b7139b
Introduce #[napi] procedural macro to automation development boilerplate (#696)
* 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>
2021-09-23 01:29:09 +08:00

28 lines
783 B
TypeScript

import { execSync } from 'child_process'
import { join } from 'path'
import ava from 'ava'
import { napiVersion } from '../napi-version'
const bindings = require('../../index.node')
const test = napiVersion >= 8 ? ava : ava.skip
test('should be able to add async cleanup hook', (t) => {
const output = execSync(
`node ${join(__dirname, 'sub-process.js')}`,
).toString()
t.is(output.trim(), 'Exit from sub process')
})
test('should be able to add removable async cleanup hook', (t) => {
const output = execSync(
`node ${join(__dirname, 'sub-process-removable.js')}`,
).toString()
t.is(output.trim(), 'Exit from sub process')
})
test('should be able to remove cleanup hook after added', (t) => {
t.notThrows(() => bindings.testRemoveAsyncCleanupHook())
})