This repository has been archived by the owner on Nov 3, 2024. It is now read-only.
forked from dfuse-io/dfuse-eosio
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinit_test.go
81 lines (66 loc) · 2.32 KB
/
init_test.go
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
// Copyright 2020 dfuse Platform Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package eosws
import (
"encoding/json"
"os"
"testing"
"github.com/streamingfast/bstream"
"github.com/dfuse-io/dfuse-eosio/codec"
pbcodec "github.com/dfuse-io/dfuse-eosio/pb/dfuse/eosio/codec/v1"
"github.com/streamingfast/jsonpb"
"github.com/streamingfast/logging"
"github.com/eoscanada/eos-go"
proto "github.com/golang/protobuf/proto"
"github.com/golang/protobuf/ptypes/timestamp"
"github.com/stretchr/testify/require"
"go.uber.org/zap"
)
func init() {
logging.TestingOverride()
}
func testBlock(t *testing.T, id, previousID, producer string, libNum uint64, trxTraceJSONs ...string) *bstream.Block {
trxTraces := make([]*pbcodec.TransactionTrace, len(trxTraceJSONs))
for i, trxTraceJSON := range trxTraceJSONs {
trxTrace := new(pbcodec.TransactionTrace)
require.NoError(t, jsonpb.UnmarshalString(trxTraceJSON, trxTrace))
trxTraces[i] = trxTrace
}
pbblock := &pbcodec.Block{
Id: id,
Number: eos.BlockNum(id),
Header: &pbcodec.BlockHeader{
Previous: previousID,
Producer: producer,
Timestamp: ×tamp.Timestamp{},
},
UnfilteredTransactionTraces: trxTraces,
}
if os.Getenv("DEBUG") != "" {
out, err := json.Marshal(pbblock)
require.NoError(t, err)
// We re-normalize to a plain map[string]interface{} so it's printed as JSON and not a proto default String implementation
normalizedOut := map[string]interface{}{}
require.NoError(t, json.Unmarshal(out, &normalizedOut))
zlog.Debug("created test block", zap.Any("block", normalizedOut))
}
block, err := codec.BlockFromProto(pbblock)
require.NoError(t, err)
return block
}
func protoJSONMarshalIndent(t *testing.T, message proto.Message) string {
value, err := jsonpb.MarshalIndentToString(message, " ")
require.NoError(t, err)
return value
}