From eb431c5e0f7a6f8be0ed06f57313e3687a358835 Mon Sep 17 00:00:00 2001 From: arnaucube Date: Mon, 1 Nov 2021 18:51:31 +0100 Subject: [PATCH] Add circuit test utils --- .gitignore | 2 + package.json | 23 +++++++++ test/keccak256.js | 120 ++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 145 insertions(+) create mode 100644 .gitignore create mode 100644 package.json create mode 100644 test/keccak256.js diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..7a7b33a --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +package-lock.json +node_modules diff --git a/package.json b/package.json new file mode 100644 index 0000000..7dee12b --- /dev/null +++ b/package.json @@ -0,0 +1,23 @@ +{ + "name": "keccak-circom", + "version": "0.0.1", + "description": "Keccak256 hash ethereum compatible implementation in Circom", + "main": "index.js", + "directories": { + "test": "test" + }, + "scripts": { + "test": "mocha --max-old-space-size=4000" + }, + "author": "arnaucube", + "license": "GPL-3.0", + "dependencies": { + "circomlib": "^2.0.1" + }, + "devDependencies": { + "chai": "^4.3.4", + "circom_tester": "0.0.5", + "mocha": "^9.1.2", + "keccak256": "1.0.3" + } +} diff --git a/test/keccak256.js b/test/keccak256.js new file mode 100644 index 0000000..1506240 --- /dev/null +++ b/test/keccak256.js @@ -0,0 +1,120 @@ +const chai = require("chai"); +const path = require("path"); +const crypto = require("crypto"); +const F1Field = require("ffjavascript").F1Field; +const Scalar = require("ffjavascript").Scalar; +exports.p = Scalar.fromString("21888242871839275222246405745257275088548364400416034343698204186575808495617"); +const Fr = new F1Field(exports.p); + +const assert = chai.assert; + +const keccak256 = require("keccak256"); + +const wasm_tester = require("circom_tester").wasm; + +// const printSignal = require("./helpers/printsignal"); + +function bytesToU64(byteArray) { + var value = 0; + for ( var i = byteArray.length - 1; i >= 0; i--) { + value = (value * 256) + byteArray[i]; + } + + return value; +} +function u64ToBytes(long) { + var byteArray = [0, 0, 0, 0, 0, 0, 0, 0]; + + for ( var index = 0; index < byteArray.length; index ++ ) { + var byte = long & 0xff; + byteArray [ index ] = byte; + long = (long - byte) / 256 ; + } + + return byteArray; +} + +function u64ToBits(a) { + const aBytes = u64ToBytes(a); + return bytesToBits(aBytes); +} +function bytesToBits(b) { + const bits = []; + for (let i = 0; i < b.length; i++) { + for (let j = 0; j < 8; j++) { + if ((b[i]&(1< 0) { + bits.push(Fr.e(1)); + } else { + bits.push(Fr.e(0)); + } + } + } + return bits +} +function u64ArrayToBits(u) { + let r = []; + for (let i = 0; i < u.length; i++) { + r = r.concat(u64ToBits(u[i])); + } + return r +} +function bitsToU64(b) { + if (b.length != 64) { + console.log("b.length = ", b.length, " max=64"); + return; + } + const by = bitsToBytes(b) + return bytesToU64(by) +} +function bitsToBytes(a) { + const len = Math.floor((a.length -1 )/8)+1; + const b = []; + + for (let i=0; i { + let a = 3; + let aBits = u64ToBits(a); + let a2 = bitsToU64(aBits); + assert.equal(a2, a); + a = 12345; + aBits = u64ToBits(a); + a2 = bitsToU64(aBits); + 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]; + aBits = u64ArrayToBits(a); + a2 = bitsToU64Array(aBits); + // console.log("a", a); + // console.log("a2", a2); + + assert.deepEqual(a2, a); + }); +}); +