forked from hazelcast/hazelcast-go-client
-
Notifications
You must be signed in to change notification settings - Fork 0
/
proxy_it_test.go
70 lines (63 loc) · 2.03 KB
/
proxy_it_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
/*
* Copyright (c) 2008-2021, Hazelcast, Inc. All Rights Reserved.
*
* 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 hazelcast_test
import (
"context"
"testing"
"time"
"github.com/stretchr/testify/assert"
hz "github.com/hazelcast/hazelcast-go-client"
"github.com/hazelcast/hazelcast-go-client/internal/it"
)
func TestRetryWithoutRedoOperation(t *testing.T) {
// The connection should be retried on IOError
retryResult(t, false, true)
}
func TestProxy_Destroy(t *testing.T) {
it.MapTester(t, func(t *testing.T, m *hz.Map) {
if err := m.Destroy(context.Background()); err != nil {
t.Fatal(err)
}
// the next call should do nothing and return no error
if err := m.Destroy(context.Background()); err != nil {
t.Fatal(err)
}
})
}
func retryResult(t *testing.T, redo bool, target bool) {
cluster := it.StartNewClusterWithOptions("TestProxy_Destroy", 15701, 1)
config := cluster.DefaultConfig()
config.Cluster.RedoOperation = redo
ctx := context.Background()
client := it.MustClient(hz.StartNewClientWithConfig(ctx, config))
m := it.MustValue(client.GetMap(ctx, "redo-test")).(*hz.Map)
// shutdown the cluster and try again
cluster.Shutdown()
okCh := make(chan bool)
go func(ch chan<- bool) {
// set is a non-retryable operation
if err := m.Set(context.Background(), "key", "value"); err != nil {
ch <- false
} else {
ch <- true
}
}(okCh)
time.Sleep(1 * time.Second)
cluster = it.StartNewClusterWithOptions("TestProxy_Destroy", 15701, 1)
defer cluster.Shutdown()
ok := <-okCh
assert.Equal(t, target, ok)
}