This repository has been archived on 2023-04-09. You can view files and clone it, but cannot push or open issues or pull requests.
chainsafe-bls/test/spec/aggregate_sigs_verify.test.ts

43 lines
1.1 KiB
TypeScript
Raw Normal View History

2020-02-26 08:19:15 +00:00
import path from "path";
2020-11-05 20:55:25 +00:00
import bls, {initBLS} from "../../src";
import {describeDirectorySpecTest, InputType} from "@chainsafe/lodestar-spec-test-util";
2020-02-26 08:19:15 +00:00
2020-11-05 21:44:36 +00:00
interface IAggregateSigsVerifyTestCase {
2020-02-26 08:19:15 +00:00
data: {
input: {
2020-05-21 10:52:11 +00:00
pubkeys: string[];
messages: string[];
2020-02-26 08:19:15 +00:00
signature: string;
};
output: boolean;
};
}
before(async function f() {
try {
await initBLS();
} catch (e) {
console.log(e);
}
});
2020-11-05 21:44:36 +00:00
describeDirectorySpecTest<IAggregateSigsVerifyTestCase, boolean>(
2020-02-26 08:19:15 +00:00
"BLS - aggregate sigs verify",
2020-11-05 20:55:25 +00:00
path.join(__dirname, "../../node_modules/@chainsafe/eth2-spec-tests/tests/general/phase0/bls/aggregate_verify/small"),
2020-11-04 17:40:36 +00:00
(testCase) => {
const pubkeys = testCase.data.input.pubkeys.map((pubkey) => {
2020-05-21 10:52:11 +00:00
return Buffer.from(pubkey.replace("0x", ""), "hex");
2020-02-26 08:19:15 +00:00
});
2020-11-04 17:40:36 +00:00
const messages = testCase.data.input.messages.map((msg) => {
2020-05-21 10:52:11 +00:00
return Buffer.from(msg.replace("0x", ""), "hex");
2020-02-26 08:19:15 +00:00
});
2020-11-05 20:55:25 +00:00
return bls.verifyMultiple(pubkeys, messages, Buffer.from(testCase.data.input.signature.replace("0x", ""), "hex"));
2020-11-04 17:40:36 +00:00
},
2020-02-26 08:19:15 +00:00
{
inputTypes: {
data: InputType.YAML,
},
2020-11-04 17:40:36 +00:00
getExpected: (testCase) => testCase.data.output,
2020-02-26 08:19:15 +00:00
}
);