mirror of
https://github.com/opentofu/opentofu.git
synced 2024-12-25 08:21:07 -06:00
fedd315275
This commit replaces `ioutil.TempDir` with `t.TempDir` in tests. The directory created by `t.TempDir` is automatically removed when the test and all its subtests complete. Prior to this commit, temporary directory created using `ioutil.TempDir` needs to be removed manually by calling `os.RemoveAll`, which is omitted in some tests. The error handling boilerplate e.g. defer func() { if err := os.RemoveAll(dir); err != nil { t.Fatal(err) } } is also tedious, but `t.TempDir` handles this for us nicely. Reference: https://pkg.go.dev/testing#T.TempDir Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
76 lines
2.0 KiB
Go
76 lines
2.0 KiB
Go
package command
|
|
|
|
import (
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
svchost "github.com/hashicorp/terraform-svchost"
|
|
svcauth "github.com/hashicorp/terraform-svchost/auth"
|
|
"github.com/hashicorp/terraform-svchost/disco"
|
|
"github.com/hashicorp/terraform/internal/command/cliconfig"
|
|
)
|
|
|
|
func TestLogout(t *testing.T) {
|
|
workDir := t.TempDir()
|
|
|
|
ui := cli.NewMockUi()
|
|
credsSrc := cliconfig.EmptyCredentialsSourceForTests(filepath.Join(workDir, "credentials.tfrc.json"))
|
|
|
|
c := &LogoutCommand{
|
|
Meta: Meta{
|
|
Ui: ui,
|
|
Services: disco.NewWithCredentialsSource(credsSrc),
|
|
},
|
|
}
|
|
|
|
testCases := []struct {
|
|
// Hostname to associate a pre-stored token
|
|
hostname string
|
|
// Command-line arguments
|
|
args []string
|
|
// true iff the token at hostname should be removed by the command
|
|
shouldRemove bool
|
|
}{
|
|
// If no command-line arguments given, should remove app.terraform.io token
|
|
{"app.terraform.io", []string{}, true},
|
|
|
|
// Can still specify app.terraform.io explicitly
|
|
{"app.terraform.io", []string{"app.terraform.io"}, true},
|
|
|
|
// Can remove tokens for other hostnames
|
|
{"tfe.example.com", []string{"tfe.example.com"}, true},
|
|
|
|
// Logout does not remove tokens for other hostnames
|
|
{"tfe.example.com", []string{"other-tfe.acme.com"}, false},
|
|
}
|
|
for _, tc := range testCases {
|
|
host := svchost.Hostname(tc.hostname)
|
|
token := svcauth.HostCredentialsToken("some-token")
|
|
err := credsSrc.StoreForHost(host, token)
|
|
if err != nil {
|
|
t.Fatalf("unexpected error storing credentials: %s", err)
|
|
}
|
|
|
|
status := c.Run(tc.args)
|
|
if status != 0 {
|
|
t.Fatalf("unexpected error code %d\nstderr:\n%s", status, ui.ErrorWriter.String())
|
|
}
|
|
|
|
creds, err := credsSrc.ForHost(host)
|
|
if err != nil {
|
|
t.Errorf("failed to retrieve credentials: %s", err)
|
|
}
|
|
if tc.shouldRemove {
|
|
if creds != nil {
|
|
t.Errorf("wrong token %q; should have no token", creds.Token())
|
|
}
|
|
} else {
|
|
if got, want := creds.Token(), "some-token"; got != want {
|
|
t.Errorf("wrong token %q; want %q", got, want)
|
|
}
|
|
}
|
|
}
|
|
}
|