woodpecker/plugins/secrets/vault/kubernetes_test.go
Matt Leung 79428aa231 Enable Vault auth through kubernetes auth method
Added a feature to obtain the initial Vault token from the Kubernetes
auth method.

This works by making a request to the Vault server at the specified auth
method mount point's login path and presenting the JWT located in a file
on a running pod, along with the Kubernetes role to authenticate as.

Vault will then respond with a token and its TTL, if the request is valid.
2018-04-24 14:56:28 -07:00

69 lines
1.9 KiB
Go

package vault
import (
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"net/http/httptest"
"testing"
"time"
)
func TestGetKubernetesToken(t *testing.T) {
fakeRole := "fakeRole"
fakeMountPoint := "kubernetes"
fakeJwtFile := "fixtures/fakeJwt"
b, _ := ioutil.ReadFile(fakeJwtFile)
fakeJwt := string(b)
fakeClientToken := "fakeClientToken"
fakeLeaseMinutes := "10m"
fakeLeaseDuration, _ := time.ParseDuration(fakeLeaseMinutes)
fakeResp := fmt.Sprintf("{\"auth\": {\"client_token\": \"%s\", \"lease_duration\": \"%s\"}}", fakeClientToken, fakeLeaseMinutes)
expectedPath := "/v1/auth/kubernetes/login"
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusOK)
if r.Method != "POST" {
t.Errorf("Expected 'POST' request, got '%s'", r.Method)
}
if r.URL.EscapedPath() != expectedPath {
t.Errorf("Expected request to '%s', got '%s'", expectedPath, r.URL.EscapedPath())
}
var postdata struct {
Jwt string
Role string
}
err := json.NewDecoder(r.Body).Decode(&postdata)
if err != nil {
t.Errorf("Encountered error parsing request JSON: %s", err)
}
jwt := postdata.Jwt
if jwt != fakeJwt {
t.Errorf("Expected request to have jwt with value '%s', got: '%s'", fakeJwt, jwt)
}
role := postdata.Role
if role != fakeRole {
t.Errorf("Expected request to have role with value '%s', got: '%s'", fakeRole, role)
}
fmt.Fprintf(w, fakeResp)
}))
defer ts.Close()
url := ts.URL
token, ttl, err := getKubernetesToken(url, fakeRole, fakeMountPoint, fakeJwtFile)
if err != nil {
t.Errorf("getKubernetesToken returned an error: %s", err)
}
if token != fakeClientToken {
t.Errorf("Expected returned token to have value '%s', got: '%s'", fakeClientToken, token)
}
if ttl != fakeLeaseDuration {
t.Errorf("Expected TTL to have value '%s', got: '%s'", fakeLeaseDuration.Seconds(), ttl.Seconds())
}
}