From a82ee5f0902cd39d5d6e341c72301d77ae056711 Mon Sep 17 00:00:00 2001 From: Finn Arne Gangstad Date: Fri, 24 Mar 2023 23:08:55 +0100 Subject: [PATCH] Tests should update test-local git configuration files (#3262) The tests would mutate $HOME/.gitconfig and $HOME/.git-credentials. Set the HOME environment variable to a suitable temporary directory before running git commands that mutate the global config. Fixes #2604 --- server/events/vcs/gh_app_creds_rotator_test.go | 1 + server/events/vcs/git_cred_writer_test.go | 8 ++++++++ 2 files changed, 9 insertions(+) diff --git a/server/events/vcs/gh_app_creds_rotator_test.go b/server/events/vcs/gh_app_creds_rotator_test.go index 4c5f4eb1e2..e0d2e28bf4 100644 --- a/server/events/vcs/gh_app_creds_rotator_test.go +++ b/server/events/vcs/gh_app_creds_rotator_test.go @@ -66,6 +66,7 @@ func Test_githubAppTokenRotator_GenerateJob(t *testing.T) { for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { tmpDir := t.TempDir() + t.Setenv("HOME", tmpDir) r := vcs.NewGithubAppTokenRotator(logging.NewNoopLogger(t), tt.fields.githubCredentials, testServer, tmpDir) got, err := r.GenerateJob() if (err != nil) != tt.wantErr { diff --git a/server/events/vcs/git_cred_writer_test.go b/server/events/vcs/git_cred_writer_test.go index 6826c1cc84..082f732475 100644 --- a/server/events/vcs/git_cred_writer_test.go +++ b/server/events/vcs/git_cred_writer_test.go @@ -16,6 +16,7 @@ import ( func TestWriteGitCreds_WriteFile(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) err := vcs.WriteGitCreds("user", "token", "hostname", tmp, logger, false) Ok(t, err) @@ -32,6 +33,7 @@ func TestWriteGitCreds_WriteFile(t *testing.T) { func TestWriteGitCreds_Appends(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) credsFile := filepath.Join(tmp, ".git-credentials") err := os.WriteFile(credsFile, []byte("contents"), 0600) @@ -51,6 +53,7 @@ func TestWriteGitCreds_Appends(t *testing.T) { func TestWriteGitCreds_NoModification(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) credsFile := filepath.Join(tmp, ".git-credentials") contents := "line1\nhttps://user:token@hostname\nline2" @@ -68,6 +71,7 @@ func TestWriteGitCreds_NoModification(t *testing.T) { func TestWriteGitCreds_ReplaceApp(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) credsFile := filepath.Join(tmp, ".git-credentials") contents := "line1\nhttps://x-access-token:v1.87dddddddddddddddd@github.com\nline2" @@ -86,6 +90,7 @@ func TestWriteGitCreds_ReplaceApp(t *testing.T) { func TestWriteGitCreds_AppendApp(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) credsFile := filepath.Join(tmp, ".git-credentials") contents := "" @@ -105,6 +110,7 @@ func TestWriteGitCreds_AppendApp(t *testing.T) { func TestWriteGitCreds_ErrIfCannotRead(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) credsFile := filepath.Join(tmp, ".git-credentials") err := os.WriteFile(credsFile, []byte("can't see me!"), 0000) @@ -128,6 +134,7 @@ func TestWriteGitCreds_ErrIfCannotWrite(t *testing.T) { func TestWriteGitCreds_ConfigureGitCredentialHelper(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) err := vcs.WriteGitCreds("user", "token", "hostname", tmp, logger, false) Ok(t, err) @@ -142,6 +149,7 @@ func TestWriteGitCreds_ConfigureGitCredentialHelper(t *testing.T) { func TestWriteGitCreds_ConfigureGitUrlOverride(t *testing.T) { logger := logging.NewNoopLogger(t) tmp := t.TempDir() + t.Setenv("HOME", tmp) err := vcs.WriteGitCreds("user", "token", "hostname", tmp, logger, false) Ok(t, err)