Files
droplet/__test__/trust.spec.ts
2025-03-20 16:24:26 +11:00

87 lines
1.7 KiB
TypeScript

import test from "ava";
import {
generateRootCa,
generateClientCertificate,
verifyClientCertificate,
signNonce,
verifyNonce,
} from "../index.js";
import { randomUUID, sign } from "crypto";
test("generate ca", (t) => {
const [pub, priv] = generateRootCa();
t.pass();
});
test("generate ca & client certs", (t) => {
const [pub, priv] = generateRootCa();
const clientName = "My Test Client";
const [clientPub, clientPriv] = generateClientCertificate(
clientName,
clientName,
pub,
priv
);
t.pass();
});
test("trust chain", (t) => {
const [pub, priv] = generateRootCa();
const clientName = "My Test Client";
const [clientPub, clientPriv] = generateClientCertificate(
clientName,
clientName,
pub,
priv
);
const [invalidPub, invalidPriv] = generateRootCa();
const valid = verifyClientCertificate(clientPub, pub);
if (valid) return t.pass();
const invalid = verifyClientCertificate(invalidPub, pub);
if (!invalid) return t.pass();
return t.fail();
});
test("nonce signing", (t) => {
const [pub, priv] = generateRootCa();
const [clientPub, clientPriv] = generateClientCertificate(
"test",
"test",
pub,
priv
);
const nonce = randomUUID();
const signature = signNonce(clientPriv, nonce);
return t.pass();
});
test("nonce signing, and verification", (t) => {
const [pub, priv] = generateRootCa();
const [clientPub, clientPriv] = generateClientCertificate(
"test",
"test",
pub,
priv
);
const nonce = randomUUID();
const signature = signNonce(clientPriv, nonce);
const valid = verifyNonce(clientPub, nonce, signature);
if (!valid) return t.fail();
return t.pass();
});