diff options
author | Felix Lange <fjl@twurst.com> | 2015-03-14 01:37:13 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2015-03-14 01:41:09 +0800 |
commit | 67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad (patch) | |
tree | 881f9b225a906fee3765ec2733211af5e431b48c /cmd/ethereum/blocktest.go | |
parent | e463479b6c7770e783a47aedcd07b02d3ee250b6 (diff) | |
download | go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.tar go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.tar.gz go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.tar.bz2 go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.tar.lz go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.tar.xz go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.tar.zst go-tangerine-67f8f83a1ba2a4dbd0f6f2fd075bb440f5c420ad.zip |
cmd/ethereum: add blocktest command
Diffstat (limited to 'cmd/ethereum/blocktest.go')
-rw-r--r-- | cmd/ethereum/blocktest.go | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/cmd/ethereum/blocktest.go b/cmd/ethereum/blocktest.go new file mode 100644 index 000000000..1bb3809cf --- /dev/null +++ b/cmd/ethereum/blocktest.go @@ -0,0 +1,66 @@ +package main + +import ( + "fmt" + + "github.com/codegangsta/cli" + "github.com/ethereum/go-ethereum/cmd/utils" + "github.com/ethereum/go-ethereum/eth" + "github.com/ethereum/go-ethereum/ethdb" + "github.com/ethereum/go-ethereum/ethutil" + "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()) != 2 { + utils.Fatalf("This command requires two arguments.") + } + file, testname := ctx.Args()[0], ctx.Args()[1] + + 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) (ethutil.Database, error) { return ethdb.NewMemDatabase() } + ethereum, err := eth.New(cfg) + if err != nil { + utils.Fatalf("%v", err) + } + + // import the genesis block + ethereum.ResetWithGenesisBlock(test.Genesis) + + // import pre accounts + if err := test.InsertPreState(ethereum.StateDb()); 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, starting ethereum.") + } + startEth(ctx, ethereum) +} |