-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdocker_run_bbccore.go
113 lines (103 loc) · 3.2 KB
/
docker_run_bbccore.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
// Copyright (c) [2019] [dabank.io]
// [devtools4chains] is licensed under the Mulan PSL v1.
// You can use this software according to the terms and conditions of the Mulan PSL v1.
// You may obtain a copy of Mulan PSL v1 at:
// http://license.coscl.org.cn/MulanPSL
// THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR
// PURPOSE.
// See the Mulan PSL v1 for more details.
package devtools4chains
import (
"context"
"fmt"
"log"
"strconv"
"testing"
"time"
"github.com/dabankio/bbrpc"
"github.com/docker/docker/api/types"
"github.com/docker/docker/api/types/container"
"github.com/docker/docker/api/types/network"
"github.com/docker/docker/client"
"github.com/docker/go-connections/nat"
)
type DockerCore struct {
Client *bbrpc.Client
MinerAddress string //矿工地址(资金来源)
MinerOwnerPubk string //矿工owner address 公钥
UnlockPass string //已有地址解锁密码
RPCPort int
Conf bbrpc.ConnConfig
}
func MustRunDockerDevCore(t *testing.T, imageName string, autoClean bool, autoRemove bool) DockerCore {
fn, info, err := DockerRunDevCore(imageName, autoRemove)
if err != nil {
t.Fatalf("docker run image failed, %v", err)
return info
}
if autoClean {
t.Cleanup(fn)
}
return info
}
// DockerRunDevCore 运行1个bbc core
func DockerRunDevCore(imageName string, autoRemove bool) (func(), DockerCore, error) {
info := DockerCore{
MinerAddress: "20g003rgxdn4s64r4d0dchvb87p791q4epswkn1txadgv1evjqqwv70e5",
MinerOwnerPubk: "3bc3e5f2e5e44f1cdbc44d3bf9325c93314be123f7563b8e6a88dc6eb1a25465",
UnlockPass: "123",
Conf: bbrpc.ConnConfig{
User: "bbc",
Pass: "123",
DisableTLS: true,
},
}
cli, err := client.NewEnvClient()
if err != nil {
return func() {}, info, err
}
idlePort, err := GetIdlePort()
if err != nil {
return func() {}, info, err
}
info.RPCPort = idlePort
cont, err := cli.ContainerCreate(context.Background(), &container.Config{
// AttachStderr: true,
// AttachStdout: true,
// Tty: true,
Image: imageName,
ExposedPorts: nat.PortSet{"9550": struct{}{}},
}, &container.HostConfig{
PortBindings: nat.PortMap{"9550": []nat.PortBinding{{HostIP: "0.0.0.0", HostPort: strconv.Itoa(idlePort)}}},
PublishAllPorts: true,
AutoRemove: autoRemove,
}, &network.NetworkingConfig{}, "")
if err != nil {
return func() {}, info, err
}
err = cli.ContainerStart(context.Background(), cont.ID, types.ContainerStartOptions{})
if err != nil {
return func() {}, info, err
}
log.Println("[info] bbc container started", cont.ID)
stopContainer := func() {
if er := cli.ContainerStop(context.Background(), cont.ID, nil); er != nil {
log.Println("[warn] stop bbc core dev container err", er)
}
}
info.Conf.Host = fmt.Sprintf("127.0.0.1:%d", idlePort)
info.Client, err = bbrpc.NewClient(&info.Conf)
if err != nil {
return stopContainer, info, err
}
for { //wait for booting
time.Sleep(time.Second)
_, e := info.Client.Getforkheight(nil)
if e == nil {
break
}
log.Println("check alive:", e)
}
return stopContainer, info, nil
}