2018-01-15 02:59:51 +00:00
|
|
|
package sharding
|
|
|
|
|
|
|
|
import (
|
2018-01-20 17:01:05 +00:00
|
|
|
"context"
|
2018-01-15 02:59:51 +00:00
|
|
|
"flag"
|
|
|
|
"fmt"
|
2018-01-20 17:01:05 +00:00
|
|
|
"math/big"
|
2018-01-15 02:59:51 +00:00
|
|
|
"math/rand"
|
|
|
|
"os"
|
2018-01-20 17:01:05 +00:00
|
|
|
"sync"
|
2018-01-15 02:59:51 +00:00
|
|
|
"testing"
|
|
|
|
|
2018-01-24 03:25:32 +00:00
|
|
|
ethereum "github.com/ethereum/go-ethereum"
|
2018-01-20 17:01:05 +00:00
|
|
|
"github.com/ethereum/go-ethereum/accounts/keystore"
|
|
|
|
"github.com/ethereum/go-ethereum/core/types"
|
|
|
|
|
2018-01-15 02:59:51 +00:00
|
|
|
"github.com/ethereum/go-ethereum/cmd/utils"
|
2018-01-20 17:01:05 +00:00
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
|
|
|
"github.com/ethereum/go-ethereum/node"
|
2018-01-15 02:59:51 +00:00
|
|
|
"github.com/ethereum/go-ethereum/rpc"
|
|
|
|
cli "gopkg.in/urfave/cli.v1"
|
|
|
|
)
|
|
|
|
|
2018-01-20 17:17:59 +00:00
|
|
|
// FakeEthService based on implementation of internal/ethapi.Client
|
2018-01-20 17:01:05 +00:00
|
|
|
type FakeEthService struct {
|
|
|
|
mu sync.Mutex
|
|
|
|
|
|
|
|
getCodeResp hexutil.Bytes
|
|
|
|
getCodeErr error
|
|
|
|
}
|
|
|
|
|
|
|
|
// eth_getCode
|
|
|
|
func (s *FakeEthService) GetCode(ctx context.Context, address common.Address, blockNr rpc.BlockNumber) (hexutil.Bytes, error) {
|
|
|
|
s.mu.Lock()
|
|
|
|
defer s.mu.Unlock()
|
|
|
|
return s.getCodeResp, s.getCodeErr
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set return values for eth_getCode
|
|
|
|
func (s *FakeEthService) SetGetCode(resp hexutil.Bytes, err error) {
|
|
|
|
s.mu.Lock()
|
|
|
|
s.getCodeResp = resp
|
|
|
|
s.getCodeErr = err
|
|
|
|
s.mu.Unlock()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *FakeEthService) GasPrice(ctx context.Context) (*big.Int, error) {
|
|
|
|
return big.NewInt(10000), nil
|
|
|
|
}
|
|
|
|
|
2018-01-24 03:25:32 +00:00
|
|
|
func (s *FakeEthService) EstimateGas(ctx context.Context, msg ethereum.CallMsg) ([]byte, error) {
|
|
|
|
return hexutil.MustDecode("0x1000000000"), nil
|
|
|
|
}
|
|
|
|
|
2018-01-20 17:01:05 +00:00
|
|
|
func (s *FakeEthService) GetTransactionCount(ctx context.Context, address common.Address, blockNr rpc.BlockNumber) (*hexutil.Uint64, error) {
|
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *FakeEthService) SendRawTransaction(ctx context.Context, encodedTx hexutil.Bytes) (common.Hash, error) {
|
|
|
|
return common.Hash{}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *FakeEthService) GetTransactionReceipt(hash common.Hash) (*types.Receipt, error) {
|
|
|
|
return &types.Receipt{
|
|
|
|
ContractAddress: common.StringToAddress("0x1"),
|
|
|
|
Logs: []*types.Log{},
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *FakeEthService) GetTransactionByHash(hash common.Hash) (tx *types.Transaction, isPending bool, err error) {
|
|
|
|
return nil, false, nil
|
2018-01-15 02:59:51 +00:00
|
|
|
}
|
|
|
|
|
2018-01-22 12:31:38 +00:00
|
|
|
type FakeNetworkService struct{}
|
|
|
|
|
|
|
|
func (s *FakeNetworkService) Version() (string, error) {
|
|
|
|
return "100", nil
|
|
|
|
}
|
|
|
|
|
2018-01-15 02:59:51 +00:00
|
|
|
func newTestServer(endpoint string) (*rpc.Server, error) {
|
2018-01-20 17:01:05 +00:00
|
|
|
// Create datadir.
|
|
|
|
if err := os.Mkdir(endpoint, 0777); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create a default account without password.
|
|
|
|
scryptN, scryptP, keydir, err := (&node.Config{DataDir: endpoint}).AccountConfig()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if _, err := keystore.StoreKey(keydir, "" /*password*/, scryptN, scryptP); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2018-01-15 02:59:51 +00:00
|
|
|
|
2018-01-20 17:01:05 +00:00
|
|
|
// Create server and register eth service with FakeEthService
|
|
|
|
server := rpc.NewServer()
|
|
|
|
if err := server.RegisterName("eth", new(FakeEthService)); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2018-01-22 12:31:38 +00:00
|
|
|
if err := server.RegisterName("net", new(FakeNetworkService)); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2018-01-20 17:01:05 +00:00
|
|
|
l, err := rpc.CreateIPCListener(endpoint + "/geth.ipc")
|
2018-01-15 02:59:51 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
go server.ServeListener(l)
|
|
|
|
|
|
|
|
return server, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func createContext() *cli.Context {
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
set.String(utils.DataDirFlag.Name, "", "")
|
|
|
|
return cli.NewContext(nil, set, nil)
|
|
|
|
}
|
|
|
|
|
2018-01-20 17:01:05 +00:00
|
|
|
func TestShardingClient(t *testing.T) {
|
|
|
|
endpoint := fmt.Sprintf("%s/go-ethereum-test-ipc-%d-%d", os.TempDir(), os.Getpid(), rand.Int63())
|
2018-01-15 02:59:51 +00:00
|
|
|
server, err := newTestServer(endpoint)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to create a test server: %v", err)
|
|
|
|
}
|
|
|
|
defer server.Stop()
|
|
|
|
|
|
|
|
ctx := createContext()
|
|
|
|
if err := ctx.GlobalSet(utils.DataDirFlag.Name, endpoint); err != nil {
|
|
|
|
t.Fatalf("Failed to set global variable for flag %s. Error: %v", utils.DataDirFlag.Name, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
c := MakeShardingClient(ctx)
|
2018-01-20 17:01:05 +00:00
|
|
|
|
2018-01-15 02:59:51 +00:00
|
|
|
if err := c.Start(); err != nil {
|
|
|
|
t.Errorf("Failed to start server: %v", err)
|
|
|
|
}
|
|
|
|
}
|