-
Notifications
You must be signed in to change notification settings - Fork 12
/
deploy_native_test.go
98 lines (66 loc) · 3.78 KB
/
deploy_native_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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// Copyright 2019 the orbs-network-go authors
// This file is part of the orbs-network-go library in the Orbs project.
//
// This source code is licensed under the MIT license found in the LICENSE file in the root directory of this source tree.
// The above notice should be included in all copies or substantial portions of the software.
package acceptance
import (
"context"
"github.com/orbs-network/orbs-network-go/test"
"github.com/orbs-network/orbs-network-go/test/acceptance/callcontract"
"github.com/orbs-network/orbs-network-go/test/contracts"
"github.com/orbs-network/orbs-spec/types/go/protocol"
"github.com/stretchr/testify/require"
"testing"
)
func TestDeployNativeContract(t *testing.T) {
NewHarness().Start(t, func(t testing.TB, ctx context.Context, network *Network) {
counterStart := contracts.MOCK_COUNTER_CONTRACT_START_FROM
network.MockContract(contracts.MockForCounter(), string(contracts.NativeSourceCodeForCounter(counterStart)))
contract := callcontract.NewContractClient(network)
t.Log("deploying contract")
response, txHash := contract.DeployNativeCounterContract(ctx, 1, 0)
test.RequireSuccess(t, response, "lock to address 5 failed")
t.Log("wait for node to sync with deployment")
network.WaitForTransactionInNodeState(ctx, txHash, 0)
require.EqualValues(t, counterStart, contract.CounterGet(ctx, 0), "get counter after deploy")
t.Log("transacting with contract")
_, txHash = contract.CounterAdd(ctx, 1, 17)
t.Log("wait for node to sync with transaction")
network.WaitForTransactionInNodeState(ctx, txHash, 0)
require.EqualValues(t, counterStart+17, contract.CounterGet(ctx, 0), "get counter after transaction")
})
}
func TestLockNativeDeployment(t *testing.T) {
NewHarness().Start(t, func(t testing.TB, ctx context.Context, network *Network) {
counterStart := contracts.MOCK_COUNTER_CONTRACT_START_FROM
network.MockContract(contracts.MockForCounter(), string(contracts.NativeSourceCodeForCounter(counterStart)))
contract := callcontract.NewContractClient(network)
t.Log("lock native deployment to account 5 should succeed")
response, _ := contract.LockNativeDeployment(ctx, 0, 5)
test.RequireSuccess(t, response, "lock to address 5 failed")
t.Log("lock native deployment to account 6 should fail (already locked)")
response, _ = contract.LockNativeDeployment(ctx, 0, 6)
test.RequireResult(t, protocol.EXECUTION_RESULT_ERROR_SMART_CONTRACT, response, "lock to account 6 should have failed")
t.Log("deploy native contract from account 6 should fail")
response, txHash := contract.DeployNativeCounterContract(ctx, 0, 6)
test.RequireResult(t, protocol.EXECUTION_RESULT_ERROR_SMART_CONTRACT, response, "deployment by account 6 should have failed")
network.WaitForTransactionInNodeState(ctx, txHash, 0)
t.Log("transacting with contract should fail")
response, _ = contract.CounterAdd(ctx, 0, 17)
test.RequireResult(t, protocol.EXECUTION_RESULT_ERROR_CONTRACT_NOT_DEPLOYED, response, "transaction should fail because contract is not deployed")
t.Log("unlock native deployment from account 5 should succeed")
response, _ = contract.UnlockNativeDeployment(ctx, 0, 5)
test.RequireSuccess(t, response, "unlock by address 5 failed")
t.Log("lock native deployment to account 6 should succeed")
response, _ = contract.LockNativeDeployment(ctx, 0, 6)
test.RequireSuccess(t, response, "lock to address 6 failed")
t.Log("deploy native contract from account 6 should succeed")
response, txHash = contract.DeployNativeCounterContract(ctx, 0, 6)
test.RequireSuccess(t, response, "deployment by address 6 failed")
network.WaitForTransactionInNodeState(ctx, txHash, 0)
t.Log("transacting with contract should succeed")
response, _ = contract.CounterAdd(ctx, 0, 17)
test.RequireSuccess(t, response, "transaction by address 6 failed")
})
}