2016-07-26 01:30:28 +05:30
|
|
|
package kubernetes
|
|
|
|
|
|
|
|
import (
|
2016-10-27 01:38:03 +05:30
|
|
|
"fmt"
|
2016-07-26 01:30:28 +05:30
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2017-07-26 02:15:17 +05:30
|
|
|
"github.com/sirupsen/logrus"
|
2018-09-03 12:14:44 +05:30
|
|
|
|
|
|
|
"github.com/dexidp/dex/storage"
|
|
|
|
"github.com/dexidp/dex/storage/conformance"
|
2016-07-26 01:30:28 +05:30
|
|
|
)
|
|
|
|
|
2016-10-23 20:28:28 +05:30
|
|
|
const testKubeConfigEnv = "DEX_KUBECONFIG"
|
|
|
|
|
2016-07-26 01:30:28 +05:30
|
|
|
func TestLoadClient(t *testing.T) {
|
|
|
|
loadClient(t)
|
|
|
|
}
|
|
|
|
|
2016-08-02 11:23:12 +05:30
|
|
|
func loadClient(t *testing.T) *client {
|
2016-10-23 20:28:28 +05:30
|
|
|
config := Config{
|
|
|
|
KubeConfigFile: os.Getenv(testKubeConfigEnv),
|
|
|
|
}
|
|
|
|
if config.KubeConfigFile == "" {
|
|
|
|
t.Skipf("test environment variable %q not set, skipping", testKubeConfigEnv)
|
2016-07-26 01:30:28 +05:30
|
|
|
}
|
2016-11-23 05:05:46 +05:30
|
|
|
logger := &logrus.Logger{
|
|
|
|
Out: os.Stderr,
|
|
|
|
Formatter: &logrus.TextFormatter{DisableColors: true},
|
|
|
|
Level: logrus.DebugLevel,
|
|
|
|
}
|
2017-02-27 23:04:59 +05:30
|
|
|
s, err := config.open(logger, true)
|
2016-07-26 01:30:28 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestURLFor(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
apiVersion, namespace, resource, name string
|
|
|
|
|
|
|
|
baseURL string
|
|
|
|
want string
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"v1", "default", "pods", "a",
|
|
|
|
"https://k8s.example.com",
|
|
|
|
"https://k8s.example.com/api/v1/namespaces/default/pods/a",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"foo/v1", "default", "bar", "a",
|
|
|
|
"https://k8s.example.com",
|
|
|
|
"https://k8s.example.com/apis/foo/v1/namespaces/default/bar/a",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"foo/v1", "default", "bar", "a",
|
|
|
|
"https://k8s.example.com/",
|
|
|
|
"https://k8s.example.com/apis/foo/v1/namespaces/default/bar/a",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"foo/v1", "default", "bar", "a",
|
|
|
|
"https://k8s.example.com/",
|
|
|
|
"https://k8s.example.com/apis/foo/v1/namespaces/default/bar/a",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
// no namespace
|
|
|
|
"foo/v1", "", "bar", "a",
|
|
|
|
"https://k8s.example.com",
|
|
|
|
"https://k8s.example.com/apis/foo/v1/bar/a",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
2016-10-14 05:20:20 +05:30
|
|
|
c := &client{baseURL: test.baseURL}
|
2016-07-26 01:30:28 +05:30
|
|
|
got := c.urlFor(test.apiVersion, test.namespace, test.resource, test.name)
|
|
|
|
if got != test.want {
|
|
|
|
t.Errorf("(&client{baseURL:%q}).urlFor(%q, %q, %q, %q): expected %q got %q",
|
|
|
|
test.baseURL,
|
|
|
|
test.apiVersion, test.namespace, test.resource, test.name,
|
|
|
|
test.want, got,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStorage(t *testing.T) {
|
|
|
|
client := loadClient(t)
|
2016-10-27 01:38:03 +05:30
|
|
|
newStorage := func() storage.Storage {
|
2016-10-06 04:34:48 +05:30
|
|
|
for _, resource := range []string{
|
|
|
|
resourceAuthCode,
|
|
|
|
resourceAuthRequest,
|
|
|
|
resourceClient,
|
|
|
|
resourceRefreshToken,
|
|
|
|
resourceKeys,
|
|
|
|
resourcePassword,
|
|
|
|
} {
|
|
|
|
if err := client.deleteAll(resource); err != nil {
|
2016-10-27 01:38:03 +05:30
|
|
|
// Fatalf sometimes doesn't print the error message.
|
|
|
|
fmt.Fprintf(os.Stderr, "delete all %q failed: %v\n", resource, err)
|
2016-10-06 04:34:48 +05:30
|
|
|
t.Fatalf("delete all %q failed: %v", resource, err)
|
|
|
|
}
|
|
|
|
}
|
2016-09-18 06:31:15 +05:30
|
|
|
return client
|
2016-10-27 01:38:03 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
conformance.RunTests(t, newStorage)
|
|
|
|
conformance.RunTransactionTests(t, newStorage)
|
2016-07-26 01:30:28 +05:30
|
|
|
}
|