2015-06-10 20:00:54 +03:00
|
|
|
package tests
|
2014-10-19 00:20:25 +03:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2015-06-11 01:11:30 +03:00
|
|
|
"fmt"
|
2014-10-19 00:20:25 +03:00
|
|
|
"io"
|
|
|
|
"io/ioutil"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
2015-06-10 23:29:42 +03:00
|
|
|
"path/filepath"
|
2015-07-04 18:45:18 +03:00
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/core"
|
2014-10-19 00:20:25 +03:00
|
|
|
)
|
|
|
|
|
2015-06-10 23:29:42 +03:00
|
|
|
var (
|
|
|
|
baseDir = filepath.Join(".", "files")
|
2015-07-03 10:40:07 +03:00
|
|
|
blockTestDir = filepath.Join(baseDir, "BlockchainTests")
|
2015-06-10 23:29:42 +03:00
|
|
|
stateTestDir = filepath.Join(baseDir, "StateTests")
|
|
|
|
transactionTestDir = filepath.Join(baseDir, "TransactionTests")
|
|
|
|
vmTestDir = filepath.Join(baseDir, "VMTests")
|
2015-06-11 00:04:06 +03:00
|
|
|
|
2015-07-03 10:40:07 +03:00
|
|
|
BlockSkipTests = []string{
|
2015-07-06 14:56:56 +03:00
|
|
|
// Fails in InsertPreState with: computed state root does not
|
|
|
|
// match genesis block bba25a96 0d8f85c8 Christoph said it will be
|
|
|
|
// fixed eventually
|
2015-07-03 10:40:07 +03:00
|
|
|
"SimpleTx3",
|
|
|
|
|
2015-07-06 14:56:56 +03:00
|
|
|
// These tests are not valid, as they are out of scope for RLP and
|
|
|
|
// the consensus protocol.
|
2015-07-03 10:40:07 +03:00
|
|
|
"BLOCK__RandomByteAtTheEnd",
|
|
|
|
"TRANSCT__RandomByteAtTheEnd",
|
|
|
|
"BLOCK__ZeroByteAtTheEnd",
|
|
|
|
"TRANSCT__ZeroByteAtTheEnd",
|
|
|
|
}
|
2015-07-06 14:56:56 +03:00
|
|
|
|
|
|
|
/* Go does not support transaction (account) nonces above 2^64. This
|
|
|
|
technically breaks consensus but is regarded as "reasonable
|
|
|
|
engineering constraint" as accounts cannot easily reach such high
|
|
|
|
nonce values in practice
|
|
|
|
*/
|
2015-06-15 00:55:03 +03:00
|
|
|
TransSkipTests = []string{"TransactionWithHihghNonce256"}
|
2015-07-06 14:56:56 +03:00
|
|
|
StateSkipTests = []string{}
|
2015-06-15 00:55:03 +03:00
|
|
|
VmSkipTests = []string{}
|
2015-06-10 23:29:42 +03:00
|
|
|
)
|
2015-06-10 20:00:54 +03:00
|
|
|
|
2015-06-15 00:55:03 +03:00
|
|
|
func readJson(reader io.Reader, value interface{}) error {
|
2014-10-19 00:20:25 +03:00
|
|
|
data, err := ioutil.ReadAll(reader)
|
|
|
|
if err != nil {
|
2015-06-11 01:11:30 +03:00
|
|
|
return fmt.Errorf("Error reading JSON file", err.Error())
|
|
|
|
}
|
|
|
|
|
2015-07-04 18:45:18 +03:00
|
|
|
core.DisableBadBlockReporting = true
|
2015-06-11 01:11:30 +03:00
|
|
|
if err = json.Unmarshal(data, &value); err != nil {
|
|
|
|
if syntaxerr, ok := err.(*json.SyntaxError); ok {
|
|
|
|
line := findLine(data, syntaxerr.Offset)
|
|
|
|
return fmt.Errorf("JSON syntax error at line %v: %v", line, err)
|
|
|
|
}
|
|
|
|
return fmt.Errorf("JSON unmarshal error: %v", err)
|
2014-10-19 00:20:25 +03:00
|
|
|
}
|
2015-06-10 23:10:33 +03:00
|
|
|
return nil
|
2014-10-19 00:20:25 +03:00
|
|
|
}
|
|
|
|
|
2015-06-15 00:55:03 +03:00
|
|
|
func readJsonHttp(uri string, value interface{}) error {
|
2014-10-19 00:20:25 +03:00
|
|
|
resp, err := http.Get(uri)
|
|
|
|
if err != nil {
|
2015-06-10 23:10:33 +03:00
|
|
|
return err
|
2014-10-19 00:20:25 +03:00
|
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
2015-06-15 00:55:03 +03:00
|
|
|
err = readJson(resp.Body, value)
|
2015-06-10 23:10:33 +03:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
2014-10-19 00:20:25 +03:00
|
|
|
}
|
|
|
|
|
2015-06-15 00:55:03 +03:00
|
|
|
func readJsonFile(fn string, value interface{}) error {
|
2014-10-19 00:20:25 +03:00
|
|
|
file, err := os.Open(fn)
|
|
|
|
if err != nil {
|
2015-06-10 23:10:33 +03:00
|
|
|
return err
|
2014-10-19 00:20:25 +03:00
|
|
|
}
|
|
|
|
defer file.Close()
|
|
|
|
|
2015-06-15 00:55:03 +03:00
|
|
|
err = readJson(file, value)
|
2015-06-10 23:10:33 +03:00
|
|
|
if err != nil {
|
2015-06-11 01:11:30 +03:00
|
|
|
return fmt.Errorf("%s in file %s", err.Error(), fn)
|
2015-06-10 23:10:33 +03:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2015-06-15 00:55:03 +03:00
|
|
|
|
|
|
|
// findLine returns the line number for the given offset into data.
|
|
|
|
func findLine(data []byte, offset int64) (line int) {
|
|
|
|
line = 1
|
|
|
|
for i, r := range string(data) {
|
|
|
|
if int64(i) >= offset {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if r == '\n' {
|
|
|
|
line++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|