mirror of
https://github.com/arnaucube/keccak256-circom.git
synced 2026-01-10 16:01:28 +01:00
Update js tests to work with bigint for u64
- Updated js tests to work with bigint for u64 to avoid overflows - Added one more test for Theta with bigger values
This commit is contained in:
4
.github/workflows/test.yml
vendored
4
.github/workflows/test.yml
vendored
@@ -12,6 +12,10 @@ jobs:
|
|||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v1
|
||||||
with:
|
with:
|
||||||
node-version: ${{ matrix.node-version }}
|
node-version: ${{ matrix.node-version }}
|
||||||
|
- name: install c dependencies
|
||||||
|
run: |
|
||||||
|
sudo apt install -y nlohmann-json3-dev
|
||||||
|
sudo apt install -y nasm
|
||||||
- name: Prepare circom
|
- name: Prepare circom
|
||||||
run: |
|
run: |
|
||||||
# once circom binary is published, instead of compiling from source
|
# once circom binary is published, instead of compiling from source
|
||||||
|
|||||||
@@ -42,6 +42,28 @@ func TestTheta(t *testing.T) {
|
|||||||
qt.Assert(t, bitsToU64Array(s[:]), qt.DeepEquals, sU64[:])
|
qt.Assert(t, bitsToU64Array(s[:]), qt.DeepEquals, sU64[:])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestTheta2(t *testing.T) {
|
||||||
|
input := []uint64{26388279066651, 246290629787648, 26388279902208, 25165850, 246290605457408, 7784628352, 844424965783552, 2305843009213694083, 844432714760192, 2305843009249345539, 637534226, 14848, 641204224, 14354, 3670528, 6308236288, 2130304761856, 648518346341354496, 6309216256, 648520476645130240, 4611706359392501763, 792677514882318336, 20340965113972, 4611732197915754499, 792633534417207412}
|
||||||
|
var s [25 * 64]bool
|
||||||
|
var sU64 [25]uint64
|
||||||
|
copy(s[:], u64ArrayToBits(input))
|
||||||
|
copy(sU64[:], input)
|
||||||
|
|
||||||
|
s = theta(s)
|
||||||
|
sU64 = thetaU64Version(sU64)
|
||||||
|
|
||||||
|
// fmt.Println(bitsToU64Array(s[:]))
|
||||||
|
qt.Assert(t, bitsToU64Array(s[:]), qt.DeepEquals, sU64[:])
|
||||||
|
qt.Assert(t, bitsToU64Array(s[:]), qt.DeepEquals,
|
||||||
|
[]uint64{3749081831850030700, 1297317621190464868, 10017560217643747862, 7854780639862409219, 13836147678645575967, 3749090635727681271, 1297915755455157604, 12323429615135705749, 7855062122598582297, 16141814766035214620, 3749090628446369381, 1297071330560683876, 10017586606556924438, 7854780639837253643, 13835971756788491039, 3749090634251287159, 1297070162329376100, 9369068259580659222, 7854780645071013913, 14484490034407743775, 8360757404916954740, 1801500877105239396, 10017570663003408994, 3243123208712177690, 14628605291203076459})
|
||||||
|
fmt.Println(bitsToU64(s[1*64:2*64]), s[1*64:2*64])
|
||||||
|
|
||||||
|
// compute again theta on the current state
|
||||||
|
s = theta(s)
|
||||||
|
sU64 = thetaU64Version(sU64)
|
||||||
|
qt.Assert(t, bitsToU64Array(s[:]), qt.DeepEquals, sU64[:])
|
||||||
|
}
|
||||||
|
|
||||||
func TestRhoPi(t *testing.T) {
|
func TestRhoPi(t *testing.T) {
|
||||||
s, sU64 := newS()
|
s, sU64 := newS()
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,7 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"chai": "^4.3.4",
|
"chai": "^4.3.4",
|
||||||
"circom_tester": "0.0.5",
|
"circom_tester": "0.0.9",
|
||||||
"mocha": "^9.1.2",
|
"mocha": "^9.1.2",
|
||||||
"keccak256": "1.0.3"
|
"keccak256": "1.0.3"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,29 +11,27 @@ const assert = chai.assert;
|
|||||||
const keccak256 = require("keccak256");
|
const keccak256 = require("keccak256");
|
||||||
|
|
||||||
const wasm_tester = require("circom_tester").wasm;
|
const wasm_tester = require("circom_tester").wasm;
|
||||||
|
const c_tester = require("circom_tester").c;
|
||||||
|
|
||||||
// const printSignal = require("./helpers/printsignal");
|
// const printSignal = require("./helpers/printsignal");
|
||||||
|
|
||||||
function bytesToU64(byteArray) {
|
function bytesToU64(byteArray) {
|
||||||
var value = 0;
|
// var value = 0;
|
||||||
|
var value = Fr.e(0);
|
||||||
for ( var i = byteArray.length - 1; i >= 0; i--) {
|
for ( var i = byteArray.length - 1; i >= 0; i--) {
|
||||||
value = (value * 256) + byteArray[i];
|
// value = (value * 256) + byteArray[i];
|
||||||
|
value = Fr.add(Fr.mul(Fr.e(value), Fr.e(256)), Fr.e(byteArray[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
function u64ToBytes(long) {
|
function u64ToBytes(a) {
|
||||||
var byteArray = [0, 0, 0, 0, 0, 0, 0, 0];
|
var b = Fr.e(a);
|
||||||
|
|
||||||
for ( var index = 0; index < byteArray.length; index ++ ) {
|
const buff = new Uint8Array(8);
|
||||||
var byte = long & 0xff;
|
Scalar.toRprLE(buff, 0, b, 8);
|
||||||
byteArray [ index ] = byte;
|
return buff;
|
||||||
long = (long - byte) / 256 ;
|
|
||||||
}
|
|
||||||
|
|
||||||
return byteArray;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function u64ToBits(a) {
|
function u64ToBits(a) {
|
||||||
const aBytes = u64ToBytes(a);
|
const aBytes = u64ToBytes(a);
|
||||||
return bytesToBits(aBytes);
|
return bytesToBits(aBytes);
|
||||||
@@ -42,10 +40,12 @@ function bytesToBits(b) {
|
|||||||
const bits = [];
|
const bits = [];
|
||||||
for (let i = 0; i < b.length; i++) {
|
for (let i = 0; i < b.length; i++) {
|
||||||
for (let j = 0; j < 8; j++) {
|
for (let j = 0; j < 8; j++) {
|
||||||
if ((b[i]&(1<<j)) > 0) {
|
if ((Number(b[i])&(1<<j)) > 0) {
|
||||||
bits.push(Fr.e(1));
|
// bits.push(Fr.e(1));
|
||||||
|
bits.push(1);
|
||||||
} else {
|
} else {
|
||||||
bits.push(Fr.e(0));
|
// bits.push(Fr.e(0));
|
||||||
|
bits.push(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -89,6 +89,13 @@ function bitsToU64Array(b) {
|
|||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function strsToBigInts(a) {
|
||||||
|
let b = [];
|
||||||
|
for (let i=0; i<a.length; i++) {
|
||||||
|
b[i] = Fr.e(a[i]);
|
||||||
|
}
|
||||||
|
return b;
|
||||||
|
}
|
||||||
function intsToBigInts(a) {
|
function intsToBigInts(a) {
|
||||||
let b = [];
|
let b = [];
|
||||||
for (let i=0; i<a.length; i++) {
|
for (let i=0; i<a.length; i++) {
|
||||||
@@ -96,6 +103,13 @@ function intsToBigInts(a) {
|
|||||||
}
|
}
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
function bigIntsToInts(a) {
|
||||||
|
let b = [];
|
||||||
|
for (let i=0; i<a.length; i++) {
|
||||||
|
b[i] = Number(a[i]);
|
||||||
|
}
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
describe("Utils test", function () {
|
describe("Utils test", function () {
|
||||||
this.timeout(100000);
|
this.timeout(100000);
|
||||||
@@ -109,11 +123,10 @@ describe("Utils test", function () {
|
|||||||
aBits = u64ToBits(a);
|
aBits = u64ToBits(a);
|
||||||
a2 = bitsToU64(aBits);
|
a2 = bitsToU64(aBits);
|
||||||
assert.equal(a2, a);
|
assert.equal(a2, a);
|
||||||
|
|
||||||
a = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
a = intsToBigInts([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
aBits = u64ArrayToBits(a);
|
aBits = u64ArrayToBits(a);
|
||||||
a2 = bitsToU64Array(aBits);
|
a2 = bitsToU64Array(aBits);
|
||||||
// console.log(a2, a);
|
|
||||||
assert.deepEqual(a2, a);
|
assert.deepEqual(a2, a);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -124,9 +137,56 @@ describe("Theta test", function () {
|
|||||||
|
|
||||||
it ("Theta (testvector generated from go)", async () => {
|
it ("Theta (testvector generated from go)", async () => {
|
||||||
const cir = await wasm_tester(path.join(__dirname, "circuits", "theta_test.circom"));
|
const cir = await wasm_tester(path.join(__dirname, "circuits", "theta_test.circom"));
|
||||||
|
|
||||||
|
const input = intsToBigInts([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
|
const expectedOut = intsToBigInts([26,9,13,29,47,31,14,8,22,34,16,3,3,19,37,21,24,30,12,56,14,29,25,9,51]);
|
||||||
|
const stateIn = u64ArrayToBits(input);
|
||||||
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
|
const witness = await cir.calculateWitness({ "in": stateIn }, true);
|
||||||
|
|
||||||
|
const stateOut = witness.slice(1, 1+(25*64));
|
||||||
|
const stateOutU64 = bitsToU64Array(stateOut);
|
||||||
|
// console.log(stateOutU64, expectedOut);
|
||||||
|
assert.deepEqual(stateOutU64, expectedOut);
|
||||||
|
});
|
||||||
|
it ("Theta (same test as previous, but using c_tester to ensure that circom_tester with c works as expected)", async () => {
|
||||||
|
const cir = await c_tester(path.join(__dirname, "circuits", "theta_test.circom"));
|
||||||
|
|
||||||
|
const input = intsToBigInts([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
|
const expectedOut = intsToBigInts([26,9,13,29,47,31,14,8,22,34,16,3,3,19,37,21,24,30,12,56,14,29,25,9,51]);
|
||||||
|
const stateIn = u64ArrayToBits(input);
|
||||||
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
|
const witness = await cir.calculateWitness({ "in": stateIn }, true);
|
||||||
|
|
||||||
|
const stateOut = witness.slice(1, 1+(25*64));
|
||||||
|
const stateOutU64 = bitsToU64Array(stateOut);
|
||||||
|
// console.log(stateOutU64, expectedOut);
|
||||||
|
assert.deepEqual(stateOutU64, expectedOut);
|
||||||
|
});
|
||||||
|
|
||||||
|
it ("Theta (testvector generated from go)", async () => {
|
||||||
|
const cir = await wasm_tester(path.join(__dirname, "circuits", "theta_test.circom"));
|
||||||
|
// const cir = await c_tester(path.join(__dirname, "circuits", "theta_test.circom"));
|
||||||
|
|
||||||
|
const input = strsToBigInts(["26388279066651", "246290629787648", "26388279902208",
|
||||||
|
"25165850", "246290605457408", "7784628352", "844424965783552",
|
||||||
|
"2305843009213694083", "844432714760192", "2305843009249345539",
|
||||||
|
"637534226", "14848", "641204224", "14354", "3670528", "6308236288",
|
||||||
|
"2130304761856", "648518346341354496", "6309216256", "648520476645130240",
|
||||||
|
"4611706359392501763", "792677514882318336", "20340965113972",
|
||||||
|
"4611732197915754499", "792633534417207412"]);
|
||||||
|
const expectedOut = strsToBigInts(["3749081831850030700", "1297317621190464868",
|
||||||
|
"10017560217643747862", "7854780639862409219", "13836147678645575967",
|
||||||
|
"3749090635727681271", "1297915755455157604", "12323429615135705749",
|
||||||
|
"7855062122598582297", "16141814766035214620", "3749090628446369381",
|
||||||
|
"1297071330560683876", "10017586606556924438", "7854780639837253643",
|
||||||
|
"13835971756788491039", "3749090634251287159", "1297070162329376100",
|
||||||
|
"9369068259580659222", "7854780645071013913", "14484490034407743775",
|
||||||
|
"8360757404916954740", "1801500877105239396", "10017570663003408994",
|
||||||
|
"3243123208712177690", "14628605291203076459"]);
|
||||||
|
|
||||||
const input = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
|
||||||
const expectedOut = [26,9,13,29,47,31,14,8,22,34,16,3,3,19,37,21,24,30,12,56,14,29,25,9,51];
|
|
||||||
const stateIn = u64ArrayToBits(input);
|
const stateIn = u64ArrayToBits(input);
|
||||||
const expectedOutBits = u64ArrayToBits(expectedOut);
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
@@ -134,9 +194,10 @@ describe("Theta test", function () {
|
|||||||
|
|
||||||
const stateOut = witness.slice(1, 1+(25*64));
|
const stateOut = witness.slice(1, 1+(25*64));
|
||||||
const stateOutU64 = bitsToU64Array(stateOut);
|
const stateOutU64 = bitsToU64Array(stateOut);
|
||||||
// console.log(stateOutU64, expectedOut);
|
|
||||||
assert.deepEqual(stateOutU64, expectedOut);
|
assert.deepEqual(stateOutU64, expectedOut);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("RhoPi test", function () {
|
describe("RhoPi test", function () {
|
||||||
@@ -145,12 +206,12 @@ describe("RhoPi test", function () {
|
|||||||
it ("RhoPi (testvector generated from go)", async () => {
|
it ("RhoPi (testvector generated from go)", async () => {
|
||||||
const cir = await wasm_tester(path.join(__dirname, "circuits", "rhopi_test.circom"));
|
const cir = await wasm_tester(path.join(__dirname, "circuits", "rhopi_test.circom"));
|
||||||
|
|
||||||
const input = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
const input = intsToBigInts([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
const expectedOut = [0, 105553116266496, 105553116266496, 37748736, 393216,
|
const expectedOut = strsToBigInts(["0", "105553116266496", "105553116266496", "37748736", "393216",
|
||||||
805306368, 9437184, 80, 562949953421312, 13835058055282163714,
|
"805306368", "9437184", "80", "562949953421312", "13835058055282163714",
|
||||||
2, 448, 436207616, 4864, 5242880, 536870912, 343597383680,
|
"2", "448", "436207616", "4864", "5242880", "536870912", "343597383680",
|
||||||
11264, 557056, 1657324662872342528, 9223372036854775808,
|
"11264", "557056", "1657324662872342528", "9223372036854775808",
|
||||||
288230376151711744, 7696581394432, 32985348833280, 84];
|
"288230376151711744", "7696581394432", "32985348833280", "84"]);
|
||||||
const stateIn = u64ArrayToBits(input);
|
const stateIn = u64ArrayToBits(input);
|
||||||
const expectedOutBits = u64ArrayToBits(expectedOut);
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
@@ -169,9 +230,9 @@ describe("Chi test", function () {
|
|||||||
it ("Chi (testvector generated from go)", async () => {
|
it ("Chi (testvector generated from go)", async () => {
|
||||||
const cir = await wasm_tester(path.join(__dirname, "circuits", "chi_test.circom"));
|
const cir = await wasm_tester(path.join(__dirname, "circuits", "chi_test.circom"));
|
||||||
|
|
||||||
const input = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
const input = intsToBigInts([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
const expectedOut = [2, 0, 6, 3, 5, 4, 14, 6, 12, 11, 14, 10, 14, 13, 15,
|
const expectedOut = intsToBigInts([2, 0, 6, 3, 5, 4, 14, 6, 12, 11, 14, 10, 14, 13, 15,
|
||||||
14, 18, 16, 30, 3, 22, 20, 30, 19, 25];
|
14, 18, 16, 30, 3, 22, 20, 30, 19, 25]);
|
||||||
const stateIn = u64ArrayToBits(input);
|
const stateIn = u64ArrayToBits(input);
|
||||||
const expectedOutBits = u64ArrayToBits(expectedOut);
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
@@ -190,8 +251,8 @@ describe("Iota test", function () {
|
|||||||
it ("Iota 3 (testvector generated from go)", async () => {
|
it ("Iota 3 (testvector generated from go)", async () => {
|
||||||
const cir = await wasm_tester(path.join(__dirname, "circuits", "iota3_test.circom"));
|
const cir = await wasm_tester(path.join(__dirname, "circuits", "iota3_test.circom"));
|
||||||
|
|
||||||
const input = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
const input = intsToBigInts([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
const expectedOut = [9223372039002292224,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
const expectedOut = strsToBigInts(["9223372039002292224",1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
const stateIn = u64ArrayToBits(input);
|
const stateIn = u64ArrayToBits(input);
|
||||||
const expectedOutBits = u64ArrayToBits(expectedOut);
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
@@ -205,8 +266,8 @@ describe("Iota test", function () {
|
|||||||
it ("Iota 10 (testvector generated from go)", async () => {
|
it ("Iota 10 (testvector generated from go)", async () => {
|
||||||
const cir = await wasm_tester(path.join(__dirname, "circuits", "iota10_test.circom"));
|
const cir = await wasm_tester(path.join(__dirname, "circuits", "iota10_test.circom"));
|
||||||
|
|
||||||
const input = [9223372039002292224,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
const input = strsToBigInts(["9223372039002292224",1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
const expectedOut = [9223372036854775817,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
|
const expectedOut = strsToBigInts(["9223372036854775817",1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24]);
|
||||||
const stateIn = u64ArrayToBits(input);
|
const stateIn = u64ArrayToBits(input);
|
||||||
const expectedOutBits = u64ArrayToBits(expectedOut);
|
const expectedOutBits = u64ArrayToBits(expectedOut);
|
||||||
|
|
||||||
@@ -238,4 +299,3 @@ describe("Keccak-Pad test", function () {
|
|||||||
assert.deepEqual(stateOutBytes, expectedOut);
|
assert.deepEqual(stateOutBytes, expectedOut);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user