2018-08-02 09:07:55 +02:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-09-22 19:49:20 +02:00
|
|
|
"database/sql"
|
2018-08-02 09:07:55 +02:00
|
|
|
"fmt"
|
2021-09-22 19:49:20 +02:00
|
|
|
"io/ioutil"
|
2018-08-02 09:07:55 +02:00
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
2021-09-22 19:49:20 +02:00
|
|
|
"os"
|
2018-08-02 09:07:55 +02:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
"github.com/status-im/status-go/appdatabase"
|
2018-08-02 09:07:55 +02:00
|
|
|
"github.com/status-im/status-go/params"
|
2021-09-22 19:49:20 +02:00
|
|
|
"github.com/status-im/status-go/rpc/network"
|
2018-08-02 09:07:55 +02:00
|
|
|
|
|
|
|
gethrpc "github.com/ethereum/go-ethereum/rpc"
|
|
|
|
)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
func setupTestNetworkDB(t *testing.T) (*sql.DB, func()) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "rpc-network-tests-")
|
|
|
|
require.NoError(t, err)
|
|
|
|
db, err := appdatabase.InitializeDB(tmpfile.Name(), "rpc-network-tests")
|
|
|
|
require.NoError(t, err)
|
|
|
|
return db, func() {
|
|
|
|
require.NoError(t, db.Close())
|
|
|
|
require.NoError(t, os.Remove(tmpfile.Name()))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-02 09:07:55 +02:00
|
|
|
func TestBlockedRoutesCall(t *testing.T) {
|
2021-09-22 19:49:20 +02:00
|
|
|
db, close := setupTestNetworkDB(t)
|
|
|
|
defer close()
|
|
|
|
|
2018-08-02 09:07:55 +02:00
|
|
|
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
fmt.Fprintln(w, `{
|
|
|
|
"id": 1,
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"result": "0x234234e22b9ffc2387e18636e0534534a3d0c56b0243567432453264c16e78a2adc"
|
|
|
|
}`)
|
|
|
|
}))
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
gethRPCClient, err := gethrpc.Dial(ts.URL)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
c, err := NewClient(gethRPCClient, 1, params.UpstreamRPCConfig{Enabled: false, URL: ""}, []network.Network{}, db)
|
2018-08-02 09:07:55 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
for _, m := range blockedMethods {
|
|
|
|
var (
|
|
|
|
result interface{}
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
err = c.Call(&result, 1, m)
|
2018-08-02 09:07:55 +02:00
|
|
|
require.EqualError(t, err, ErrMethodNotFound.Error())
|
|
|
|
require.Nil(t, result)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
err = c.CallContext(context.Background(), &result, 1, m)
|
2018-08-02 09:07:55 +02:00
|
|
|
require.EqualError(t, err, ErrMethodNotFound.Error())
|
|
|
|
require.Nil(t, result)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
err = c.CallContextIgnoringLocalHandlers(context.Background(), &result, 1, m)
|
2018-08-02 09:07:55 +02:00
|
|
|
require.EqualError(t, err, ErrMethodNotFound.Error())
|
|
|
|
require.Nil(t, result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBlockedRoutesRawCall(t *testing.T) {
|
2021-09-22 19:49:20 +02:00
|
|
|
db, close := setupTestNetworkDB(t)
|
|
|
|
defer close()
|
|
|
|
|
2018-08-02 09:07:55 +02:00
|
|
|
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
fmt.Fprintln(w, `{
|
|
|
|
"id": 1,
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"result": "0x234234e22b9ffc2387e18636e0534534a3d0c56b0243567432453264c16e78a2adc"
|
|
|
|
}`)
|
|
|
|
}))
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
gethRPCClient, err := gethrpc.Dial(ts.URL)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
c, err := NewClient(gethRPCClient, 1, params.UpstreamRPCConfig{Enabled: false, URL: ""}, []network.Network{}, db)
|
2018-08-02 09:07:55 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
for _, m := range blockedMethods {
|
|
|
|
rawResult := c.CallRaw(fmt.Sprintf(`{
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"id": 1,
|
|
|
|
"method": "%s",
|
|
|
|
"params": ["0xc862bf3cf4565d46abcbadaf4712a8940bfea729a91b9b0e338eab5166341ab5"]
|
|
|
|
}`, m))
|
|
|
|
require.Contains(t, rawResult, fmt.Sprintf(`{"code":-32700,"message":"%s"}`, ErrMethodNotFound))
|
|
|
|
}
|
|
|
|
}
|
2019-03-21 13:02:16 +01:00
|
|
|
|
|
|
|
func TestUpdateUpstreamURL(t *testing.T) {
|
2021-09-22 19:49:20 +02:00
|
|
|
db, close := setupTestNetworkDB(t)
|
|
|
|
defer close()
|
|
|
|
|
2019-03-21 13:02:16 +01:00
|
|
|
ts := createTestServer("")
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
updatedUpstreamTs := createTestServer("")
|
|
|
|
defer updatedUpstreamTs.Close()
|
|
|
|
|
|
|
|
gethRPCClient, err := gethrpc.Dial(ts.URL)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
2021-09-22 19:49:20 +02:00
|
|
|
c, err := NewClient(gethRPCClient, 1, params.UpstreamRPCConfig{Enabled: true, URL: ts.URL}, []network.Network{}, db)
|
2019-03-21 13:02:16 +01:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, ts.URL, c.upstreamURL)
|
|
|
|
|
|
|
|
// cache the original upstream client
|
|
|
|
originalUpstreamClient := c.upstream
|
|
|
|
|
|
|
|
err = c.UpdateUpstreamURL(updatedUpstreamTs.URL)
|
|
|
|
require.NoError(t, err)
|
|
|
|
// the upstream cleint instance should change
|
|
|
|
require.NotEqual(t, originalUpstreamClient, c.upstream)
|
|
|
|
require.Equal(t, updatedUpstreamTs.URL, c.upstreamURL)
|
|
|
|
}
|
|
|
|
|
|
|
|
func createTestServer(resp string) *httptest.Server {
|
|
|
|
if resp == "" {
|
|
|
|
resp = `{
|
|
|
|
"id": 1,
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"result": "0x234234e22b9ffc2387e18636e0534534a3d0c56b0243567432453264c16e78a2adc"
|
|
|
|
}`
|
|
|
|
}
|
|
|
|
|
|
|
|
return httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
fmt.Fprintln(w, resp)
|
|
|
|
}))
|
|
|
|
}
|