2023-11-01 03:32:09 +00:00
|
|
|
# Nimbus
|
2024-06-17 07:56:39 +00:00
|
|
|
# Copyright (c) 2019-2024 Status Research & Development GmbH
|
2023-11-01 03:32:09 +00:00
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
|
|
# http://opensource.org/licenses/MIT)
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except
|
|
|
|
# according to those terms.
|
|
|
|
|
2020-11-19 06:56:22 +00:00
|
|
|
import
|
2023-01-27 14:57:48 +00:00
|
|
|
unittest2,
|
2020-11-19 06:56:22 +00:00
|
|
|
eth/common/eth_types,
|
2024-06-17 07:56:39 +00:00
|
|
|
../nimbus/evm/internals,
|
2022-12-02 04:39:12 +00:00
|
|
|
../nimbus/core/pow/header
|
2020-11-19 06:56:22 +00:00
|
|
|
|
|
|
|
func toAddress(n: int): EthAddress =
|
|
|
|
result[19] = n.byte
|
2021-08-05 09:40:53 +00:00
|
|
|
|
2020-11-19 06:56:22 +00:00
|
|
|
func toAddress(a, b: int): EthAddress =
|
|
|
|
result[18] = a.byte
|
|
|
|
result[19] = b.byte
|
|
|
|
|
|
|
|
func toAddress(a, b, c: int): EthAddress =
|
|
|
|
result[17] = a.byte
|
|
|
|
result[18] = b.byte
|
|
|
|
result[19] = c.byte
|
|
|
|
|
|
|
|
proc miscMain*() =
|
|
|
|
suite "Misc test suite":
|
|
|
|
test "EthAddress to int":
|
|
|
|
check toAddress(0xff).toInt == 0xFF
|
|
|
|
check toAddress(0x10, 0x0).toInt == 0x1000
|
|
|
|
check toAddress(0x10, 0x0, 0x0).toInt == 0x100000
|
|
|
|
|
2021-08-18 12:40:33 +00:00
|
|
|
test "calcGasLimitEIP1559":
|
|
|
|
type
|
|
|
|
GLT = object
|
|
|
|
limit: GasInt
|
|
|
|
max : GasInt
|
|
|
|
min : GasInt
|
|
|
|
|
|
|
|
const testData = [
|
|
|
|
GLT(limit: 20000000, max: 20019530, min: 19980470),
|
|
|
|
GLT(limit: 40000000, max: 40039061, min: 39960939)
|
|
|
|
]
|
|
|
|
|
|
|
|
for x in testData:
|
|
|
|
# Increase
|
|
|
|
var have = calcGasLimit1559(x.limit, 2*x.limit)
|
|
|
|
var want = x.max
|
|
|
|
check have == want
|
|
|
|
|
|
|
|
# Decrease
|
|
|
|
have = calcGasLimit1559(x.limit, 0)
|
|
|
|
want = x.min
|
|
|
|
check have == want
|
|
|
|
|
|
|
|
# Small decrease
|
|
|
|
have = calcGasLimit1559(x.limit, x.limit-1)
|
|
|
|
want = x.limit-1
|
|
|
|
check have == want
|
|
|
|
|
|
|
|
# Small increase
|
|
|
|
have = calcGasLimit1559(x.limit, x.limit+1)
|
|
|
|
want = x.limit+1
|
|
|
|
check have == want
|
|
|
|
|
|
|
|
# No change
|
|
|
|
have = calcGasLimit1559(x.limit, x.limit)
|
|
|
|
want = x.limit
|
|
|
|
check have == want
|
|
|
|
|
2020-11-19 06:56:22 +00:00
|
|
|
when isMainModule:
|
|
|
|
miscMain()
|