forked from LaconicNetwork/kompose
Merge pull request #277 from surajssd/generic-service-type
Generic service type handler for kompose
This commit is contained in:
commit
04b1d004b4
@ -143,6 +143,7 @@ type ServiceConfig struct {
|
|||||||
Restart string
|
Restart string
|
||||||
User string
|
User string
|
||||||
VolumesFrom []string
|
VolumesFrom []string
|
||||||
|
ServiceType string
|
||||||
}
|
}
|
||||||
|
|
||||||
// EnvVar holds the environment variable struct of a container
|
// EnvVar holds the environment variable struct of a container
|
||||||
|
|||||||
@ -207,6 +207,16 @@ func (c *Compose) LoadFile(file string) kobject.KomposeObject {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// canonical "Custom Labels" handler
|
||||||
|
// Labels used to influence conversion of kompose will be handled
|
||||||
|
// from here for docker-compose. Each loader will have such handler.
|
||||||
|
for key, value := range composeServiceConfig.Labels {
|
||||||
|
switch key {
|
||||||
|
case "kompose.service.type":
|
||||||
|
serviceConfig.ServiceType = handleServiceType(value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// convert compose labels to annotations
|
// convert compose labels to annotations
|
||||||
serviceConfig.Annotations = map[string]string(composeServiceConfig.Labels)
|
serviceConfig.Annotations = map[string]string(composeServiceConfig.Labels)
|
||||||
|
|
||||||
@ -227,3 +237,17 @@ func (c *Compose) LoadFile(file string) kobject.KomposeObject {
|
|||||||
|
|
||||||
return komposeObject
|
return komposeObject
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func handleServiceType(ServiceType string) string {
|
||||||
|
switch strings.ToLower(ServiceType) {
|
||||||
|
case "", "clusterip":
|
||||||
|
return string(api.ServiceTypeClusterIP)
|
||||||
|
case "nodeport":
|
||||||
|
return string(api.ServiceTypeNodePort)
|
||||||
|
case "loadbalancer":
|
||||||
|
return string(api.ServiceTypeLoadBalancer)
|
||||||
|
default:
|
||||||
|
logrus.Fatalf("Unknown value '%s', supported values are 'NodePort, ClusterIP or LoadBalancer'", ServiceType)
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
43
pkg/loader/compose/compose_test.go
Normal file
43
pkg/loader/compose/compose_test.go
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2016 The Kubernetes Authors All rights reserved.
|
||||||
|
|
||||||
|
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 compose
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
// Test if service types are parsed properly on user input
|
||||||
|
// give a service type and expect correct input
|
||||||
|
func TestHandleServiceType(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
labelValue string
|
||||||
|
serviceType string
|
||||||
|
}{
|
||||||
|
{"NodePort", "NodePort"},
|
||||||
|
{"nodeport", "NodePort"},
|
||||||
|
{"LoadBalancer", "LoadBalancer"},
|
||||||
|
{"loadbalancer", "LoadBalancer"},
|
||||||
|
{"ClusterIP", "ClusterIP"},
|
||||||
|
{"clusterip", "ClusterIP"},
|
||||||
|
{"", "ClusterIP"},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
result := handleServiceType(tt.labelValue)
|
||||||
|
if result != tt.serviceType {
|
||||||
|
t.Errorf("Expected %q, got %q", tt.serviceType, result)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -244,21 +244,7 @@ func (k *Kubernetes) CreateService(name string, service kobject.ServiceConfig, o
|
|||||||
servicePorts := k.ConfigServicePorts(name, service)
|
servicePorts := k.ConfigServicePorts(name, service)
|
||||||
svc.Spec.Ports = servicePorts
|
svc.Spec.Ports = servicePorts
|
||||||
|
|
||||||
// Configure service types
|
svc.Spec.Type = api.ServiceType(service.ServiceType)
|
||||||
for key, value := range service.Annotations {
|
|
||||||
if key == "kompose.service.type" {
|
|
||||||
if strings.ToLower(value) == "nodeport" {
|
|
||||||
svc.Spec.Type = "NodePort"
|
|
||||||
} else if strings.ToLower(value) == "clusterip" {
|
|
||||||
svc.Spec.Type = "ClusterIP"
|
|
||||||
} else if strings.ToLower(value) == "loadbalancer" {
|
|
||||||
svc.Spec.Type = "LoadBalancer"
|
|
||||||
} else {
|
|
||||||
logrus.Fatalf("Unknown value '%s', supported values are 'NodePort, ClusterIP and LoadBalancer' " , value)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Configure annotations
|
// Configure annotations
|
||||||
annotations := transformer.ConfigAnnotations(service)
|
annotations := transformer.ConfigAnnotations(service)
|
||||||
svc.ObjectMeta.Annotations = annotations
|
svc.ObjectMeta.Annotations = annotations
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 2016 Skippbox, Ltd All rights reserved.
|
Copyright 2016 The Kubernetes Authors All rights reserved.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
@ -17,9 +17,10 @@ limitations under the License.
|
|||||||
package kubernetes
|
package kubernetes
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
"github.com/kubernetes-incubator/kompose/pkg/kobject"
|
"github.com/kubernetes-incubator/kompose/pkg/kobject"
|
||||||
"k8s.io/kubernetes/pkg/api"
|
"k8s.io/kubernetes/pkg/api"
|
||||||
"testing"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -64,63 +65,3 @@ func TestCreateService(t *testing.T) {
|
|||||||
t.Errorf("Expected port 123 upon conversion, actual %d", svc.Spec.Ports[0].Port)
|
t.Errorf("Expected port 123 upon conversion, actual %d", svc.Spec.Ports[0].Port)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
Test the creation of a service with a specified annotation (kompose.service.type) as "nodeport".
|
|
||||||
The expected result is that Kompose will convert the spec type to "NodePort" upon generation.
|
|
||||||
*/
|
|
||||||
func TestCreateServiceWithServiceTypeNodePort(t *testing.T) {
|
|
||||||
|
|
||||||
// An example service
|
|
||||||
service := kobject.ServiceConfig{
|
|
||||||
ContainerName: "name",
|
|
||||||
Image: "image",
|
|
||||||
Environment: []kobject.EnvVar{kobject.EnvVar{Name: "env", Value: "value"}},
|
|
||||||
Port: []kobject.Ports{kobject.Ports{HostPort: 123, ContainerPort: 456, Protocol: api.ProtocolTCP}},
|
|
||||||
Command: []string{"cmd"},
|
|
||||||
WorkingDir: "dir",
|
|
||||||
Args: []string{"arg1", "arg2"},
|
|
||||||
Volumes: []string{"/tmp/volume"},
|
|
||||||
Network: []string{"network1", "network2"}, // not supported
|
|
||||||
Labels: nil,
|
|
||||||
Annotations: map[string]string{"kompose.service.type": "nodeport"},
|
|
||||||
CPUSet: "cpu_set", // not supported
|
|
||||||
CPUShares: 1, // not supported
|
|
||||||
CPUQuota: 1, // not supported
|
|
||||||
CapAdd: []string{"cap_add"}, // not supported
|
|
||||||
CapDrop: []string{"cap_drop"}, // not supported
|
|
||||||
Expose: []string{"expose"}, // not supported
|
|
||||||
Privileged: true,
|
|
||||||
Restart: "always",
|
|
||||||
User: "user", // not supported
|
|
||||||
}
|
|
||||||
|
|
||||||
// An example object generated via k8s runtime.Objects()
|
|
||||||
kompose_object := kobject.KomposeObject{
|
|
||||||
ServiceConfigs: map[string]kobject.ServiceConfig{"app": service},
|
|
||||||
}
|
|
||||||
k := Kubernetes{}
|
|
||||||
tests := []struct {
|
|
||||||
labelValue string
|
|
||||||
serviceType string
|
|
||||||
}{
|
|
||||||
{"NodePort", "NodePort"},
|
|
||||||
{"nodeport", "NodePort"},
|
|
||||||
{"LoadBalancer", "LoadBalancer"},
|
|
||||||
{"loadbalancer", "LoadBalancer"},
|
|
||||||
{"ClusterIP", "ClusterIP"},
|
|
||||||
{"clusterip", "ClusterIP"},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, tt := range tests {
|
|
||||||
kompose_object.ServiceConfigs["app"].Annotations["kompose.service.type"] = tt.labelValue
|
|
||||||
|
|
||||||
objects := k.Transform(kompose_object, kobject.ConvertOptions{CreateD: true, Replicas: 3})
|
|
||||||
|
|
||||||
// Test the creation of the service with modified annotations (kompose.service.type)
|
|
||||||
svc := k.CreateService("foo", service, objects)
|
|
||||||
if svc.Spec.Type != api.ServiceType(tt.serviceType) {
|
|
||||||
t.Errorf("Expected NodePort, actual %d", svc.Spec.Type)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user