2017-11-22 13:35:47 +00:00
|
|
|
/*
|
|
|
|
Copyright 2017 The Kubernetes Authors.
|
|
|
|
|
|
|
|
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 main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"syscall"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2019-06-30 22:58:18 +00:00
|
|
|
corev1 "k8s.io/api/core/v1"
|
2018-07-16 16:17:13 +00:00
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
2018-12-05 16:27:55 +00:00
|
|
|
"k8s.io/client-go/kubernetes"
|
|
|
|
"k8s.io/client-go/kubernetes/fake"
|
|
|
|
|
|
|
|
"k8s.io/ingress-nginx/internal/file"
|
|
|
|
"k8s.io/ingress-nginx/internal/ingress/controller"
|
2017-11-22 13:35:47 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestCreateApiserverClient(t *testing.T) {
|
2018-07-16 16:17:13 +00:00
|
|
|
_, err := createApiserverClient("", "")
|
2017-11-22 13:35:47 +00:00
|
|
|
if err == nil {
|
2018-06-11 09:17:50 +00:00
|
|
|
t.Fatal("Expected an error creating REST client without an API server URL or kubeconfig file.")
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHandleSigterm(t *testing.T) {
|
2018-07-16 16:17:13 +00:00
|
|
|
clientSet := fake.NewSimpleClientset()
|
|
|
|
|
|
|
|
ns := "test"
|
|
|
|
|
|
|
|
cm := createConfigMap(clientSet, ns, t)
|
|
|
|
defer deleteConfigMap(cm, ns, clientSet, t)
|
2017-11-22 13:35:47 +00:00
|
|
|
|
2018-07-16 16:17:13 +00:00
|
|
|
name := "test"
|
2019-06-30 22:58:18 +00:00
|
|
|
pod := corev1.Pod{
|
2018-07-16 16:17:13 +00:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: name,
|
|
|
|
Namespace: ns,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err := clientSet.CoreV1().Pods(ns).Create(&pod)
|
2017-11-22 13:35:47 +00:00
|
|
|
if err != nil {
|
2018-07-16 16:17:13 +00:00
|
|
|
t.Fatalf("error creating pod %v: %v", pod, err)
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
resetForTesting(func() { t.Fatal("bad parse") })
|
|
|
|
|
2018-07-16 16:17:13 +00:00
|
|
|
os.Setenv("POD_NAME", name)
|
|
|
|
os.Setenv("POD_NAMESPACE", ns)
|
2017-11-22 13:35:47 +00:00
|
|
|
defer os.Setenv("POD_NAME", "")
|
|
|
|
defer os.Setenv("POD_NAMESPACE", "")
|
|
|
|
|
|
|
|
oldArgs := os.Args
|
|
|
|
defer func() { os.Args = oldArgs }()
|
|
|
|
os.Args = []string{"cmd", "--default-backend-service", "ingress-nginx/default-backend-http", "--http-port", "0", "--https-port", "0"}
|
|
|
|
|
|
|
|
_, conf, err := parseFlags()
|
|
|
|
if err != nil {
|
2018-06-11 09:17:50 +00:00
|
|
|
t.Errorf("Unexpected error creating NGINX controller: %v", err)
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
2018-07-16 16:17:13 +00:00
|
|
|
conf.Client = clientSet
|
2017-11-22 13:35:47 +00:00
|
|
|
|
|
|
|
fs, err := file.NewFakeFS()
|
|
|
|
if err != nil {
|
2018-06-11 09:17:50 +00:00
|
|
|
t.Fatalf("Unexpected error: %v", err)
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
|
|
|
|
2018-07-07 17:46:18 +00:00
|
|
|
ngx := controller.NewNGINXController(conf, nil, fs)
|
2017-11-22 13:35:47 +00:00
|
|
|
|
|
|
|
go handleSigterm(ngx, func(code int) {
|
|
|
|
if code != 1 {
|
2018-06-11 09:17:50 +00:00
|
|
|
t.Errorf("Expected exit code 1 but %d received", code)
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
|
2018-06-11 09:17:50 +00:00
|
|
|
t.Logf("Sending SIGTERM to PID %d", syscall.Getpid())
|
2017-11-22 13:35:47 +00:00
|
|
|
err = syscall.Kill(syscall.Getpid(), syscall.SIGTERM)
|
|
|
|
if err != nil {
|
2018-06-11 09:17:50 +00:00
|
|
|
t.Error("Unexpected error sending SIGTERM signal.")
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
2018-07-16 16:17:13 +00:00
|
|
|
|
|
|
|
err = clientSet.CoreV1().Pods(ns).Delete(name, &metav1.DeleteOptions{})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("error deleting pod %v: %v", pod, err)
|
|
|
|
}
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|
|
|
|
|
2018-07-16 16:17:13 +00:00
|
|
|
func createConfigMap(clientSet kubernetes.Interface, ns string, t *testing.T) string {
|
|
|
|
t.Helper()
|
|
|
|
t.Log("Creating temporal config map")
|
|
|
|
|
2019-06-30 22:58:18 +00:00
|
|
|
configMap := &corev1.ConfigMap{
|
2018-07-16 16:17:13 +00:00
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "config",
|
|
|
|
SelfLink: fmt.Sprintf("/api/v1/namespaces/%s/configmaps/config", ns),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
cm, err := clientSet.CoreV1().ConfigMaps(ns).Create(configMap)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("error creating the configuration map: %v", err)
|
|
|
|
}
|
|
|
|
t.Logf("Temporal configmap %v created", cm)
|
|
|
|
|
|
|
|
return cm.Name
|
|
|
|
}
|
|
|
|
|
|
|
|
func deleteConfigMap(cm, ns string, clientSet kubernetes.Interface, t *testing.T) {
|
|
|
|
t.Helper()
|
|
|
|
t.Logf("Deleting temporal configmap %v", cm)
|
|
|
|
|
|
|
|
err := clientSet.CoreV1().ConfigMaps(ns).Delete(cm, &metav1.DeleteOptions{})
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("error deleting the configmap: %v", err)
|
|
|
|
}
|
|
|
|
t.Logf("Temporal configmap %v deleted", cm)
|
2017-11-22 13:35:47 +00:00
|
|
|
}
|