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/fast_aggregate_verify.test.ts

40 lines
1.2 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 {describeDirectorySpecTest, InputType} from "@chainsafe/lodestar-spec-test-util";
import {hexToBytes} from "../../src/helpers";
2020-11-19 13:22:41 +00:00
import {SPEC_TESTS_DIR} from "../params";
import {describeForAllImplementations} from "../switch";
import {CoordType} from "@chainsafe/blst";
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: {
pubkeys: string[];
message: string;
signature: string;
};
output: boolean;
};
}
describeForAllImplementations((bls) => {
2020-11-19 13:22:41 +00:00
describeDirectorySpecTest<IAggregateSigsVerifyTestCase, boolean>(
"bls/fast_aggregate_verify/small",
path.join(SPEC_TESTS_DIR, "tests/general/phase0/bls/fast_aggregate_verify/small"),
2020-11-19 13:22:41 +00:00
(testCase) => {
const {pubkeys, message, signature} = testCase.data.input;
try {
return bls.Signature.fromBytes(hexToBytes(signature)).verifyAggregate(
pubkeys.map((hex) => bls.PublicKey.fromBytes(hexToBytes(hex), CoordType.jacobian, true)),
hexToBytes(message)
);
} catch (e) {
return false;
}
2020-02-26 08:19:15 +00:00
},
2020-11-19 13:22:41 +00:00
{
inputTypes: {data: InputType.YAML},
getExpected: (testCase) => testCase.data.output,
}
);
});