2023-03-28 20:12:30 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 20:12:30 +01:00
|
|
|
|
2017-10-17 13:06:40 +02:00
|
|
|
package inspect
|
2016-10-31 19:37:27 -04:00
|
|
|
|
|
|
|
import (
|
2020-10-09 14:57:29 -05:00
|
|
|
"flag"
|
2022-11-10 10:26:01 -06:00
|
|
|
"os"
|
2020-04-24 17:18:56 -05:00
|
|
|
"path/filepath"
|
2016-10-31 19:37:27 -04:00
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mitchellh/cli"
|
2020-10-09 14:57:29 -05:00
|
|
|
"github.com/stretchr/testify/require"
|
2016-10-31 19:37:27 -04:00
|
|
|
)
|
|
|
|
|
2020-10-09 14:57:29 -05:00
|
|
|
// update allows golden files to be updated based on the current output.
|
|
|
|
var update = flag.Bool("update", false, "update golden files")
|
|
|
|
|
|
|
|
// golden reads and optionally writes the expected data to the golden file,
|
|
|
|
// returning the contents as a string.
|
|
|
|
func golden(t *testing.T, name, got string) string {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
golden := filepath.Join("testdata", name+".golden")
|
|
|
|
if *update && got != "" {
|
2022-11-10 10:26:01 -06:00
|
|
|
err := os.WriteFile(golden, []byte(got), 0644)
|
2020-10-09 14:57:29 -05:00
|
|
|
require.NoError(t, err)
|
|
|
|
}
|
|
|
|
|
2022-11-10 10:26:01 -06:00
|
|
|
expected, err := os.ReadFile(golden)
|
2020-10-09 14:57:29 -05:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
return string(expected)
|
|
|
|
}
|
|
|
|
|
2018-03-19 12:56:00 -04:00
|
|
|
func TestSnapshotInspectCommand_noTabs(t *testing.T) {
|
2017-10-17 16:07:48 +02:00
|
|
|
t.Parallel()
|
2017-10-17 09:03:41 +02:00
|
|
|
if strings.ContainsRune(New(cli.NewMockUi()).Help(), '\t') {
|
2017-10-17 15:44:20 +02:00
|
|
|
t.Fatal("help has tabs")
|
2017-10-17 09:03:41 +02:00
|
|
|
}
|
2016-10-31 19:37:27 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestSnapshotInspectCommand_Validation(t *testing.T) {
|
2017-10-17 16:07:48 +02:00
|
|
|
t.Parallel()
|
2017-10-17 09:03:41 +02:00
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
2016-10-31 19:37:27 -04:00
|
|
|
|
|
|
|
cases := map[string]struct {
|
|
|
|
args []string
|
|
|
|
output string
|
|
|
|
}{
|
|
|
|
"no file": {
|
|
|
|
[]string{},
|
|
|
|
"Missing FILE argument",
|
|
|
|
},
|
|
|
|
"extra args": {
|
|
|
|
[]string{"foo", "bar", "baz"},
|
|
|
|
"Too many arguments",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tc := range cases {
|
|
|
|
// Ensure our buffer is always clear
|
|
|
|
if ui.ErrorWriter != nil {
|
|
|
|
ui.ErrorWriter.Reset()
|
|
|
|
}
|
|
|
|
if ui.OutputWriter != nil {
|
|
|
|
ui.OutputWriter.Reset()
|
|
|
|
}
|
|
|
|
|
|
|
|
code := c.Run(tc.args)
|
|
|
|
if code == 0 {
|
|
|
|
t.Errorf("%s: expected non-zero exit", name)
|
|
|
|
}
|
|
|
|
|
|
|
|
output := ui.ErrorWriter.String()
|
|
|
|
if !strings.Contains(output, tc.output) {
|
|
|
|
t.Errorf("%s: expected %q to contain %q", name, output, tc.output)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-17 14:04:51 +02:00
|
|
|
func TestSnapshotInspectCommand(t *testing.T) {
|
2016-10-31 19:37:27 -04:00
|
|
|
|
2020-10-09 14:57:29 -05:00
|
|
|
filepath := "./testdata/backup.snap"
|
2016-10-31 19:37:27 -04:00
|
|
|
|
|
|
|
// Inspect the snapshot
|
2017-10-17 09:03:41 +02:00
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
2020-10-09 14:57:29 -05:00
|
|
|
args := []string{filepath}
|
2016-10-31 19:37:27 -04:00
|
|
|
|
2017-02-09 20:00:38 -05:00
|
|
|
code := c.Run(args)
|
2016-10-31 19:37:27 -04:00
|
|
|
if code != 0 {
|
|
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
2020-10-09 14:57:29 -05:00
|
|
|
want := golden(t, t.Name(), ui.OutputWriter.String())
|
|
|
|
require.Equal(t, want, ui.OutputWriter.String())
|
2016-10-31 19:37:27 -04:00
|
|
|
}
|
2020-11-05 11:01:44 -06:00
|
|
|
|
2020-11-10 11:18:21 -06:00
|
|
|
func TestSnapshotInspectKVDetailsCommand(t *testing.T) {
|
2020-11-05 11:01:44 -06:00
|
|
|
|
2020-11-10 11:18:21 -06:00
|
|
|
filepath := "./testdata/backupWithKV.snap"
|
2020-11-05 11:01:44 -06:00
|
|
|
|
|
|
|
// Inspect the snapshot
|
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
2020-11-10 11:18:21 -06:00
|
|
|
args := []string{"-kvdetails", filepath}
|
2020-11-05 11:01:44 -06:00
|
|
|
|
|
|
|
code := c.Run(args)
|
|
|
|
if code != 0 {
|
|
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
want := golden(t, t.Name(), ui.OutputWriter.String())
|
|
|
|
require.Equal(t, want, ui.OutputWriter.String())
|
|
|
|
}
|
|
|
|
|
2020-11-10 11:18:21 -06:00
|
|
|
func TestSnapshotInspectKVDetailsDepthCommand(t *testing.T) {
|
2020-11-05 11:01:44 -06:00
|
|
|
|
2020-11-10 11:18:21 -06:00
|
|
|
filepath := "./testdata/backupWithKV.snap"
|
2020-11-05 11:01:44 -06:00
|
|
|
|
|
|
|
// Inspect the snapshot
|
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
2020-11-10 11:18:21 -06:00
|
|
|
args := []string{"-kvdetails", "-kvdepth", "3", filepath}
|
2020-11-05 11:01:44 -06:00
|
|
|
|
|
|
|
code := c.Run(args)
|
|
|
|
if code != 0 {
|
|
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
want := golden(t, t.Name(), ui.OutputWriter.String())
|
|
|
|
require.Equal(t, want, ui.OutputWriter.String())
|
|
|
|
}
|
|
|
|
|
2020-11-10 11:18:21 -06:00
|
|
|
func TestSnapshotInspectKVDetailsDepthFilterCommand(t *testing.T) {
|
2020-11-05 11:01:44 -06:00
|
|
|
|
2020-11-10 11:18:21 -06:00
|
|
|
filepath := "./testdata/backupWithKV.snap"
|
2020-11-05 11:01:44 -06:00
|
|
|
|
|
|
|
// Inspect the snapshot
|
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
2020-11-10 11:18:21 -06:00
|
|
|
args := []string{"-kvdetails", "-kvdepth", "3", "-kvfilter", "vault/logical", filepath}
|
|
|
|
|
|
|
|
code := c.Run(args)
|
|
|
|
if code != 0 {
|
|
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
want := golden(t, t.Name(), ui.OutputWriter.String())
|
|
|
|
require.Equal(t, want, ui.OutputWriter.String())
|
|
|
|
}
|
2021-04-23 16:17:08 +01:00
|
|
|
|
|
|
|
// TestSnapshotInspectCommandRaw test reading a snaphost directly from a raft
|
|
|
|
// data dir.
|
|
|
|
func TestSnapshotInspectCommandRaw(t *testing.T) {
|
|
|
|
filepath := "./testdata/raw/state.bin"
|
|
|
|
|
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
|
|
|
args := []string{filepath}
|
|
|
|
|
|
|
|
code := c.Run(args)
|
|
|
|
if code != 0 {
|
|
|
|
t.Fatalf("bad: %d. %#v", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
want := golden(t, t.Name(), ui.OutputWriter.String())
|
|
|
|
require.Equal(t, want, ui.OutputWriter.String())
|
|
|
|
}
|
2021-04-23 20:48:10 +01:00
|
|
|
|
|
|
|
func TestSnapshotInspectInvalidFile(t *testing.T) {
|
|
|
|
// Attempt to open a non-snapshot file.
|
|
|
|
filepath := "./testdata/TestSnapshotInspectCommand.golden"
|
|
|
|
|
|
|
|
// Inspect the snapshot
|
|
|
|
ui := cli.NewMockUi()
|
|
|
|
c := New(ui)
|
|
|
|
args := []string{filepath}
|
|
|
|
|
|
|
|
code := c.Run(args)
|
|
|
|
// Just check it was an error code returned and not a panic - originally this
|
|
|
|
// would panic.
|
|
|
|
if code == 0 {
|
|
|
|
t.Fatalf("should return an error code")
|
|
|
|
}
|
|
|
|
}
|