mirror of
https://github.com/ahmetb/kubectx.git
synced 2026-03-16 19:02:14 +00:00
Compare commits
1 Commits
master
...
abalkan/re
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
961fc1b6a8 |
@@ -18,8 +18,6 @@ import (
|
|||||||
"runtime"
|
"runtime"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/ahmetb/kubectx/internal/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestNSFile(t *testing.T) {
|
func TestNSFile(t *testing.T) {
|
||||||
@@ -50,7 +48,7 @@ func TestNSFile(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestNSFile_path_windows(t *testing.T) {
|
func TestNSFile_path_windows(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("_FORCE_GOOS", "windows")()
|
t.Setenv("_FORCE_GOOS", "windows")
|
||||||
fp := NewNSFile("a:b:c").path()
|
fp := NewNSFile("a:b:c").path()
|
||||||
|
|
||||||
if expected := "a__b__c"; !strings.HasSuffix(fp, expected) {
|
if expected := "a__b__c"; !strings.HasSuffix(fp, expected) {
|
||||||
@@ -68,7 +66,7 @@ func Test_isWindows(t *testing.T) {
|
|||||||
t.Fatalf("isWindows() returned true for %s", runtime.GOOS)
|
t.Fatalf("isWindows() returned true for %s", runtime.GOOS)
|
||||||
}
|
}
|
||||||
|
|
||||||
defer testutil.WithEnvVar("_FORCE_GOOS", "windows")()
|
t.Setenv("_FORCE_GOOS", "windows")
|
||||||
if !isWindows() {
|
if !isWindows() {
|
||||||
t.Fatalf("isWindows() failed to detect windows with env override.")
|
t.Fatalf("isWindows() failed to detect windows with env override.")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,8 +17,6 @@ package cmdutil
|
|||||||
import (
|
import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/ahmetb/kubectx/internal/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_homeDir(t *testing.T) {
|
func Test_homeDir(t *testing.T) {
|
||||||
@@ -64,18 +62,14 @@ func Test_homeDir(t *testing.T) {
|
|||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
t.Run(c.name, func(tt *testing.T) {
|
t.Run(c.name, func(tt *testing.T) {
|
||||||
var unsets []func()
|
|
||||||
for _, e := range c.envs {
|
for _, e := range c.envs {
|
||||||
unsets = append(unsets, testutil.WithEnvVar(e.k, e.v))
|
tt.Setenv(e.k, e.v)
|
||||||
}
|
}
|
||||||
|
|
||||||
got := HomeDir()
|
got := HomeDir()
|
||||||
if got != c.want {
|
if got != c.want {
|
||||||
t.Errorf("expected:%q got:%q", c.want, got)
|
t.Errorf("expected:%q got:%q", c.want, got)
|
||||||
}
|
}
|
||||||
for _, u := range unsets {
|
|
||||||
u()
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,17 +15,16 @@
|
|||||||
package kubeconfig
|
package kubeconfig
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/ahmetb/kubectx/internal/cmdutil"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/ahmetb/kubectx/internal/testutil"
|
"github.com/ahmetb/kubectx/internal/cmdutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_kubeconfigPath(t *testing.T) {
|
func Test_kubeconfigPath(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("HOME", "/x/y/z")()
|
t.Setenv("HOME", "/x/y/z")
|
||||||
|
|
||||||
expected := filepath.FromSlash("/x/y/z/.kube/config")
|
expected := filepath.FromSlash("/x/y/z/.kube/config")
|
||||||
got, err := kubeconfigPath()
|
got, err := kubeconfigPath()
|
||||||
@@ -38,9 +37,9 @@ func Test_kubeconfigPath(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Test_kubeconfigPath_noEnvVars(t *testing.T) {
|
func Test_kubeconfigPath_noEnvVars(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("XDG_CACHE_HOME", "")()
|
t.Setenv("XDG_CACHE_HOME", "")
|
||||||
defer testutil.WithEnvVar("HOME", "")()
|
t.Setenv("HOME", "")
|
||||||
defer testutil.WithEnvVar("USERPROFILE", "")()
|
t.Setenv("USERPROFILE", "")
|
||||||
|
|
||||||
_, err := kubeconfigPath()
|
_, err := kubeconfigPath()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
@@ -49,7 +48,7 @@ func Test_kubeconfigPath_noEnvVars(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Test_kubeconfigPath_envOvveride(t *testing.T) {
|
func Test_kubeconfigPath_envOvveride(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("KUBECONFIG", "foo")()
|
t.Setenv("KUBECONFIG", "foo")
|
||||||
|
|
||||||
v, err := kubeconfigPath()
|
v, err := kubeconfigPath()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -62,7 +61,7 @@ func Test_kubeconfigPath_envOvveride(t *testing.T) {
|
|||||||
|
|
||||||
func Test_kubeconfigPath_envOvverideDoesNotSupportPathSeparator(t *testing.T) {
|
func Test_kubeconfigPath_envOvverideDoesNotSupportPathSeparator(t *testing.T) {
|
||||||
path := strings.Join([]string{"file1", "file2"}, string(os.PathListSeparator))
|
path := strings.Join([]string{"file1", "file2"}, string(os.PathListSeparator))
|
||||||
defer testutil.WithEnvVar("KUBECONFIG", path)()
|
t.Setenv("KUBECONFIG", path)
|
||||||
|
|
||||||
_, err := kubeconfigPath()
|
_, err := kubeconfigPath()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
@@ -71,7 +70,7 @@ func Test_kubeconfigPath_envOvverideDoesNotSupportPathSeparator(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestStandardKubeconfigLoader_returnsNotFoundErr(t *testing.T) {
|
func TestStandardKubeconfigLoader_returnsNotFoundErr(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("KUBECONFIG", "foo")()
|
t.Setenv("KUBECONFIG", "foo")
|
||||||
kc := new(Kubeconfig).WithLoader(DefaultLoader)
|
kc := new(Kubeconfig).WithLoader(DefaultLoader)
|
||||||
err := kc.Parse()
|
err := kc.Parse()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
|
|||||||
@@ -18,8 +18,6 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/google/go-cmp/cmp"
|
"github.com/google/go-cmp/cmp"
|
||||||
|
|
||||||
"github.com/ahmetb/kubectx/internal/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@@ -27,8 +25,8 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func Test_useColors_forceColors(t *testing.T) {
|
func Test_useColors_forceColors(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("_KUBECTX_FORCE_COLOR", "1")()
|
t.Setenv("_KUBECTX_FORCE_COLOR", "1")
|
||||||
defer testutil.WithEnvVar("NO_COLOR", "1")()
|
t.Setenv("NO_COLOR", "1")
|
||||||
|
|
||||||
if v := useColors(); !cmp.Equal(v, &tr) {
|
if v := useColors(); !cmp.Equal(v, &tr) {
|
||||||
t.Fatalf("expected useColors() = true; got = %v", v)
|
t.Fatalf("expected useColors() = true; got = %v", v)
|
||||||
@@ -36,7 +34,7 @@ func Test_useColors_forceColors(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Test_useColors_disableColors(t *testing.T) {
|
func Test_useColors_disableColors(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("NO_COLOR", "1")()
|
t.Setenv("NO_COLOR", "1")
|
||||||
|
|
||||||
if v := useColors(); !cmp.Equal(v, &fa) {
|
if v := useColors(); !cmp.Equal(v, &fa) {
|
||||||
t.Fatalf("expected useColors() = false; got = %v", v)
|
t.Fatalf("expected useColors() = false; got = %v", v)
|
||||||
@@ -44,8 +42,8 @@ func Test_useColors_disableColors(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Test_useColors_default(t *testing.T) {
|
func Test_useColors_default(t *testing.T) {
|
||||||
defer testutil.WithEnvVar("NO_COLOR", "")()
|
t.Setenv("NO_COLOR", "")
|
||||||
defer testutil.WithEnvVar("_KUBECTX_FORCE_COLOR", "")()
|
t.Setenv("_KUBECTX_FORCE_COLOR", "")
|
||||||
|
|
||||||
if v := useColors(); v != nil {
|
if v := useColors(); v != nil {
|
||||||
t.Fatalf("expected useColors() = nil; got=%v", *v)
|
t.Fatalf("expected useColors() = nil; got=%v", *v)
|
||||||
|
|||||||
@@ -1,31 +0,0 @@
|
|||||||
// Copyright 2021 Google LLC
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
package testutil
|
|
||||||
|
|
||||||
import "os"
|
|
||||||
|
|
||||||
// WithEnvVar sets an env var temporarily. Call its return value
|
|
||||||
// in defer to restore original value in env (if exists).
|
|
||||||
func WithEnvVar(key, value string) func() {
|
|
||||||
orig, ok := os.LookupEnv(key)
|
|
||||||
os.Setenv(key, value)
|
|
||||||
return func() {
|
|
||||||
if ok {
|
|
||||||
os.Setenv(key, orig)
|
|
||||||
} else {
|
|
||||||
os.Unsetenv(key)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user