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
|
|
|
|
|
|
|
interface AggregateSigsVerifyTestCase {
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
describeDirectorySpecTest<AggregateSigsVerifyTestCase, boolean>(
|
|
|
|
"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
|
|
|
}
|
|
|
|
);
|