46 lines
1.3 KiB
TypeScript
46 lines
1.3 KiB
TypeScript
import {beforeAll, expect, test} from 'bun:test'
|
|
import {PrivateWrap, SecretBox} from '..'
|
|
import {pubkey_toString} from '../src/misc'
|
|
|
|
let k1!: CryptoKeyPair;
|
|
let k2!: CryptoKeyPair;
|
|
let message!: CryptoKey;
|
|
|
|
beforeAll(async () => {
|
|
k1 = await PrivateWrap.gen(false)
|
|
k2 = await PrivateWrap.gen(true)
|
|
message = await SecretBox.gen(true)
|
|
})
|
|
|
|
test('base case', async () => {
|
|
const box = await PrivateWrap.encrypt(message, k1.publicKey)
|
|
const unboxed = await box.decrypt(k1.privateKey)
|
|
expect(unboxed).toEqual(message)
|
|
})
|
|
test("Different key can't decrypt", async () => {
|
|
const box = await PrivateWrap.encrypt(message, k1.publicKey)
|
|
const unboxed = await box.decrypt(k2.privateKey)
|
|
expect(unboxed).toBeNull()
|
|
})
|
|
|
|
test('Key generation', async () => {
|
|
const ser1 = await pubkey_toString(k1.publicKey)
|
|
const ser2 = await pubkey_toString(k2.publicKey)
|
|
expect(ser1).not.toEqual(ser2)
|
|
|
|
expect(k1.privateKey.extractable).toBeFalse()
|
|
expect(k1.publicKey.extractable).toBeTrue()
|
|
expect(k2.privateKey.extractable).toBeTrue()
|
|
expect(k2.publicKey.extractable).toBeTrue()
|
|
})
|
|
|
|
test('serialization', async () => {
|
|
const box = await PrivateWrap.encrypt(message, k1.publicKey)
|
|
|
|
const ser = await box.toString()
|
|
const de = await PrivateWrap.fromString(ser)
|
|
expect(de).not.toBeNull()
|
|
|
|
expect(de).toEqual(box)
|
|
})
|