import * as types from "@peculiar/webcrypto-types"; import * as pvtsutils from "pvtsutils"; import { testCrypto, webCrypto } from "./utils"; context("PBKDF", () => { testCrypto(webCrypto, [ { name: "PBKDF2", actions: { deriveBits: [ { key: { format: "raw", data: new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 0]), algorithm: { name: "PBKDF2", }, extractable: false, keyUsages: ["deriveBits"], }, algorithm: { name: "PBKDF2", salt: new Uint8Array([1, 2, 3, 4]), hash: "SHA-256", iterations: 1000, } as types.Pbkdf2Params, data: pvtsutils.Convert.FromBase64("3GK58/4RT+UPLooz5HT1MQ=="), length: 128, }, ], deriveKey: [ { key: { format: "raw", data: new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8, 9, 0]), algorithm: { name: "PBKDF2", }, extractable: false, keyUsages: ["deriveKey"], }, algorithm: { name: "PBKDF2", salt: new Uint8Array([1, 2, 3, 4]), hash: "SHA-256", iterations: 1000, } as types.Pbkdf2Params, derivedKeyType: { name: "AES-CBC", length: 128, } as types.AesDerivedKeyParams, keyUsages: ["encrypt"], format: "raw", keyData: pvtsutils.Convert.FromBase64("3GK58/4RT+UPLooz5HT1MQ=="), }, ], }, }, ]); });