From e68b9d00a6e05b3a941f63ffb696f91e554ac5ec Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 18 Oct 2024 20:33:49 +0200 Subject: Adding upstream version 9.0.3. Signed-off-by: Daniel Baumann --- modules/user/user_test.go | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 modules/user/user_test.go (limited to 'modules/user/user_test.go') diff --git a/modules/user/user_test.go b/modules/user/user_test.go new file mode 100644 index 0000000..372a675 --- /dev/null +++ b/modules/user/user_test.go @@ -0,0 +1,43 @@ +// Copyright 2020 The Gitea Authors. All rights reserved. +// SPDX-License-Identifier: MIT + +package user + +import ( + "os/exec" + "runtime" + "strings" + "testing" +) + +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 len(user) == 0 { + t.Errorf("expected non-empty user, got: %s", user) + } + // 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) + } + t.Setenv("USER", "spoofed") + user = CurrentUsername() + if user != whoami { + t.Errorf("expected %s as user, got: %s", whoami, user) + } +} -- cgit v1.2.3