Add a test suite
This commit is contained in:
@@ -7,3 +7,6 @@ go:
|
|||||||
before_install:
|
before_install:
|
||||||
- sudo apt-get update -qq
|
- sudo apt-get update -qq
|
||||||
- sudo apt-get install -qq --no-install-recommends libpam0g-dev
|
- sudo apt-get install -qq --no-install-recommends libpam0g-dev
|
||||||
|
- sudo useradd -d /tmp/test -p '$1$Qd8H95T5$RYSZQeoFbEB.gS19zS99A0' -s /bin/false test
|
||||||
|
|
||||||
|
script: sudo go test -v ./...
|
||||||
|
|||||||
10
README.md
10
README.md
@@ -11,5 +11,15 @@ There's an example of a "fake login" program in the examples directory.
|
|||||||
Look at the pam module's [godocs][1] for details about the Go API, or refer
|
Look at the pam module's [godocs][1] for details about the Go API, or refer
|
||||||
to the official [PAM documentation][2].
|
to the official [PAM documentation][2].
|
||||||
|
|
||||||
|
The test suite must be run as the root user. To setup your system for testing,
|
||||||
|
create a user named "test" with the password "secret". For example:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ sudo useradd test \
|
||||||
|
-d /tmp/test \
|
||||||
|
-p '$1$Qd8H95T5$RYSZQeoFbEB.gS19zS99A0' \
|
||||||
|
-s /bin/false
|
||||||
|
```
|
||||||
|
|
||||||
[1]: http://godoc.org/github.com/msteinert/pam
|
[1]: http://godoc.org/github.com/msteinert/pam
|
||||||
[2]: http://www.kernel.org/pub/linux/libs/pam/Linux-PAM-html/adg-interface-by-app-expected.html
|
[2]: http://www.kernel.org/pub/linux/libs/pam/Linux-PAM-html/adg-interface-by-app-expected.html
|
||||||
|
|||||||
@@ -106,7 +106,7 @@ func Start(service, user string, handler ConversationHandler) (*Transaction, err
|
|||||||
var u *C.char
|
var u *C.char
|
||||||
if len(user) != 0 {
|
if len(user) != 0 {
|
||||||
u = C.CString(user)
|
u = C.CString(user)
|
||||||
defer C.free(unsafe.Pointer(s))
|
defer C.free(unsafe.Pointer(u))
|
||||||
}
|
}
|
||||||
t.status = C.pam_start(s, u, t.conv.conv, &t.handle)
|
t.status = C.pam_start(s, u, t.conv.conv, &t.handle)
|
||||||
if t.status != C.PAM_SUCCESS {
|
if t.status != C.PAM_SUCCESS {
|
||||||
|
|||||||
82
transaction_test.go
Normal file
82
transaction_test.go
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
package pam
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestPAM_001(t *testing.T) {
|
||||||
|
tx, err := StartFunc("", "test", func(s Style, msg string) (string, error) {
|
||||||
|
return "secret", nil
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("start #error: %v", err)
|
||||||
|
}
|
||||||
|
err = tx.Authenticate(0)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("authenticate #error: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPAM_002(t *testing.T) {
|
||||||
|
tx, err := StartFunc("", "", func(s Style, msg string) (string, error) {
|
||||||
|
switch s {
|
||||||
|
case PromptEchoOn:
|
||||||
|
return "test", nil
|
||||||
|
case PromptEchoOff:
|
||||||
|
return "secret", nil
|
||||||
|
}
|
||||||
|
return "", errors.New("unexpected")
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("start #error: %v", err)
|
||||||
|
}
|
||||||
|
err = tx.Authenticate(0)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("authenticate #error: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type Credentials struct {
|
||||||
|
User string
|
||||||
|
Password string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Credentials) RespondPAM(s Style, msg string) (string, error) {
|
||||||
|
switch s {
|
||||||
|
case PromptEchoOn:
|
||||||
|
return c.User, nil
|
||||||
|
case PromptEchoOff:
|
||||||
|
return c.Password, nil
|
||||||
|
}
|
||||||
|
return "", errors.New("unexpected")
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPAM_003(t *testing.T) {
|
||||||
|
c := Credentials{
|
||||||
|
User: "test",
|
||||||
|
Password: "secret",
|
||||||
|
}
|
||||||
|
tx, err := Start("", "", c)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("start #error: %v", err)
|
||||||
|
}
|
||||||
|
err = tx.Authenticate(0)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("authenticate #error: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPAM_004(t *testing.T) {
|
||||||
|
c := Credentials{
|
||||||
|
Password: "secret",
|
||||||
|
}
|
||||||
|
tx, err := Start("", "test", c)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("start #error: %v", err)
|
||||||
|
}
|
||||||
|
err = tx.Authenticate(0)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("authenticate #error: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user