aboutsummaryrefslogtreecommitdiffstats
path: root/rpc/api_test.go
blob: a00c2f3f1e77a4c8d98e94ab69cf768102e5c4db (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
package rpc

import (
    "encoding/json"
    // "sync"
    "testing"
    // "time"

    "github.com/ethereum/go-ethereum/xeth"
)

func TestWeb3Sha3(t *testing.T) {
    jsonstr := `{"jsonrpc":"2.0","method":"web3_sha3","params":["0x68656c6c6f20776f726c64"],"id":64}`
    expected := "0x47173285a8d7341e5e972fc677286384f802f8ef42a5ec5f03bbfa254cb01fad"

    api := &EthereumApi{}

    var req RpcRequest
    json.Unmarshal([]byte(jsonstr), &req)

    var response interface{}
    _ = api.GetRequestReply(&req, &response)

    if response.(string) != expected {
        t.Errorf("Expected %s got %s", expected, response)
    }
}

func TestDbStr(t *testing.T) {
    jsonput := `{"jsonrpc":"2.0","method":"db_putString","params":["testDB","myKey","myString"],"id":64}`
    jsonget := `{"jsonrpc":"2.0","method":"db_getString","params":["testDB","myKey"],"id":64}`
    expected := "myString"

    xeth := &xeth.XEth{}
    api := NewEthereumApi(xeth, "")
    defer api.db.Close()
    var response interface{}

    var req RpcRequest
    json.Unmarshal([]byte(jsonput), &req)
    _ = api.GetRequestReply(&req, &response)

    json.Unmarshal([]byte(jsonget), &req)
    _ = api.GetRequestReply(&req, &response)

    if response.(string) != expected {
        t.Errorf("Expected %s got %s", expected, response)
    }
}

func TestDbHexStr(t *testing.T) {
    jsonput := `{"jsonrpc":"2.0","method":"db_putHex","params":["testDB","beefKey","0xbeef"],"id":64}`
    jsonget := `{"jsonrpc":"2.0","method":"db_getHex","params":["testDB","beefKey"],"id":64}`
    expected := "0xbeef"

    xeth := &xeth.XEth{}
    api := NewEthereumApi(xeth, "")
    defer api.db.Close()
    var response interface{}

    var req RpcRequest
    json.Unmarshal([]byte(jsonput), &req)
    _ = api.GetRequestReply(&req, &response)

    json.Unmarshal([]byte(jsonget), &req)
    _ = api.GetRequestReply(&req, &response)

    if response.(string) != expected {
        t.Errorf("Expected %s got %s", expected, response)
    }
}

// func TestFilterClose(t *testing.T) {
//  t.Skip()
//  api := &EthereumApi{
//      logs:     make(map[int]*logFilter),
//      messages: make(map[int]*whisperFilter),
//      quit:     make(chan struct{}),
//  }

//  filterTickerTime = 1
//  api.logs[0] = &logFilter{}
//  api.messages[0] = &whisperFilter{}
//  var wg sync.WaitGroup
//  wg.Add(1)
//  go api.start()
//  go func() {
//      select {
//      case <-time.After(500 * time.Millisecond):
//          api.stop()
//          wg.Done()
//      }
//  }()
//  wg.Wait()
//  if len(api.logs) != 0 {
//      t.Error("expected logs to be empty")
//  }

//  if len(api.messages) != 0 {
//      t.Error("expected messages to be empty")
//  }
// }