499c6b5c36
* Adding L1RollupTxId field to Transactions * Adding rollup transactions signing key config and bug fixing within api.go. Signing key and endpoint will be removed when go handles batch fetching
56 lines
2.2 KiB
Go
56 lines
2.2 KiB
Go
// Copyright 2015 The go-ethereum Authors
|
|
// This file is part of the go-ethereum library.
|
|
//
|
|
// The go-ethereum library is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Lesser General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// The go-ethereum library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
package tests
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/ethereum/go-ethereum/params"
|
|
)
|
|
|
|
func TestTransaction(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
txt := new(testMatcher)
|
|
// These can't be parsed, invalid hex in RLP
|
|
txt.skipLoad("^ttWrongRLP/.*")
|
|
// We don't allow more than uint64 in gas amount
|
|
// This is a pseudo-consensus vulnerability, but not in practice
|
|
// because of the gas limit
|
|
txt.skipLoad("^ttGasLimit/TransactionWithGasLimitxPriceOverflow.json")
|
|
// We _do_ allow more than uint64 in gas price, as opposed to the tests
|
|
// This is also not a concern, as long as tx.Cost() uses big.Int for
|
|
// calculating the final cozt
|
|
txt.skipLoad(".*TransactionWithGasPriceOverflow.*")
|
|
|
|
// The nonce is too large for uint64. Not a concern, it means geth won't
|
|
// accept transactions at a certain point in the distant future
|
|
txt.skipLoad("^ttNonce/TransactionWithHighNonce256.json")
|
|
|
|
// The value is larger than uint64, which according to the test is invalid.
|
|
// Geth accepts it, which is not a consensus issue since we use big.Int's
|
|
// internally to calculate the cost
|
|
txt.skipLoad("^ttValue/TransactionWithHighValueOverflow.json")
|
|
txt.skipLoad("^ttSignature/TransactionWithTooManyRLPElements.json")
|
|
txt.walk(t, transactionTestDir, func(t *testing.T, name string, test *TransactionTest) {
|
|
cfg := params.MainnetChainConfig
|
|
if err := txt.checkFailure(t, name, test.Run(cfg)); err != nil {
|
|
t.Error(err)
|
|
}
|
|
})
|
|
}
|