napi-rs/examples/napi-compat-mode/__tests__/napi4/tokio_rt.spec.ts

50 lines
1.3 KiB
TypeScript
Raw Normal View History

import { readFileSync } from 'fs'
import { join } from 'path'
import test from 'ava'
import { napiVersion } from '../napi-version'
2020-07-08 00:59:09 +08:00
const bindings = require('../../index.node')
const filepath = join(__dirname, './example.txt')
test.serial('should execute future on tokio runtime', async (t) => {
if (napiVersion < 4) {
t.is(bindings.testExecuteTokioReadfile, undefined)
return
}
const fileContent = await bindings.testExecuteTokioReadfile(filepath)
t.true(Buffer.isBuffer(fileContent))
t.deepEqual(readFileSync(filepath), fileContent)
})
test.serial('should reject error from tokio future', async (t) => {
if (napiVersion < 4) {
t.is(bindings.testTokioError, undefined)
return
}
try {
await bindings.testTokioError(filepath)
throw new TypeError('Unreachable')
} catch (e) {
2021-11-19 14:58:21 +08:00
t.is((e as Error).message, 'Error from tokio future')
2020-07-08 00:59:09 +08:00
}
})
test.serial('should be able to execute future paralleled', async (t) => {
if (napiVersion < 4) {
t.is(bindings.testExecuteTokioReadfile, undefined)
return
}
const buffers = await Promise.all(
Array.from({ length: 50 }).map((_) =>
bindings.testExecuteTokioReadfile(filepath),
),
)
for (const fileContent of buffers) {
t.true(Buffer.isBuffer(fileContent))
t.deepEqual(readFileSync(filepath), fileContent)
}
})