proxy: add tests (#44)

This commit is contained in:
Bobby DeSimone 2019-02-12 16:38:17 -08:00 committed by GitHub
parent 4f4f3965aa
commit 09744f6adb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 185 additions and 102 deletions

View file

@ -1,36 +1,58 @@
package authenticator
import (
"net/url"
"errors"
"reflect"
"testing"
"time"
)
func TestNew(t *testing.T) {
type args struct {
uri *url.URL
internalURL string
OverideCertificateName string
key string
func TestMockAuthenticate(t *testing.T) {
// Absurd, but I caught a typo this way.
fixedDate := time.Date(2009, 11, 17, 20, 34, 58, 651387237, time.UTC)
redeemResponse := &RedeemResponse{
AccessToken: "AccessToken",
RefreshToken: "RefreshToken",
Expiry: fixedDate,
}
tests := []struct {
name string
args args
wantP Authenticator
wantErr bool
}{
// TODO: Add test cases.
ma := &MockAuthenticate{
RedeemError: errors.New("RedeemError"),
RedeemResponse: redeemResponse,
RefreshResponse: "RefreshResponse",
RefreshTime: fixedDate,
RefreshError: errors.New("RefreshError"),
ValidateResponse: true,
ValidateError: errors.New("ValidateError"),
CloseError: errors.New("CloseError"),
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
gotP, err := New(tt.args.uri, tt.args.internalURL, tt.args.OverideCertificateName, tt.args.key)
if (err != nil) != tt.wantErr {
t.Errorf("New() error = %v, wantErr %v", err, tt.wantErr)
return
}
if !reflect.DeepEqual(gotP, tt.wantP) {
t.Errorf("New() = %v, want %v", gotP, tt.wantP)
}
})
got, gotErr := ma.Redeem("a")
if gotErr.Error() != "RedeemError" {
t.Errorf("unexpected value for gotErr %s", gotErr)
}
if !reflect.DeepEqual(redeemResponse, got) {
t.Errorf("unexpected value for redeemResponse %s", got)
}
gotToken, gotTime, gotErr := ma.Refresh("a")
if gotErr.Error() != "RefreshError" {
t.Errorf("unexpected value for gotErr %s", gotErr)
}
if !reflect.DeepEqual(gotToken, "RefreshResponse") {
t.Errorf("unexpected value for gotToken %s", gotToken)
}
if !gotTime.Equal(fixedDate) {
t.Errorf("unexpected value for gotTime %s", gotTime)
}
ok, gotErr := ma.Validate("a")
if !ok {
t.Errorf("unexpected value for ok : %t", ok)
}
if gotErr.Error() != "ValidateError" {
t.Errorf("unexpected value for gotErr %s", gotErr)
}
gotErr = ma.Close()
if gotErr.Error() != "CloseError" {
t.Errorf("unexpected value for ma.CloseError %s", gotErr)
}
}