Merge pull request #7 from 3v1n0/rootless-tests

tests: Add more tests on PAM conversations that can run as user
This commit is contained in:
Mike Steinert
2023-09-20 08:46:09 -05:00
committed by GitHub
5 changed files with 95 additions and 8 deletions

View File

@@ -0,0 +1,2 @@
# Custom stack to deny permit, independent of the user name/pass
auth requisite pam_deny.so

View File

@@ -0,0 +1,3 @@
# Custom stack to always permit, independent of the user name/pass
auth optional pam_echo.so This is an info message for user %u on %s
auth required pam_permit.so

View File

@@ -0,0 +1,2 @@
# Custom stack to deny permit, independent of the user name/pass
auth requisite pam_succeed_if.so user = testuser

View File

@@ -168,14 +168,11 @@ func TestPAM_007(t *testing.T) {
func TestPAM_ConfDir(t *testing.T) { func TestPAM_ConfDir(t *testing.T) {
u, _ := user.Current() u, _ := user.Current()
if u.Uid != "0" {
t.Skip("run this test as root")
}
c := Credentials{ c := Credentials{
// the custom service always permits even with wrong password. // the custom service always permits even with wrong password.
Password: "wrongsecret", Password: "wrongsecret",
} }
tx, err := StartConfDir("my-service", "test", c, ".") tx, err := StartConfDir("permit-service", u.Username, c, "test-services")
if !CheckPamHasStartConfdir() { if !CheckPamHasStartConfdir() {
if err == nil { if err == nil {
t.Fatalf("start should have errored out as pam_start_confdir is not available: %v", err) t.Fatalf("start should have errored out as pam_start_confdir is not available: %v", err)
@@ -194,13 +191,96 @@ func TestPAM_ConfDir(t *testing.T) {
func TestPAM_ConfDir_FailNoServiceOrUnsupported(t *testing.T) { func TestPAM_ConfDir_FailNoServiceOrUnsupported(t *testing.T) {
u, _ := user.Current() u, _ := user.Current()
if u.Uid != "0" {
t.Skip("run this test as root")
}
c := Credentials{ c := Credentials{
Password: "secret", Password: "secret",
} }
_, err := StartConfDir("does-not-exists", "test", c, ".") _, err := StartConfDir("does-not-exists", u.Username, c, ".")
if err == nil {
t.Fatalf("authenticate #expected an error")
}
s := err.Error()
if len(s) == 0 {
t.Fatalf("error #expected an error message")
}
}
func TestPAM_ConfDir_InfoMessage(t *testing.T) {
u, _ := user.Current()
var infoText string
tx, err := StartConfDir("echo-service", u.Username,
ConversationFunc(func(s Style, msg string) (string, error) {
switch s {
case TextInfo:
infoText = msg
return "", nil
}
return "", errors.New("unexpected")
}), "test-services")
if err != nil {
t.Fatalf("start #error: %v", err)
}
err = tx.Authenticate(0)
if err != nil {
t.Fatalf("authenticate #error: %v", err)
}
if infoText != "This is an info message for user " + u.Username + " on echo-service" {
t.Fatalf("Unexpected info message: %v", infoText)
}
}
func TestPAM_ConfDir_Deny(t *testing.T) {
u, _ := user.Current()
tx, err := StartConfDir("deny-service", u.Username, Credentials{}, "test-services")
if err != nil {
t.Fatalf("start #error: %v", err)
}
err = tx.Authenticate(0)
if err == nil {
t.Fatalf("authenticate #expected an error")
}
s := err.Error()
if len(s) == 0 {
t.Fatalf("error #expected an error message")
}
}
func TestPAM_ConfDir_PromptForUserName(t *testing.T) {
c := Credentials{
User: "testuser",
// the custom service only cares about correct user name.
Password: "wrongsecret",
}
tx, err := StartConfDir("succeed-if-user-test", "", c, "test-services")
if !CheckPamHasStartConfdir() {
if err == nil {
t.Fatalf("start should have errored out as pam_start_confdir is not available: %v", err)
}
// nothing else we do, we don't support it.
return
}
if err != nil {
t.Fatalf("start #error: %v", err)
}
err = tx.Authenticate(0)
if err != nil {
t.Fatalf("authenticate #error: %v", err)
}
}
func TestPAM_ConfDir_WrongUserName(t *testing.T) {
c := Credentials{
User: "wronguser",
Password: "wrongsecret",
}
tx, err := StartConfDir("succeed-if-user-test", "", c, "test-services")
if !CheckPamHasStartConfdir() {
if err == nil {
t.Fatalf("start should have errored out as pam_start_confdir is not available: %v", err)
}
// nothing else we do, we don't support it.
return
}
err = tx.Authenticate(0)
if err == nil { if err == nil {
t.Fatalf("authenticate #expected an error") t.Fatalf("authenticate #expected an error")
} }