// Copyright (c) 2018 XDPoSChain // // This program 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. // // This program 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 this program. If not, see . package randomize import ( "context" "math/big" "testing" "time" "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind" "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind/backends" "github.com/XinFinOrg/XDPoSChain/common" "github.com/XinFinOrg/XDPoSChain/common/hexutil" "github.com/XinFinOrg/XDPoSChain/contracts" "github.com/XinFinOrg/XDPoSChain/core" "github.com/XinFinOrg/XDPoSChain/core/types" "github.com/XinFinOrg/XDPoSChain/crypto" "github.com/XinFinOrg/XDPoSChain/params" ) var ( epocNumber = int64(12) key, _ = crypto.HexToECDSA("b71c71a67e1177ad4e901695e1b4b9ee17ae16c6668d313eac2f96dbcda3f291") addr = crypto.PubkeyToAddress(key.PublicKey) byte0 = make([][32]byte, epocNumber) acc1Key, _ = crypto.HexToECDSA("8a1f9a8f95be41cd7ccb6168179afb4504aefe388d1e14474d32c45c72ce7b7a") acc1Addr = crypto.PubkeyToAddress(acc1Key.PublicKey) ) func TestRandomize(t *testing.T) { contractBackend := backends.NewXDCSimulatedBackend(core.GenesisAlloc{addr: {Balance: big.NewInt(100000000000000)}}, 10000000, params.TestXDPoSMockChainConfig) transactOpts := bind.NewKeyedTransactor(key) transactOpts.GasLimit = 1000000 randomizeAddress, randomize, err := DeployRandomize(transactOpts, contractBackend) t.Log("contract address", randomizeAddress.String()) if err != nil { t.Fatalf("can't deploy root registry: %v", err) } contractBackend.Commit() d := time.Now().Add(1000 * time.Millisecond) ctx, cancel := context.WithDeadline(context.Background(), d) defer cancel() code, _ := contractBackend.CodeAt(ctx, randomizeAddress, nil) t.Log("contract code", hexutil.Encode(code)) f := func(key, val common.Hash) bool { t.Log(key.Hex(), val.Hex()) return true } contractBackend.ForEachStorageAt(ctx, randomizeAddress, nil, f) s, err := randomize.SetSecret(byte0) if err != nil { t.Fatalf("can't set secret: %v", err) } t.Log("tx data", s) contractBackend.Commit() } func TestSendTxRandomizeSecretAndOpening(t *testing.T) { genesis := core.GenesisAlloc{acc1Addr: {Balance: big.NewInt(1000000000000)}} // TODO(daniel): replace NewSimulatedBackend with NewXDCSimulatedBackend backend := backends.NewSimulatedBackend(genesis, 42000000) backend.Commit() signer := types.HomesteadSigner{} ctx := context.Background() transactOpts := bind.NewKeyedTransactor(acc1Key) transactOpts.GasLimit = 4200000 epocNumber := uint64(900) randomizeAddr, randomizeContract, err := DeployRandomize(transactOpts, backend) if err != nil { t.Fatalf("Can't deploy randomize SC: %v", err) } backend.Commit() randomizeKeyValue := contracts.RandStringByte(32) for i := 1; i <= 900; i++ { nonce := uint64(i) switch i { case 800: tx, err := contracts.BuildTxSecretRandomize(nonce, randomizeAddr, epocNumber, randomizeKeyValue) if err != nil { t.Fatalf("Can't create tx randomize secret: %v", err) } tx, err = types.SignTx(tx, signer, acc1Key) if err != nil { t.Fatalf("Can't sign tx randomize secret: %v", err) } err = backend.SendTransaction(ctx, tx) if err != nil { t.Fatalf("Can't send tx for create randomize secret: %v", err) } case 850: // Set opening. tx, err := contracts.BuildTxOpeningRandomize(nonce, randomizeAddr, randomizeKeyValue) if err != nil { t.Fatalf("Can't create tx randomize opening: %v", err) } tx, err = types.SignTx(tx, signer, acc1Key) if err != nil { t.Fatalf("Can't sign tx randomize opening: %v", err) } err = backend.SendTransaction(ctx, tx) if err != nil { t.Fatalf("Can't send tx for create randomize opening: %v", err) } case 900: // Get randomize secret from SC. secrets, err := randomizeContract.GetSecret(acc1Addr) if err != nil { t.Error("Fail get secrets from randomize", err) } if len(secrets) <= 0 { t.Error("Empty get secrets from SC", err) } // Decrypt randomize from SC. opening, err := randomizeContract.GetOpening(acc1Addr) if err != nil { t.Fatalf("Can't get secret from SC: %v", err) } randomize, err := contracts.DecryptRandomizeFromSecretsAndOpening(secrets, opening) t.Log("randomize", randomize) if err != nil { t.Error("Can't decrypt secret and opening", err) } default: tx, err := types.SignTx(types.NewTransaction(nonce, common.Address{}, new(big.Int), 21000, new(big.Int), nil), signer, acc1Key) if err != nil { t.Fatalf("Can't sign tx randomize: %v", err) } err = backend.SendTransaction(ctx, tx) if err != nil { t.Fatalf("Can't send tx for create randomize: %v", err) } } backend.Commit() } }