2021-12-15 00:02:11 +01:00
|
|
|
# Constantine
|
|
|
|
# Copyright (c) 2018-2019 Status Research & Development GmbH
|
|
|
|
# Copyright (c) 2020-Present Mamy André-Ratsimbazafy
|
|
|
|
# Licensed and distributed under either of
|
|
|
|
# * MIT license (license terms in the root directory or at http://opensource.org/licenses/MIT).
|
|
|
|
# * Apache v2 license (license terms in the root directory or at http://www.apache.org/licenses/LICENSE-2.0).
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
|
|
|
import
|
|
|
|
# Standard library
|
2022-02-21 01:04:53 +01:00
|
|
|
std/[times, os, strutils, macros],
|
2021-12-15 00:02:11 +01:00
|
|
|
# 3rd party
|
2022-02-27 01:49:08 +01:00
|
|
|
pkg/jsony,
|
2021-12-15 00:02:11 +01:00
|
|
|
# Internals
|
2023-02-07 13:10:17 +01:00
|
|
|
../constantine/platforms/codecs,
|
2022-02-21 01:04:53 +01:00
|
|
|
../constantine/ethereum_evm_precompiles
|
2021-12-15 00:02:11 +01:00
|
|
|
|
|
|
|
type
|
2023-06-01 23:38:41 +02:00
|
|
|
PrecompileTests = object
|
2021-12-15 00:02:11 +01:00
|
|
|
`func`: string
|
|
|
|
fork: string
|
2023-06-01 23:38:41 +02:00
|
|
|
data: seq[PrecompileTest]
|
2021-12-15 00:02:11 +01:00
|
|
|
|
|
|
|
HexString = string
|
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
PrecompileTest = object
|
2021-12-15 00:02:11 +01:00
|
|
|
Input: HexString
|
|
|
|
Expected: HexString
|
|
|
|
Name: string
|
|
|
|
Gas: int
|
|
|
|
NoBenchmark: bool
|
|
|
|
|
|
|
|
const
|
|
|
|
TestVectorsDir* =
|
2022-02-21 01:04:53 +01:00
|
|
|
currentSourcePath.rsplit(DirSep, 1)[0] / "protocol_ethereum_evm_precompiles"
|
2021-12-15 00:02:11 +01:00
|
|
|
|
|
|
|
proc loadVectors(TestType: typedesc, filename: string): TestType =
|
|
|
|
let content = readFile(TestVectorsDir/filename)
|
|
|
|
result = content.fromJson(TestType)
|
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
template runPrecompileTests(filename: string, funcname: untyped) =
|
|
|
|
block:
|
|
|
|
proc `PrecompileTestrunner _ funcname`() =
|
|
|
|
let vec = loadVectors(PrecompileTests, filename)
|
|
|
|
echo "Running ", filename
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
for test in vec.data:
|
|
|
|
stdout.write " Testing " & test.Name & " ... "
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
# Length: 2 hex characters -> 1 byte
|
|
|
|
var inputbytes = newSeq[byte](test.Input.len div 2)
|
|
|
|
inputbytes.paddedFromHex(test.Input, bigEndian)
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
var expected = newSeq[byte](test.Expected.len div 2)
|
|
|
|
expected.paddedFromHex(test.Expected, bigEndian)
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
var r = newSeq[byte](test.Expected.len div 2)
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
let status = funcname(r, inputbytes)
|
|
|
|
if status != cttEVM_Success:
|
|
|
|
reset(r)
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
doAssert r == expected, "[Test Failure]\n" &
|
|
|
|
" " & funcname.astToStr & " status: " & $status & "\n" &
|
|
|
|
" " & "result: " & r.toHex() & "\n" &
|
|
|
|
" " & "expected: " & expected.toHex() & '\n'
|
2023-02-07 13:10:17 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
stdout.write "Success\n"
|
2023-02-07 13:10:17 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
`PrecompileTestrunner _ funcname`()
|
2021-12-15 00:02:11 +01:00
|
|
|
|
2023-06-01 23:38:41 +02:00
|
|
|
runPrecompileTests("bn256Add.json", eth_evm_ecadd)
|
|
|
|
runPrecompileTests("bn256mul.json", eth_evm_ecmul)
|
|
|
|
runPrecompileTests("pairing.json", eth_evm_ecpairing)
|
|
|
|
runPrecompileTests("modexp.json", eth_evm_modexp)
|
|
|
|
runPrecompileTests("modexp_eip2565.json", eth_evm_modexp)
|