2021-07-26 16:59:33 +00:00
|
|
|
package etcd_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"regexp"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
. "github.com/onsi/ginkgo"
|
2021-08-30 15:27:59 +00:00
|
|
|
"github.com/onsi/ginkgo/reporters"
|
2021-07-26 16:59:33 +00:00
|
|
|
. "github.com/onsi/gomega"
|
2021-08-10 18:13:26 +00:00
|
|
|
testutil "github.com/rancher/k3s/tests/util"
|
2021-07-26 16:59:33 +00:00
|
|
|
)
|
|
|
|
|
2021-08-10 23:22:12 +00:00
|
|
|
var server *testutil.K3sServer
|
2021-08-26 23:26:19 +00:00
|
|
|
var serverArgs = []string{"--cluster-init"}
|
2021-07-26 16:59:33 +00:00
|
|
|
var _ = BeforeSuite(func() {
|
2021-08-26 23:26:19 +00:00
|
|
|
if !testutil.IsExistingServer() {
|
|
|
|
var err error
|
|
|
|
server, err = testutil.K3sStartServer(serverArgs...)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
}
|
2021-07-26 16:59:33 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
var _ = Describe("etcd snapshots", func() {
|
2021-08-26 23:26:19 +00:00
|
|
|
BeforeEach(func() {
|
|
|
|
if testutil.IsExistingServer() && !testutil.ServerArgsPresent(serverArgs) {
|
|
|
|
Skip("Test needs k3s server with: " + strings.Join(serverArgs, " "))
|
|
|
|
}
|
|
|
|
})
|
2021-07-26 16:59:33 +00:00
|
|
|
When("a new etcd is created", func() {
|
|
|
|
It("starts up with no problems", func() {
|
|
|
|
Eventually(func() (string, error) {
|
2021-08-10 18:13:26 +00:00
|
|
|
return testutil.K3sCmd("kubectl", "get", "pods", "-A")
|
2021-10-28 19:35:28 +00:00
|
|
|
}, "180s", "5s").Should(MatchRegexp("kube-system.+coredns.+1\\/1.+Running"))
|
2021-07-26 16:59:33 +00:00
|
|
|
})
|
|
|
|
It("saves an etcd snapshot", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "save")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Saving current etcd snapshot set to k3s-etcd-snapshots"))
|
|
|
|
})
|
|
|
|
It("list snapshots", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "ls")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(MatchRegexp(`:///var/lib/rancher/k3s/server/db/snapshots/on-demand`))
|
|
|
|
})
|
|
|
|
It("deletes a snapshot", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
lsResult, err := testutil.K3sCmd("etcd-snapshot", "ls")
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
reg, err := regexp.Compile(`on-demand[^\s]+`)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
snapshotName := reg.FindString(lsResult)
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "delete", snapshotName)).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Removing the given locally stored etcd snapshot"))
|
|
|
|
})
|
|
|
|
})
|
|
|
|
When("saving a custom name", func() {
|
|
|
|
It("saves an etcd snapshot with a custom name", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "save", "--name", "ALIVEBEEF")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Saving etcd snapshot to /var/lib/rancher/k3s/server/db/snapshots/ALIVEBEEF"))
|
|
|
|
})
|
|
|
|
It("deletes that snapshot", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
lsResult, err := testutil.K3sCmd("etcd-snapshot", "ls")
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
reg, err := regexp.Compile(`ALIVEBEEF[^\s]+`)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
snapshotName := reg.FindString(lsResult)
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "delete", snapshotName)).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Removing the given locally stored etcd snapshot"))
|
|
|
|
})
|
|
|
|
})
|
|
|
|
When("using etcd snapshot prune", func() {
|
|
|
|
It("saves 3 different snapshots", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "save", "-name", "PRUNE_TEST")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Saving current etcd snapshot set to k3s-etcd-snapshots"))
|
|
|
|
time.Sleep(1 * time.Second)
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "save", "-name", "PRUNE_TEST")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Saving current etcd snapshot set to k3s-etcd-snapshots"))
|
|
|
|
time.Sleep(1 * time.Second)
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "save", "-name", "PRUNE_TEST")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Saving current etcd snapshot set to k3s-etcd-snapshots"))
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
})
|
|
|
|
It("lists all 3 snapshots", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
lsResult, err := testutil.K3sCmd("etcd-snapshot", "ls")
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2021-08-26 23:26:19 +00:00
|
|
|
reg, err := regexp.Compile(`:///var/lib/rancher/k3s/server/db/snapshots/PRUNE_TEST`)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
sepLines := reg.FindAllString(lsResult, -1)
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(sepLines).To(HaveLen(3))
|
|
|
|
})
|
|
|
|
It("prunes snapshots down to 2", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "prune", "--snapshot-retention", "2", "--name", "PRUNE_TEST")).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(BeEmpty())
|
2021-08-10 18:13:26 +00:00
|
|
|
lsResult, err := testutil.K3sCmd("etcd-snapshot", "ls")
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2021-08-26 23:26:19 +00:00
|
|
|
reg, err := regexp.Compile(`:///var/lib/rancher/k3s/server/db/snapshots/PRUNE_TEST`)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
sepLines := reg.FindAllString(lsResult, -1)
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(sepLines).To(HaveLen(2))
|
|
|
|
})
|
|
|
|
It("cleans up remaining snapshots", func() {
|
2021-08-10 18:13:26 +00:00
|
|
|
lsResult, err := testutil.K3sCmd("etcd-snapshot", "ls")
|
2021-07-26 16:59:33 +00:00
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
reg, err := regexp.Compile(`PRUNE_TEST[^\s]+`)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
for _, snapshotName := range reg.FindAllString(lsResult, -1) {
|
2021-08-10 18:13:26 +00:00
|
|
|
Expect(testutil.K3sCmd("etcd-snapshot", "delete", snapshotName)).
|
2021-07-26 16:59:33 +00:00
|
|
|
To(ContainSubstring("Removing the given locally stored etcd snapshot"))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
var _ = AfterSuite(func() {
|
2021-08-26 23:26:19 +00:00
|
|
|
if !testutil.IsExistingServer() {
|
|
|
|
Expect(testutil.K3sKillServer(server)).To(Succeed())
|
|
|
|
}
|
2021-07-26 16:59:33 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
func Test_IntegrationEtcd(t *testing.T) {
|
|
|
|
RegisterFailHandler(Fail)
|
2021-08-30 15:27:59 +00:00
|
|
|
RunSpecsWithDefaultAndCustomReporters(t, "Etcd Suite", []Reporter{
|
|
|
|
reporters.NewJUnitReporter("/tmp/results/junit-etcd.xml"),
|
|
|
|
})
|
2021-07-26 16:59:33 +00:00
|
|
|
}
|