aboutsummaryrefslogtreecommitdiffstats
path: root/cmd/geth/blocktest.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2015-03-27 04:27:52 +0800
committerobscuren <geffobscura@gmail.com>2015-03-27 04:27:52 +0800
commitb0b0939879b9fb8453ec1c8fa2ceb522e56df3bc (patch)
tree5c506d98a654f387cd15e2c4aee7f24be5305f91 /cmd/geth/blocktest.go
parent829240c3252d9da09c9000e42b0686425a313e8b (diff)
downloadgo-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.tar
go-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.tar.gz
go-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.tar.bz2
go-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.tar.lz
go-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.tar.xz
go-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.tar.zst
go-tangerine-b0b0939879b9fb8453ec1c8fa2ceb522e56df3bc.zip
renamed ethereum => geth
Diffstat (limited to 'cmd/geth/blocktest.go')
-rw-r--r--cmd/geth/blocktest.go80
1 files changed, 80 insertions, 0 deletions
diff --git a/cmd/geth/blocktest.go b/cmd/geth/blocktest.go
new file mode 100644
index 000000000..d9cdfa83f
--- /dev/null
+++ b/cmd/geth/blocktest.go
@@ -0,0 +1,80 @@
+package main
+
+import (
+ "fmt"
+
+ "github.com/codegangsta/cli"
+ "github.com/ethereum/go-ethereum/cmd/utils"
+ "github.com/ethereum/go-ethereum/common"
+ "github.com/ethereum/go-ethereum/eth"
+ "github.com/ethereum/go-ethereum/ethdb"
+ "github.com/ethereum/go-ethereum/tests"
+)
+
+var blocktestCmd = cli.Command{
+ Action: runblocktest,
+ Name: "blocktest",
+ Usage: `loads a block test file`,
+ Description: `
+The first argument should be a block test file.
+The second argument is the name of a block test from the file.
+
+The block test will be loaded into an in-memory database.
+If loading succeeds, the RPC server is started. Clients will
+be able to interact with the chain defined by the test.
+`,
+}
+
+func runblocktest(ctx *cli.Context) {
+ if len(ctx.Args()) != 3 {
+ utils.Fatalf("Usage: ethereum blocktest <path-to-test-file> <test-name> {rpc, norpc}")
+ }
+ file, testname, startrpc := ctx.Args()[0], ctx.Args()[1], ctx.Args()[2]
+
+ bt, err := tests.LoadBlockTests(file)
+ if err != nil {
+ utils.Fatalf("%v", err)
+ }
+ test, ok := bt[testname]
+ if !ok {
+ utils.Fatalf("Test file does not contain test named %q", testname)
+ }
+
+ cfg := utils.MakeEthConfig(ClientIdentifier, Version, ctx)
+ cfg.NewDB = func(path string) (common.Database, error) { return ethdb.NewMemDatabase() }
+ cfg.MaxPeers = 0 // disable network
+ ethereum, err := eth.New(cfg)
+ if err != nil {
+ utils.Fatalf("%v", err)
+ }
+
+ // import the genesis block
+ ethereum.ResetWithGenesisBlock(test.Genesis)
+
+ // import pre accounts
+ statedb, err := test.InsertPreState(ethereum.StateDb())
+ if err != nil {
+ utils.Fatalf("could not insert genesis accounts: %v", err)
+ }
+
+ // insert the test blocks, which will execute all transactions
+ chain := ethereum.ChainManager()
+ if err := chain.InsertChain(test.Blocks); err != nil {
+ utils.Fatalf("Block Test load error: %v", err)
+ } else {
+ fmt.Println("Block Test chain loaded")
+ }
+
+ if err := test.ValidatePostState(statedb); err != nil {
+ utils.Fatalf("post state validation failed: %v", err)
+ }
+ fmt.Println("Block Test post state validated, starting ethereum.")
+
+ if startrpc == "rpc" {
+ startEth(ctx, ethereum)
+ utils.StartRPC(ethereum, ctx)
+ ethereum.WaitForShutdown()
+ } else {
+ startEth(ctx, ethereum)
+ }
+}