-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathbefore_test.go
108 lines (90 loc) · 3.32 KB
/
before_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
99
100
101
102
103
104
105
106
107
108
package mtest
import (
"fmt"
"io"
"os"
"path/filepath"
"time"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
)
// RunBeforeSuite is for Ginkgo BeforeSuite
func RunBeforeSuite() {
fmt.Println("Preparing...")
SetDefaultEventuallyPollingInterval(time.Second)
SetDefaultEventuallyTimeout(3 * time.Minute)
err := prepareSSHClients(host1, host2, host3)
Expect(err).NotTo(HaveOccurred())
// sync VM root filesystem to store newly generated SSH host keys.
for h := range sshClients {
execSafeAt(h, "sync")
}
By("copying test files")
for _, testFile := range []string{etcdPath, etcdctlPath} {
f, err := os.Open(testFile)
Expect(err).NotTo(HaveOccurred())
defer f.Close()
remoteFilename := filepath.Join("/var/tmp", filepath.Base(testFile))
for _, host := range []string{host1, host2, host3} {
_, err := f.Seek(0, io.SeekStart)
Expect(err).NotTo(HaveOccurred())
stdout, stderr, err := execAtWithStream(host, f, "dd", "of="+remoteFilename)
Expect(err).NotTo(HaveOccurred(), "stdout=%s, stderr=%s", stdout, stderr)
stdout, stderr, err = execAt(host, "sudo", "mv", remoteFilename, filepath.Join("/opt/bin", filepath.Base(testFile)))
Expect(err).NotTo(HaveOccurred(), "stdout=%s, stderr=%s", stdout, stderr)
stdout, stderr, err = execAt(host, "sudo", "chmod", "755", filepath.Join("/opt/bin", filepath.Base(testFile)))
Expect(err).NotTo(HaveOccurred(), "stdout=%s, stderr=%s", stdout, stderr)
}
}
for _, testFile := range []string{coreosKernel, coreosInitrd, sshKeyFile, sabakanImagePath} {
f, err := os.Open(testFile)
Expect(err).NotTo(HaveOccurred())
defer f.Close()
remoteFilename := filepath.Join("/var/tmp", filepath.Base(testFile))
for _, host := range []string{host1, host2, host3} {
_, err := f.Seek(0, io.SeekStart)
Expect(err).NotTo(HaveOccurred())
stdout, stderr, err := execAtWithStream(host, f, "dd", "of="+remoteFilename)
Expect(err).NotTo(HaveOccurred(), "stdout=%s, stderr=%s", stdout, stderr)
}
}
By("loading test image")
err = loadImage(filepath.Join("/var/tmp", filepath.Base(sabakanImagePath)))
Expect(err).NotTo(HaveOccurred())
By("running install-tools")
err = installTools(sabakanImageURL)
Expect(err).NotTo(HaveOccurred())
By("starting etcd")
err = stopEtcd()
Expect(err).NotTo(HaveOccurred())
err = runEtcd()
Expect(err).NotTo(HaveOccurred())
time.Sleep(time.Second)
By("starting sabakan")
err = stopSabakan()
Expect(err).NotTo(HaveOccurred())
err = runSabakan(sabakanImageURL)
Expect(err).NotTo(HaveOccurred())
// wait sabakan
Eventually(func() error {
_, _, err := sabactl("logs")
return err
}).Should(Succeed())
By("configuring sabakan")
// register ipam.json, dhcp.json, machines.json, and ignitions
ipam, err := os.ReadFile(ipamJSONPath)
Expect(err).NotTo(HaveOccurred())
ipamFile := remoteTempFile(string(ipam))
sabactlSafe("ipam", "set", "-f", ipamFile)
dhcp, err := os.ReadFile(dhcpJSONPath)
Expect(err).NotTo(HaveOccurred())
dhcpFile := remoteTempFile(string(dhcp))
sabactlSafe("dhcp", "set", "-f", dhcpFile)
sabactlSafe("ignitions", "set", "-f", "/ignitions/worker.yml", "worker", "1.0.0")
machines, err := os.ReadFile(machinesJSONPath)
Expect(err).NotTo(HaveOccurred())
machinesFile := remoteTempFile(string(machines))
sabactlSafe("machines", "create", "-f", machinesFile)
time.Sleep(time.Second)
fmt.Println("Begin tests...")
}