mirror of
https://github.com/arnaucube/circomlib.git
synced 2026-02-06 18:56:43 +01:00
update smttestvectors.js
This commit is contained in:
3
.gitignore
vendored
3
.gitignore
vendored
@@ -60,6 +60,9 @@ typings/
|
|||||||
# next.js build output
|
# next.js build output
|
||||||
.next
|
.next
|
||||||
|
|
||||||
|
# Visual code configuration
|
||||||
|
.vscode
|
||||||
|
|
||||||
tmp
|
tmp
|
||||||
|
|
||||||
.DS_Store
|
.DS_Store
|
||||||
751
package-lock.json
generated
751
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -9,6 +9,29 @@ const expect = chai.expect;
|
|||||||
|
|
||||||
const bigInt = snarkjs.bigInt;
|
const bigInt = snarkjs.bigInt;
|
||||||
|
|
||||||
|
const bytesToHex = function (buff) {
|
||||||
|
return `0x${buff.toString("hex")}`;
|
||||||
|
};
|
||||||
|
|
||||||
|
const hexToBytes = function (hex) {
|
||||||
|
if (hex.substr(0, 2) === "0x") {
|
||||||
|
return Buffer.from(hex.substr(2), "hex");
|
||||||
|
}
|
||||||
|
|
||||||
|
return Buffer.from(hex, "hex");
|
||||||
|
};
|
||||||
|
|
||||||
|
function bigIntToBuffer(number) {
|
||||||
|
const buff = Buffer.alloc(32);
|
||||||
|
let pos = buff.length - 1;
|
||||||
|
while (!number.isZero()) {
|
||||||
|
buff[pos] = number.and(255);
|
||||||
|
number = number.shiftRight(8);
|
||||||
|
pos -= 1;
|
||||||
|
}
|
||||||
|
return buff;
|
||||||
|
}
|
||||||
|
|
||||||
function stringifyBigInts(o) {
|
function stringifyBigInts(o) {
|
||||||
if ((typeof(o) == "bigint") || (o instanceof bigInt)) {
|
if ((typeof(o) == "bigint") || (o instanceof bigInt)) {
|
||||||
return o.toString(10);
|
return o.toString(10);
|
||||||
@@ -25,10 +48,10 @@ function stringifyBigInts(o) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function newEntryFromInts(a, b, c, d) {
|
function newEntryFromBigInts(a, b, c, d) {
|
||||||
return {
|
return {
|
||||||
hi: mimcjs.hash(c, d),
|
hi: mimcjs.multiHash([c, d]),
|
||||||
hv: mimcjs.hash(a, b),
|
hv: mimcjs.multiHash([a, b]),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -40,192 +63,191 @@ function smtHash(arr) {
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
describe("SMT Javascript test", function () {
|
describe("[sparse-merkle-tree] Javascript test", function () {
|
||||||
|
|
||||||
this.timeout(100000);
|
this.timeout(100000);
|
||||||
before( async () => {
|
before( async () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it("test MIMC7", async() => {
|
it("Mimc7 hash", async () => {
|
||||||
//const h = mimcjs.multiHash(1,2,3);
|
const entries = [bigInt(12), bigInt(45), bigInt(78), bigInt(41)];
|
||||||
//const h = smtHash([1,2,3]);
|
const test = entries.slice(2);
|
||||||
//console.log(h.toString(10));
|
const hi = mimcjs.multiHash(entries.slice(2));
|
||||||
|
const hiHex = bytesToHex(bigIntToBuffer(hi));
|
||||||
const mimcjs = require("../src/mimc7.js");
|
//"0x0a546e62170e636895398e3831a7834affd35adad67016ff2d5215828e643aaf"
|
||||||
const snarkjs = require("snarkjs");
|
|
||||||
const bigInt = snarkjs.bigInt;
|
|
||||||
const smt = require("../src/smt.js");
|
|
||||||
|
|
||||||
h = mimcjs.hash(1,2,91);
|
|
||||||
console.log(h);
|
|
||||||
|
|
||||||
function smtHash(arr) {
|
|
||||||
let r = bigInt(0);
|
|
||||||
for (let i=0; i<arr.length; i++) {
|
|
||||||
r = mimcjs.hash(r, bigInt(arr[i]), 91 );
|
|
||||||
}
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log(smtHash([1, 2, 3]));
|
|
||||||
// Test from old ver
|
|
||||||
});
|
});
|
||||||
|
|
||||||
//it("Should calculate hindex", async() => {
|
|
||||||
// const entry = newEntryFromInts(12, 45, 78, 41);
|
|
||||||
// //console.log(entry.hi.toString(16));
|
|
||||||
// expect(entry.hi.toString(16)).to.be.
|
|
||||||
// equal("114438e8321f62c4a1708f443a5a66f9c8fcb0958e7b7008332b71442610b7a0");
|
|
||||||
//});
|
|
||||||
|
|
||||||
//it("Should insert 2 elements and empty them", async () => {
|
// it("Add one claim", async () => {
|
||||||
|
// const entries = newEntryFromBigInts(bigInt(12), bigInt(45), bigInt(78), bigInt(41));
|
||||||
// const tree = await smt.newMemEmptyTrie();
|
// const tree = await smt.newMemEmptyTrie();
|
||||||
// const key1 = bigInt(111);
|
// const key1 = entries.hi;
|
||||||
// const value1 = bigInt(222);
|
// const value1 = entries.hv;
|
||||||
// const key2 = bigInt(333);
|
|
||||||
// const value2 = bigInt(444);
|
|
||||||
|
|
||||||
// await tree.insert(key1,value1);
|
// await tree.insert(key1,value1);
|
||||||
// await tree.insert(key2,value2);
|
// const root = tree.root;
|
||||||
// await tree.delete(key2);
|
// const rootBuff = bigIntToBuffer(root);
|
||||||
// await tree.delete(key1);
|
// const rootHex = bytesToHex(rootBuff);
|
||||||
|
// //0x2e4bd3b61579f9ed4d814dfa4228c743b853fb6d0b5d6a80735bd5aab579231f
|
||||||
// assert(tree.root.isZero());
|
// assert(tree.root.isZero());
|
||||||
//});
|
//});
|
||||||
|
|
||||||
//it("Should insert 3 elements in dferent order and should be the same", async () => {
|
|
||||||
// const keys = [bigInt(8), bigInt(9), bigInt(32)];
|
|
||||||
// const values = [bigInt(88), bigInt(99), bigInt(3232)];
|
|
||||||
// const tree1 = await smt.newMemEmptyTrie();
|
|
||||||
// const tree2 = await smt.newMemEmptyTrie();
|
|
||||||
// const tree3 = await smt.newMemEmptyTrie();
|
|
||||||
// const tree4 = await smt.newMemEmptyTrie();
|
|
||||||
// const tree5 = await smt.newMemEmptyTrie();
|
|
||||||
// const tree6 = await smt.newMemEmptyTrie();
|
|
||||||
|
|
||||||
// await tree1.insert(keys[0],values[0]);
|
|
||||||
// await tree1.insert(keys[1],values[1]);
|
|
||||||
// await tree1.insert(keys[2],values[2]);
|
|
||||||
|
|
||||||
// await tree2.insert(keys[0],values[0]);
|
|
||||||
// await tree2.insert(keys[2],values[2]);
|
|
||||||
// await tree2.insert(keys[1],values[1]);
|
|
||||||
|
|
||||||
// await tree3.insert(keys[1],values[1]);
|
|
||||||
// await tree3.insert(keys[0],values[0]);
|
|
||||||
// await tree3.insert(keys[2],values[2]);
|
|
||||||
|
|
||||||
// await tree4.insert(keys[1],values[1]);
|
|
||||||
// await tree4.insert(keys[2],values[2]);
|
|
||||||
// await tree4.insert(keys[0],values[0]);
|
|
||||||
|
|
||||||
// await tree5.insert(keys[2],values[2]);
|
|
||||||
// await tree5.insert(keys[0],values[0]);
|
|
||||||
// await tree5.insert(keys[1],values[1]);
|
|
||||||
|
|
||||||
// await tree6.insert(keys[2],values[2]);
|
|
||||||
// await tree6.insert(keys[1],values[1]);
|
|
||||||
// await tree6.insert(keys[0],values[0]);
|
|
||||||
|
|
||||||
// assert(tree1.root.equals(tree2.root));
|
|
||||||
// assert(tree2.root.equals(tree3.root));
|
|
||||||
// assert(tree3.root.equals(tree4.root));
|
|
||||||
// assert(tree4.root.equals(tree5.root));
|
|
||||||
// assert(tree5.root.equals(tree6.root));
|
|
||||||
|
|
||||||
// assert.equal(Object.keys(tree1.db.nodes).length, Object.keys(tree2.db.nodes).length);
|
|
||||||
// assert.equal(Object.keys(tree2.db.nodes).length, Object.keys(tree3.db.nodes).length);
|
|
||||||
// assert.equal(Object.keys(tree3.db.nodes).length, Object.keys(tree4.db.nodes).length);
|
|
||||||
// assert.equal(Object.keys(tree4.db.nodes).length, Object.keys(tree5.db.nodes).length);
|
|
||||||
// assert.equal(Object.keys(tree5.db.nodes).length, Object.keys(tree6.db.nodes).length);
|
|
||||||
|
|
||||||
// await tree1.delete(keys[0]);
|
|
||||||
// await tree1.delete(keys[1]);
|
|
||||||
// await tree2.delete(keys[1]);
|
|
||||||
// await tree2.delete(keys[0]);
|
|
||||||
// assert(tree1.root.equals(tree2.root));
|
|
||||||
|
|
||||||
// await tree3.delete(keys[0]);
|
|
||||||
// await tree3.delete(keys[2]);
|
|
||||||
// await tree4.delete(keys[2]);
|
|
||||||
// await tree4.delete(keys[0]);
|
|
||||||
// assert(tree3.root.equals(tree4.root));
|
|
||||||
|
|
||||||
// await tree5.delete(keys[1]);
|
|
||||||
// await tree5.delete(keys[2]);
|
|
||||||
// await tree6.delete(keys[2]);
|
|
||||||
// await tree6.delete(keys[1]);
|
|
||||||
// assert(tree5.root.equals(tree6.root));
|
|
||||||
|
|
||||||
// await tree1.delete(keys[2]);
|
|
||||||
// await tree2.delete(keys[2]);
|
|
||||||
// await tree3.delete(keys[1]);
|
|
||||||
// await tree4.delete(keys[1]);
|
|
||||||
// await tree5.delete(keys[0]);
|
|
||||||
// await tree6.delete(keys[0]);
|
|
||||||
|
|
||||||
// assert(tree1.root.isZero());
|
|
||||||
// assert(tree2.root.isZero());
|
|
||||||
// assert(tree3.root.isZero());
|
|
||||||
// assert(tree4.root.isZero());
|
|
||||||
// assert(tree5.root.isZero());
|
|
||||||
// assert(tree6.root.isZero());
|
|
||||||
|
|
||||||
// assert.equal(Object.keys(tree1.db.nodes).length, 0);
|
|
||||||
// assert.equal(Object.keys(tree2.db.nodes).length, 0);
|
|
||||||
// assert.equal(Object.keys(tree3.db.nodes).length, 0);
|
|
||||||
// assert.equal(Object.keys(tree4.db.nodes).length, 0);
|
|
||||||
// assert.equal(Object.keys(tree5.db.nodes).length, 0);
|
|
||||||
// assert.equal(Object.keys(tree6.db.nodes).length, 0);
|
|
||||||
//});
|
|
||||||
|
|
||||||
//it("Insert and remove 100 numbers randomly", async () => {
|
|
||||||
// function perm(a) {
|
|
||||||
// const arr = a.slice();
|
|
||||||
// const rArr = [];
|
|
||||||
// for (let i=0; i<arr.length; i++) {
|
|
||||||
// let rIdx = Math.floor(Math.random() * (arr.length - i));
|
|
||||||
// rArr.push(arr[rIdx]);
|
|
||||||
// arr[rIdx] = arr[arr.length - i - 1];
|
|
||||||
// }
|
|
||||||
// return rArr;
|
|
||||||
// }
|
|
||||||
// const tree = await smt.newMemEmptyTrie();
|
|
||||||
// const arr = [];
|
|
||||||
// const N = 100;
|
|
||||||
// for (let i=0; i<N; i++) {
|
|
||||||
// arr.push(bigInt(i));
|
|
||||||
// }
|
|
||||||
// const insArr = perm(arr);
|
|
||||||
// for (let i=0; i<N; i++) {
|
|
||||||
// await tree.insert(insArr[i], i);
|
|
||||||
// }
|
|
||||||
// const delArr = perm(insArr);
|
|
||||||
// for (let i=0; i<N; i++) {
|
|
||||||
// await tree.delete(delArr[i]);
|
|
||||||
// }
|
|
||||||
|
|
||||||
// assert(tree.root.isZero());
|
|
||||||
// assert.equal(Object.keys(tree.db.nodes).length, 0);
|
|
||||||
//});
|
|
||||||
|
|
||||||
//it("Should test update", async () => {
|
|
||||||
// const tree1 = await smt.newMemEmptyTrie();
|
|
||||||
// const tree2 = await smt.newMemEmptyTrie();
|
|
||||||
|
|
||||||
// await tree1.insert(8,88);
|
|
||||||
// await tree1.insert(9,99,);
|
|
||||||
// await tree1.insert(32,3232);
|
|
||||||
|
|
||||||
// await tree2.insert(8,888);
|
|
||||||
// await tree2.insert(9,999);
|
|
||||||
// await tree2.insert(32,323232);
|
|
||||||
|
|
||||||
// await tree1.update(8, 888);
|
|
||||||
// await tree1.update(9, 999);
|
|
||||||
// await tree1.update(32, 323232);
|
|
||||||
|
|
||||||
// assert(tree1.root.equals(tree2.root));
|
|
||||||
//});
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// describe("SMT Javascript test", function () {
|
||||||
|
// this.timeout(100000);
|
||||||
|
// before( async () => {
|
||||||
|
// });
|
||||||
|
|
||||||
|
// it("Should insert 2 elements and empty them", async () => {
|
||||||
|
// const tree = await smt.newMemEmptyTrie();
|
||||||
|
// const key1 = bigInt(111);
|
||||||
|
// const value1 = bigInt(222);
|
||||||
|
// const key2 = bigInt(333);
|
||||||
|
// const value2 = bigInt(444);
|
||||||
|
|
||||||
|
// await tree.insert(key1,value1);
|
||||||
|
// await tree.insert(key2,value2);
|
||||||
|
// await tree.delete(key2);
|
||||||
|
// await tree.delete(key1);
|
||||||
|
|
||||||
|
// assert(tree.root.isZero());
|
||||||
|
// });
|
||||||
|
|
||||||
|
// it("Should insert 3 elements in dferent order and should be the same", async () => {
|
||||||
|
// const keys = [bigInt(8), bigInt(9), bigInt(32)];
|
||||||
|
// const values = [bigInt(88), bigInt(99), bigInt(3232)];
|
||||||
|
// const tree1 = await smt.newMemEmptyTrie();
|
||||||
|
// const tree2 = await smt.newMemEmptyTrie();
|
||||||
|
// const tree3 = await smt.newMemEmptyTrie();
|
||||||
|
// const tree4 = await smt.newMemEmptyTrie();
|
||||||
|
// const tree5 = await smt.newMemEmptyTrie();
|
||||||
|
// const tree6 = await smt.newMemEmptyTrie();
|
||||||
|
|
||||||
|
// await tree1.insert(keys[0],values[0]);
|
||||||
|
// await tree1.insert(keys[1],values[1]);
|
||||||
|
// await tree1.insert(keys[2],values[2]);
|
||||||
|
|
||||||
|
// await tree2.insert(keys[0],values[0]);
|
||||||
|
// await tree2.insert(keys[2],values[2]);
|
||||||
|
// await tree2.insert(keys[1],values[1]);
|
||||||
|
|
||||||
|
// await tree3.insert(keys[1],values[1]);
|
||||||
|
// await tree3.insert(keys[0],values[0]);
|
||||||
|
// await tree3.insert(keys[2],values[2]);
|
||||||
|
|
||||||
|
// await tree4.insert(keys[1],values[1]);
|
||||||
|
// await tree4.insert(keys[2],values[2]);
|
||||||
|
// await tree4.insert(keys[0],values[0]);
|
||||||
|
|
||||||
|
// await tree5.insert(keys[2],values[2]);
|
||||||
|
// await tree5.insert(keys[0],values[0]);
|
||||||
|
// await tree5.insert(keys[1],values[1]);
|
||||||
|
|
||||||
|
// await tree6.insert(keys[2],values[2]);
|
||||||
|
// await tree6.insert(keys[1],values[1]);
|
||||||
|
// await tree6.insert(keys[0],values[0]);
|
||||||
|
|
||||||
|
// assert(tree1.root.equals(tree2.root));
|
||||||
|
// assert(tree2.root.equals(tree3.root));
|
||||||
|
// assert(tree3.root.equals(tree4.root));
|
||||||
|
// assert(tree4.root.equals(tree5.root));
|
||||||
|
// assert(tree5.root.equals(tree6.root));
|
||||||
|
|
||||||
|
// assert.equal(Object.keys(tree1.db.nodes).length, Object.keys(tree2.db.nodes).length);
|
||||||
|
// assert.equal(Object.keys(tree2.db.nodes).length, Object.keys(tree3.db.nodes).length);
|
||||||
|
// assert.equal(Object.keys(tree3.db.nodes).length, Object.keys(tree4.db.nodes).length);
|
||||||
|
// assert.equal(Object.keys(tree4.db.nodes).length, Object.keys(tree5.db.nodes).length);
|
||||||
|
// assert.equal(Object.keys(tree5.db.nodes).length, Object.keys(tree6.db.nodes).length);
|
||||||
|
|
||||||
|
// await tree1.delete(keys[0]);
|
||||||
|
// await tree1.delete(keys[1]);
|
||||||
|
// await tree2.delete(keys[1]);
|
||||||
|
// await tree2.delete(keys[0]);
|
||||||
|
// assert(tree1.root.equals(tree2.root));
|
||||||
|
|
||||||
|
// await tree3.delete(keys[0]);
|
||||||
|
// await tree3.delete(keys[2]);
|
||||||
|
// await tree4.delete(keys[2]);
|
||||||
|
// await tree4.delete(keys[0]);
|
||||||
|
// assert(tree3.root.equals(tree4.root));
|
||||||
|
|
||||||
|
// await tree5.delete(keys[1]);
|
||||||
|
// await tree5.delete(keys[2]);
|
||||||
|
// await tree6.delete(keys[2]);
|
||||||
|
// await tree6.delete(keys[1]);
|
||||||
|
// assert(tree5.root.equals(tree6.root));
|
||||||
|
|
||||||
|
// await tree1.delete(keys[2]);
|
||||||
|
// await tree2.delete(keys[2]);
|
||||||
|
// await tree3.delete(keys[1]);
|
||||||
|
// await tree4.delete(keys[1]);
|
||||||
|
// await tree5.delete(keys[0]);
|
||||||
|
// await tree6.delete(keys[0]);
|
||||||
|
|
||||||
|
// assert(tree1.root.isZero());
|
||||||
|
// assert(tree2.root.isZero());
|
||||||
|
// assert(tree3.root.isZero());
|
||||||
|
// assert(tree4.root.isZero());
|
||||||
|
// assert(tree5.root.isZero());
|
||||||
|
// assert(tree6.root.isZero());
|
||||||
|
|
||||||
|
// assert.equal(Object.keys(tree1.db.nodes).length, 0);
|
||||||
|
// assert.equal(Object.keys(tree2.db.nodes).length, 0);
|
||||||
|
// assert.equal(Object.keys(tree3.db.nodes).length, 0);
|
||||||
|
// assert.equal(Object.keys(tree4.db.nodes).length, 0);
|
||||||
|
// assert.equal(Object.keys(tree5.db.nodes).length, 0);
|
||||||
|
// assert.equal(Object.keys(tree6.db.nodes).length, 0);
|
||||||
|
// });
|
||||||
|
|
||||||
|
// it("Insert and remove 100 numbers randomly", async () => {
|
||||||
|
// function perm(a) {
|
||||||
|
// const arr = a.slice();
|
||||||
|
// const rArr = [];
|
||||||
|
// for (let i=0; i<arr.length; i++) {
|
||||||
|
// let rIdx = Math.floor(Math.random() * (arr.length - i));
|
||||||
|
// rArr.push(arr[rIdx]);
|
||||||
|
// arr[rIdx] = arr[arr.length - i - 1];
|
||||||
|
// }
|
||||||
|
// return rArr;
|
||||||
|
// }
|
||||||
|
// const tree = await smt.newMemEmptyTrie();
|
||||||
|
// const arr = [];
|
||||||
|
// const N = 100;
|
||||||
|
// for (let i=0; i<N; i++) {
|
||||||
|
// arr.push(bigInt(i));
|
||||||
|
// }
|
||||||
|
// const insArr = perm(arr);
|
||||||
|
// for (let i=0; i<N; i++) {
|
||||||
|
// await tree.insert(insArr[i], i);
|
||||||
|
// }
|
||||||
|
// const delArr = perm(insArr);
|
||||||
|
// for (let i=0; i<N; i++) {
|
||||||
|
// await tree.delete(delArr[i]);
|
||||||
|
// }
|
||||||
|
|
||||||
|
// assert(tree.root.isZero());
|
||||||
|
// assert.equal(Object.keys(tree.db.nodes).length, 0);
|
||||||
|
// });
|
||||||
|
|
||||||
|
// it("Should test update", async () => {
|
||||||
|
// const tree1 = await smt.newMemEmptyTrie();
|
||||||
|
// const tree2 = await smt.newMemEmptyTrie();
|
||||||
|
|
||||||
|
// await tree1.insert(8,88);
|
||||||
|
// await tree1.insert(9,99,);
|
||||||
|
// await tree1.insert(32,3232);
|
||||||
|
|
||||||
|
// await tree2.insert(8,888);
|
||||||
|
// await tree2.insert(9,999);
|
||||||
|
// await tree2.insert(32,323232);
|
||||||
|
|
||||||
|
// await tree1.update(8, 888);
|
||||||
|
// await tree1.update(9, 999);
|
||||||
|
// await tree1.update(32, 323232);
|
||||||
|
|
||||||
|
// assert(tree1.root.equals(tree2.root));
|
||||||
|
// });
|
||||||
|
|
||||||
|
// });
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user