2020-06-06 13:16:58 +00:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/nomad/api"
|
2022-03-15 12:42:43 +00:00
|
|
|
"github.com/hashicorp/nomad/ci"
|
2020-06-06 13:16:58 +00:00
|
|
|
"github.com/hashicorp/nomad/command/agent"
|
|
|
|
"github.com/hashicorp/nomad/nomad/structs"
|
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestOperatorSnapshotRestore_Works(t *testing.T) {
|
2022-03-15 12:42:43 +00:00
|
|
|
ci.Parallel(t)
|
2020-06-06 13:16:58 +00:00
|
|
|
|
2022-05-12 15:42:40 +00:00
|
|
|
tmpDir := t.TempDir()
|
2020-06-06 13:16:58 +00:00
|
|
|
|
|
|
|
snapshotPath := generateSnapshotFile(t, func(srv *agent.TestAgent, client *api.Client, url string) {
|
|
|
|
sampleJob := `
|
|
|
|
job "snapshot-test-job" {
|
|
|
|
type = "service"
|
|
|
|
datacenters = [ "dc1" ]
|
|
|
|
group "group1" {
|
|
|
|
count = 1
|
|
|
|
task "task1" {
|
|
|
|
driver = "exec"
|
2020-10-21 14:17:27 +00:00
|
|
|
resources {
|
2020-06-06 13:16:58 +00:00
|
|
|
cpu = 1000
|
|
|
|
memory = 512
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}`
|
|
|
|
|
2020-10-05 14:07:41 +00:00
|
|
|
ui := cli.NewMockUi()
|
2020-06-06 13:16:58 +00:00
|
|
|
cmd := &JobRunCommand{Meta: Meta{Ui: ui}}
|
|
|
|
cmd.JobGetter.testStdin = strings.NewReader(sampleJob)
|
|
|
|
|
|
|
|
code := cmd.Run([]string{"--address=" + url, "-detach", "-"})
|
|
|
|
require.Zero(t, code)
|
|
|
|
})
|
|
|
|
|
|
|
|
srv, _, url := testServer(t, false, func(c *agent.Config) {
|
|
|
|
c.DevMode = false
|
|
|
|
c.DataDir = filepath.Join(tmpDir, "server1")
|
|
|
|
|
|
|
|
c.AdvertiseAddrs.HTTP = "127.0.0.1"
|
|
|
|
c.AdvertiseAddrs.RPC = "127.0.0.1"
|
|
|
|
c.AdvertiseAddrs.Serf = "127.0.0.1"
|
|
|
|
})
|
|
|
|
|
|
|
|
defer srv.Shutdown()
|
|
|
|
|
|
|
|
// job is not found before restore
|
|
|
|
j, err := srv.Agent.Server().State().JobByID(nil, structs.DefaultNamespace, "snapshot-test-job")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Nil(t, j)
|
|
|
|
|
2020-10-05 14:07:41 +00:00
|
|
|
ui := cli.NewMockUi()
|
2020-06-06 13:16:58 +00:00
|
|
|
cmd := &OperatorSnapshotRestoreCommand{Meta: Meta{Ui: ui}}
|
|
|
|
|
|
|
|
code := cmd.Run([]string{"--address=" + url, snapshotPath})
|
|
|
|
require.Empty(t, ui.ErrorWriter.String())
|
|
|
|
require.Zero(t, code)
|
|
|
|
require.Contains(t, ui.OutputWriter.String(), "Snapshot Restored")
|
|
|
|
|
|
|
|
foundJob, err := srv.Agent.Server().State().JobByID(nil, structs.DefaultNamespace, "snapshot-test-job")
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, "snapshot-test-job", foundJob.ID)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOperatorSnapshotRestore_Fails(t *testing.T) {
|
2022-03-15 12:42:43 +00:00
|
|
|
ci.Parallel(t)
|
2020-06-06 13:16:58 +00:00
|
|
|
|
2020-10-05 14:07:41 +00:00
|
|
|
ui := cli.NewMockUi()
|
2020-06-06 13:16:58 +00:00
|
|
|
cmd := &OperatorSnapshotRestoreCommand{Meta: Meta{Ui: ui}}
|
|
|
|
|
|
|
|
// Fails on misuse
|
|
|
|
code := cmd.Run([]string{"some", "bad", "args"})
|
|
|
|
require.Equal(t, 1, code)
|
|
|
|
require.Contains(t, ui.ErrorWriter.String(), commandErrorText(cmd))
|
|
|
|
ui.ErrorWriter.Reset()
|
|
|
|
|
|
|
|
// Fails when specified file does not exist
|
|
|
|
code = cmd.Run([]string{"/unicorns/leprechauns"})
|
|
|
|
require.Equal(t, 1, code)
|
|
|
|
require.Contains(t, ui.ErrorWriter.String(), "no such file")
|
|
|
|
}
|