diff options
-rw-r--r-- | cmd/geth/dao_test.go | 152 |
1 files changed, 68 insertions, 84 deletions
diff --git a/cmd/geth/dao_test.go b/cmd/geth/dao_test.go index 56e77ba0b..f90bb182d 100644 --- a/cmd/geth/dao_test.go +++ b/cmd/geth/dao_test.go @@ -80,91 +80,75 @@ var daoProForkGenesis = `{ var daoGenesisHash = common.HexToHash("5e1fc79cb4ffa4739177b5408045cd5d51c6cf766133f23f7cd72ee1f8d790e0") var daoGenesisForkBlock = big.NewInt(314) -// Tests that the DAO hard-fork number and the nodes support/opposition is correctly +// TestDAOForkBlockNewChain tests that the DAO hard-fork number and the nodes support/opposition is correctly // set in the database after various initialization procedures and invocations. -func TestDAODefaultMainnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, "", [][2]bool{{false, false}}, params.MainNetDAOForkBlock, true) -} -func TestDAOSupportMainnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, "", [][2]bool{{true, false}}, params.MainNetDAOForkBlock, true) -} -func TestDAOOpposeMainnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, "", [][2]bool{{false, true}}, params.MainNetDAOForkBlock, false) -} -func TestDAOSwitchToSupportMainnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, "", [][2]bool{{false, true}, {true, false}}, params.MainNetDAOForkBlock, true) -} -func TestDAOSwitchToOpposeMainnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, "", [][2]bool{{true, false}, {false, true}}, params.MainNetDAOForkBlock, false) -} -func TestDAODefaultTestnet(t *testing.T) { - testDAOForkBlockNewChain(t, true, "", [][2]bool{{false, false}}, params.TestNetDAOForkBlock, true) -} -func TestDAOSupportTestnet(t *testing.T) { - testDAOForkBlockNewChain(t, true, "", [][2]bool{{true, false}}, params.TestNetDAOForkBlock, true) -} -func TestDAOOpposeTestnet(t *testing.T) { - testDAOForkBlockNewChain(t, true, "", [][2]bool{{false, true}}, params.TestNetDAOForkBlock, false) -} -func TestDAOSwitchToSupportTestnet(t *testing.T) { - testDAOForkBlockNewChain(t, true, "", [][2]bool{{false, true}, {true, false}}, params.TestNetDAOForkBlock, true) -} -func TestDAOSwitchToOpposeTestnet(t *testing.T) { - testDAOForkBlockNewChain(t, true, "", [][2]bool{{true, false}, {false, true}}, params.TestNetDAOForkBlock, false) -} -func TestDAOInitOldPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoOldGenesis, [][2]bool{}, nil, false) -} -func TestDAODefaultOldPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoOldGenesis, [][2]bool{{false, false}}, nil, false) -} -func TestDAOSupportOldPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoOldGenesis, [][2]bool{{true, false}}, nil, true) -} -func TestDAOOpposeOldPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoOldGenesis, [][2]bool{{false, true}}, nil, false) -} -func TestDAOSwitchToSupportOldPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoOldGenesis, [][2]bool{{false, true}, {true, false}}, nil, true) -} -func TestDAOSwitchToOpposeOldPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoOldGenesis, [][2]bool{{true, false}, {false, true}}, nil, false) -} -func TestDAOInitNoForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoNoForkGenesis, [][2]bool{}, daoGenesisForkBlock, false) -} -func TestDAODefaultNoForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoNoForkGenesis, [][2]bool{{false, false}}, daoGenesisForkBlock, false) -} -func TestDAOSupportNoForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoNoForkGenesis, [][2]bool{{true, false}}, daoGenesisForkBlock, true) -} -func TestDAOOpposeNoForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoNoForkGenesis, [][2]bool{{false, true}}, daoGenesisForkBlock, false) -} -func TestDAOSwitchToSupportNoForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoNoForkGenesis, [][2]bool{{false, true}, {true, false}}, daoGenesisForkBlock, true) -} -func TestDAOSwitchToOpposeNoForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoNoForkGenesis, [][2]bool{{true, false}, {false, true}}, daoGenesisForkBlock, false) -} -func TestDAOInitProForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoProForkGenesis, [][2]bool{}, daoGenesisForkBlock, true) -} -func TestDAODefaultProForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoProForkGenesis, [][2]bool{{false, false}}, daoGenesisForkBlock, true) -} -func TestDAOSupportProForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoProForkGenesis, [][2]bool{{true, false}}, daoGenesisForkBlock, true) -} -func TestDAOOpposeProForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoProForkGenesis, [][2]bool{{false, true}}, daoGenesisForkBlock, false) -} -func TestDAOSwitchToSupportProForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoProForkGenesis, [][2]bool{{false, true}, {true, false}}, daoGenesisForkBlock, true) -} -func TestDAOSwitchToOpposeProForkPrivnet(t *testing.T) { - testDAOForkBlockNewChain(t, false, daoProForkGenesis, [][2]bool{{true, false}, {false, true}}, daoGenesisForkBlock, false) +func TestDAOForkBlockNewChain(t *testing.T) { + for _, arg := range []struct { + testnet bool + genesis string + votes [][2]bool + expectBlock *big.Int + expectVote bool + }{ + // Test DAO Default Mainnet + {false, "", [][2]bool{{false, false}}, params.MainNetDAOForkBlock, true}, + // test DAO Support Mainnet + {false, "", [][2]bool{{true, false}}, params.MainNetDAOForkBlock, true}, + // test DAO Oppose Mainnet + {false, "", [][2]bool{{false, true}}, params.MainNetDAOForkBlock, false}, + // test DAO Switch To Support Mainnet + {false, "", [][2]bool{{false, true}, {true, false}}, params.MainNetDAOForkBlock, true}, + // test DAO Switch To Oppose Mainnet + {false, "", [][2]bool{{true, false}, {false, true}}, params.MainNetDAOForkBlock, false}, + // test DAO Default Testnet + {true, "", [][2]bool{{false, false}}, params.TestNetDAOForkBlock, true}, + // test DAO Support Testnet + {true, "", [][2]bool{{true, false}}, params.TestNetDAOForkBlock, true}, + // test DAO Oppose Testnet + {true, "", [][2]bool{{false, true}}, params.TestNetDAOForkBlock, false}, + // test DAO Switch To Support Testnet + {true, "", [][2]bool{{false, true}, {true, false}}, params.TestNetDAOForkBlock, true}, + // test DAO Switch To Oppose Testnet + {true, "", [][2]bool{{true, false}, {false, true}}, params.TestNetDAOForkBlock, false}, + // test DAO Init Old Privnet + {false, daoOldGenesis, [][2]bool{}, nil, false}, + // test DAO Default Old Privnet + {false, daoOldGenesis, [][2]bool{{false, false}}, nil, false}, + // test DAO Support Old Privnet + {false, daoOldGenesis, [][2]bool{{true, false}}, nil, true}, + // test DAO Oppose Old Privnet + {false, daoOldGenesis, [][2]bool{{false, true}}, nil, false}, + // test DAO Switch To Support Old Privnet + {false, daoOldGenesis, [][2]bool{{false, true}, {true, false}}, nil, true}, + // test DAO Switch To Oppose Old Privnet + {false, daoOldGenesis, [][2]bool{{true, false}, {false, true}}, nil, false}, + // test DAO Init No Fork Privnet + {false, daoNoForkGenesis, [][2]bool{}, daoGenesisForkBlock, false}, + // test DAO Default No Fork Privnet + {false, daoNoForkGenesis, [][2]bool{{false, false}}, daoGenesisForkBlock, false}, + // test DAO Support No Fork Privnet + {false, daoNoForkGenesis, [][2]bool{{true, false}}, daoGenesisForkBlock, true}, + // test DAO Oppose No Fork Privnet + {false, daoNoForkGenesis, [][2]bool{{false, true}}, daoGenesisForkBlock, false}, + // test DAO Switch To Support No Fork Privnet + {false, daoNoForkGenesis, [][2]bool{{false, true}, {true, false}}, daoGenesisForkBlock, true}, + // test DAO Switch To Oppose No Fork Privnet + {false, daoNoForkGenesis, [][2]bool{{true, false}, {false, true}}, daoGenesisForkBlock, false}, + // test DAO Init Pro Fork Privnet + {false, daoProForkGenesis, [][2]bool{}, daoGenesisForkBlock, true}, + // test DAO Default Pro Fork Privnet + {false, daoProForkGenesis, [][2]bool{{false, false}}, daoGenesisForkBlock, true}, + // test DAO Support Pro Fork Privnet + {false, daoProForkGenesis, [][2]bool{{true, false}}, daoGenesisForkBlock, true}, + // test DAO Oppose Pro Fork Privnet + {false, daoProForkGenesis, [][2]bool{{false, true}}, daoGenesisForkBlock, false}, + // test DAO Switch To Support Pro Fork Privnet + {false, daoProForkGenesis, [][2]bool{{false, true}, {true, false}}, daoGenesisForkBlock, true}, + // test DAO Switch To Oppose Pro Fork Privnet + {false, daoProForkGenesis, [][2]bool{{true, false}, {false, true}}, daoGenesisForkBlock, false}, + } { + testDAOForkBlockNewChain(t, arg.testnet, arg.genesis, arg.votes, arg.expectBlock, arg.expectVote) + } } func testDAOForkBlockNewChain(t *testing.T, testnet bool, genesis string, votes [][2]bool, expectBlock *big.Int, expectVote bool) { |