summaryrefslogtreecommitdiffstats
path: root/modules/user/user_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'modules/user/user_test.go')
-rw-r--r--modules/user/user_test.go37
1 files changed, 28 insertions, 9 deletions
diff --git a/modules/user/user_test.go b/modules/user/user_test.go
index d7df151531..51f10dbbd2 100644
--- a/modules/user/user_test.go
+++ b/modules/user/user_test.go
@@ -2,21 +2,40 @@ package user
import (
"os"
+ "os/exec"
+ "runtime"
+ "strings"
"testing"
)
-func TestCurrentUsername(t *testing.T) {
- os.Setenv("USER", "")
- os.Setenv("USERNAME", "foobar")
+func getWhoamiOutput() (string, error) {
+ output, err := exec.Command("whoami").Output()
+ if err != nil {
+ return "", err
+ }
+ return strings.TrimSpace(string(output[:])), nil
+}
+func TestCurrentUsername(t *testing.T) {
user := CurrentUsername()
- if user != "foobar" {
- t.Errorf("expected foobar as user, got: %s", user)
+ if len(user) <= 0 {
+ t.Errorf("expected non-empty user, got: %s", user)
}
-
- os.Setenv("USER", "gitea")
+ // Windows whoami is weird, so just skip remaining tests
+ if runtime.GOOS == "windows" {
+ t.Skip("skipped test because of weird whoami on Windows")
+ }
+ whoami, err := getWhoamiOutput()
+ if err != nil {
+ t.Errorf("failed to run whoami to test current user: %f", err)
+ }
+ user = CurrentUsername()
+ if user != whoami {
+ t.Errorf("expected %s as user, got: %s", whoami, user)
+ }
+ os.Setenv("USER", "spoofed")
user = CurrentUsername()
- if user != "gitea" {
- t.Errorf("expected gitea as user, got: %s", user)
+ if user != whoami {
+ t.Errorf("expected %s as user, got: %s", whoami, user)
}
}