Merge pull request #68402 from saravanan30erd/cloudprovider-ovirt

Fix golint failures - pkg/cloudprovider/providers/ovirt
pull/564/head
k8s-ci-robot 2018-11-28 21:44:38 -08:00 committed by GitHub
commit 7a958cf9e9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 57 additions and 47 deletions

View File

@ -89,7 +89,6 @@ pkg/auth/authorizer/abac
pkg/capabilities pkg/capabilities
pkg/cloudprovider/providers/fake pkg/cloudprovider/providers/fake
pkg/cloudprovider/providers/gce/cloud pkg/cloudprovider/providers/gce/cloud
pkg/cloudprovider/providers/ovirt
pkg/cloudprovider/providers/photon pkg/cloudprovider/providers/photon
pkg/cloudprovider/providers/vsphere pkg/cloudprovider/providers/vsphere
pkg/cloudprovider/providers/vsphere/vclib pkg/cloudprovider/providers/vsphere/vclib

View File

@ -36,24 +36,29 @@ import (
cloudprovider "k8s.io/cloud-provider" cloudprovider "k8s.io/cloud-provider"
) )
// ProviderName is the name of this cloud provider.
const ProviderName = "ovirt" const ProviderName = "ovirt"
type OVirtInstance struct { // Instance specifies UUID, name and IP address of the instance.
type Instance struct {
UUID string UUID string
Name string Name string
IPAddress string IPAddress string
} }
type OVirtInstanceMap map[string]OVirtInstance // InstanceMap provides the map of Ovirt instances.
type InstanceMap map[string]Instance
type OVirtCloud struct { // Cloud is an implementation of the cloud provider interface for Ovirt.
type Cloud struct {
VmsRequest *url.URL VmsRequest *url.URL
HostsRequest *url.URL HostsRequest *url.URL
} }
type OVirtApiConfig struct { // APIConfig wraps the api settings for the Ovirt.
type APIConfig struct {
Connection struct { Connection struct {
ApiEntry string `gcfg:"uri"` APIEntry string `gcfg:"uri"`
Username string `gcfg:"username"` Username string `gcfg:"username"`
Password string `gcfg:"password"` Password string `gcfg:"password"`
} }
@ -62,21 +67,24 @@ type OVirtApiConfig struct {
} }
} }
type XmlVmAddress struct { // XMLVMAddress is an implementation for the Ovirt instance IP address in xml.
type XMLVMAddress struct {
Address string `xml:"address,attr"` Address string `xml:"address,attr"`
} }
type XmlVmInfo struct { // XMLVMInfo is an implementation for the Ovirt instance details in xml.
type XMLVMInfo struct {
UUID string `xml:"id,attr"` UUID string `xml:"id,attr"`
Name string `xml:"name"` Name string `xml:"name"`
Hostname string `xml:"guest_info>fqdn"` Hostname string `xml:"guest_info>fqdn"`
Addresses []XmlVmAddress `xml:"guest_info>ips>ip"` Addresses []XMLVMAddress `xml:"guest_info>ips>ip"`
State string `xml:"status>state"` State string `xml:"status>state"`
} }
type XmlVmsList struct { // XMLVmsList is an implementation to provide the list of Ovirt instances.
type XMLVmsList struct {
XMLName xml.Name `xml:"vms"` XMLName xml.Name `xml:"vms"`
Vm []XmlVmInfo `xml:"vm"` VM []XMLVMInfo `xml:"vm"`
} }
func init() { func init() {
@ -86,12 +94,12 @@ func init() {
}) })
} }
func newOVirtCloud(config io.Reader) (*OVirtCloud, error) { func newOVirtCloud(config io.Reader) (*Cloud, error) {
if config == nil { if config == nil {
return nil, fmt.Errorf("missing configuration file for ovirt cloud provider") return nil, fmt.Errorf("missing configuration file for ovirt cloud provider")
} }
oVirtConfig := OVirtApiConfig{} oVirtConfig := APIConfig{}
/* defaults */ /* defaults */
oVirtConfig.Connection.Username = "admin@internal" oVirtConfig.Connection.Username = "admin@internal"
@ -100,11 +108,11 @@ func newOVirtCloud(config io.Reader) (*OVirtCloud, error) {
return nil, err return nil, err
} }
if oVirtConfig.Connection.ApiEntry == "" { if oVirtConfig.Connection.APIEntry == "" {
return nil, fmt.Errorf("missing ovirt uri in cloud provider configuration") return nil, fmt.Errorf("missing ovirt uri in cloud provider configuration")
} }
request, err := url.Parse(oVirtConfig.Connection.ApiEntry) request, err := url.Parse(oVirtConfig.Connection.APIEntry)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -113,49 +121,50 @@ func newOVirtCloud(config io.Reader) (*OVirtCloud, error) {
request.User = url.UserPassword(oVirtConfig.Connection.Username, oVirtConfig.Connection.Password) request.User = url.UserPassword(oVirtConfig.Connection.Username, oVirtConfig.Connection.Password)
request.RawQuery = url.Values{"search": {oVirtConfig.Filters.VmsQuery}}.Encode() request.RawQuery = url.Values{"search": {oVirtConfig.Filters.VmsQuery}}.Encode()
return &OVirtCloud{VmsRequest: request}, nil return &Cloud{VmsRequest: request}, nil
} }
// Initialize passes a Kubernetes clientBuilder interface to the cloud provider // Initialize passes a Kubernetes clientBuilder interface to the cloud provider
func (v *OVirtCloud) Initialize(clientBuilder cloudprovider.ControllerClientBuilder, stop <-chan struct{}) { func (v *Cloud) Initialize(clientBuilder cloudprovider.ControllerClientBuilder, stop <-chan struct{}) {
} }
func (v *OVirtCloud) Clusters() (cloudprovider.Clusters, bool) { // Clusters returns the list of clusters.
func (v *Cloud) Clusters() (cloudprovider.Clusters, bool) {
return nil, false return nil, false
} }
// ProviderName returns the cloud provider ID. // ProviderName returns the cloud provider ID.
func (v *OVirtCloud) ProviderName() string { func (v *Cloud) ProviderName() string {
return ProviderName return ProviderName
} }
// HasClusterID returns true if the cluster has a clusterID // HasClusterID returns true if the cluster has a clusterID
func (v *OVirtCloud) HasClusterID() bool { func (v *Cloud) HasClusterID() bool {
return true return true
} }
// LoadBalancer returns an implementation of LoadBalancer for oVirt cloud // LoadBalancer returns an implementation of LoadBalancer for oVirt cloud
func (v *OVirtCloud) LoadBalancer() (cloudprovider.LoadBalancer, bool) { func (v *Cloud) LoadBalancer() (cloudprovider.LoadBalancer, bool) {
return nil, false return nil, false
} }
// Instances returns an implementation of Instances for oVirt cloud // Instances returns an implementation of Instances for oVirt cloud
func (v *OVirtCloud) Instances() (cloudprovider.Instances, bool) { func (v *Cloud) Instances() (cloudprovider.Instances, bool) {
return v, true return v, true
} }
// Zones returns an implementation of Zones for oVirt cloud // Zones returns an implementation of Zones for oVirt cloud
func (v *OVirtCloud) Zones() (cloudprovider.Zones, bool) { func (v *Cloud) Zones() (cloudprovider.Zones, bool) {
return nil, false return nil, false
} }
// Routes returns an implementation of Routes for oVirt cloud // Routes returns an implementation of Routes for oVirt cloud
func (v *OVirtCloud) Routes() (cloudprovider.Routes, bool) { func (v *Cloud) Routes() (cloudprovider.Routes, bool) {
return nil, false return nil, false
} }
// NodeAddresses returns the NodeAddresses of the instance with the specified nodeName. // NodeAddresses returns the NodeAddresses of the instance with the specified nodeName.
func (v *OVirtCloud) NodeAddresses(ctx context.Context, nodeName types.NodeName) ([]v1.NodeAddress, error) { func (v *Cloud) NodeAddresses(ctx context.Context, nodeName types.NodeName) ([]v1.NodeAddress, error) {
name := mapNodeNameToInstanceName(nodeName) name := mapNodeNameToInstanceName(nodeName)
instance, err := v.fetchInstance(name) instance, err := v.fetchInstance(name)
if err != nil { if err != nil {
@ -186,7 +195,7 @@ func (v *OVirtCloud) NodeAddresses(ctx context.Context, nodeName types.NodeName)
// NodeAddressesByProviderID returns the node addresses of an instances with the specified unique providerID // NodeAddressesByProviderID returns the node addresses of an instances with the specified unique providerID
// This method will not be called from the node that is requesting this ID. i.e. metadata service // This method will not be called from the node that is requesting this ID. i.e. metadata service
// and other local methods cannot be used here // and other local methods cannot be used here
func (v *OVirtCloud) NodeAddressesByProviderID(ctx context.Context, providerID string) ([]v1.NodeAddress, error) { func (v *Cloud) NodeAddressesByProviderID(ctx context.Context, providerID string) ([]v1.NodeAddress, error) {
return []v1.NodeAddress{}, cloudprovider.NotImplemented return []v1.NodeAddress{}, cloudprovider.NotImplemented
} }
@ -198,17 +207,17 @@ func mapNodeNameToInstanceName(nodeName types.NodeName) string {
// InstanceExistsByProviderID returns true if the instance with the given provider id still exists and is running. // InstanceExistsByProviderID returns true if the instance with the given provider id still exists and is running.
// If false is returned with no error, the instance will be immediately deleted by the cloud controller manager. // If false is returned with no error, the instance will be immediately deleted by the cloud controller manager.
func (v *OVirtCloud) InstanceExistsByProviderID(ctx context.Context, providerID string) (bool, error) { func (v *Cloud) InstanceExistsByProviderID(ctx context.Context, providerID string) (bool, error) {
return false, cloudprovider.NotImplemented return false, cloudprovider.NotImplemented
} }
// InstanceShutdownByProviderID returns true if the instance is in safe state to detach volumes // InstanceShutdownByProviderID returns true if the instance is in safe state to detach volumes
func (v *OVirtCloud) InstanceShutdownByProviderID(ctx context.Context, providerID string) (bool, error) { func (v *Cloud) InstanceShutdownByProviderID(ctx context.Context, providerID string) (bool, error) {
return false, cloudprovider.NotImplemented return false, cloudprovider.NotImplemented
} }
// InstanceID returns the cloud provider ID of the node with the specified NodeName. // InstanceID returns the cloud provider ID of the node with the specified NodeName.
func (v *OVirtCloud) InstanceID(ctx context.Context, nodeName types.NodeName) (string, error) { func (v *Cloud) InstanceID(ctx context.Context, nodeName types.NodeName) (string, error) {
name := mapNodeNameToInstanceName(nodeName) name := mapNodeNameToInstanceName(nodeName)
instance, err := v.fetchInstance(name) instance, err := v.fetchInstance(name)
if err != nil { if err != nil {
@ -222,16 +231,16 @@ func (v *OVirtCloud) InstanceID(ctx context.Context, nodeName types.NodeName) (s
// InstanceTypeByProviderID returns the cloudprovider instance type of the node with the specified unique providerID // InstanceTypeByProviderID returns the cloudprovider instance type of the node with the specified unique providerID
// This method will not be called from the node that is requesting this ID. i.e. metadata service // This method will not be called from the node that is requesting this ID. i.e. metadata service
// and other local methods cannot be used here // and other local methods cannot be used here
func (v *OVirtCloud) InstanceTypeByProviderID(ctx context.Context, providerID string) (string, error) { func (v *Cloud) InstanceTypeByProviderID(ctx context.Context, providerID string) (string, error) {
return "", cloudprovider.NotImplemented return "", cloudprovider.NotImplemented
} }
// InstanceType returns the type of the specified instance. // InstanceType returns the type of the specified instance.
func (v *OVirtCloud) InstanceType(ctx context.Context, name types.NodeName) (string, error) { func (v *Cloud) InstanceType(ctx context.Context, name types.NodeName) (string, error) {
return "", nil return "", nil
} }
func getInstancesFromXml(body io.Reader) (OVirtInstanceMap, error) { func getInstancesFromXML(body io.Reader) (InstanceMap, error) {
if body == nil { if body == nil {
return nil, fmt.Errorf("ovirt rest-api response body is missing") return nil, fmt.Errorf("ovirt rest-api response body is missing")
} }
@ -241,15 +250,15 @@ func getInstancesFromXml(body io.Reader) (OVirtInstanceMap, error) {
return nil, err return nil, err
} }
vmlist := XmlVmsList{} vmlist := XMLVmsList{}
if err := xml.Unmarshal(content, &vmlist); err != nil { if err := xml.Unmarshal(content, &vmlist); err != nil {
return nil, err return nil, err
} }
instances := make(OVirtInstanceMap) instances := make(InstanceMap)
for _, vm := range vmlist.Vm { for _, vm := range vmlist.VM {
// Always return only vms that are up and running // Always return only vms that are up and running
if vm.Hostname != "" && strings.ToLower(vm.State) == "up" { if vm.Hostname != "" && strings.ToLower(vm.State) == "up" {
address := "" address := ""
@ -257,7 +266,7 @@ func getInstancesFromXml(body io.Reader) (OVirtInstanceMap, error) {
address = vm.Addresses[0].Address address = vm.Addresses[0].Address
} }
instances[vm.Hostname] = OVirtInstance{ instances[vm.Hostname] = Instance{
UUID: vm.UUID, UUID: vm.UUID,
Name: vm.Name, Name: vm.Name,
IPAddress: address, IPAddress: address,
@ -268,7 +277,7 @@ func getInstancesFromXml(body io.Reader) (OVirtInstanceMap, error) {
return instances, nil return instances, nil
} }
func (v *OVirtCloud) fetchAllInstances() (OVirtInstanceMap, error) { func (v *Cloud) fetchAllInstances() (InstanceMap, error) {
response, err := http.Get(v.VmsRequest.String()) response, err := http.Get(v.VmsRequest.String())
if err != nil { if err != nil {
return nil, err return nil, err
@ -276,10 +285,10 @@ func (v *OVirtCloud) fetchAllInstances() (OVirtInstanceMap, error) {
defer response.Body.Close() defer response.Body.Close()
return getInstancesFromXml(response.Body) return getInstancesFromXML(response.Body)
} }
func (v *OVirtCloud) fetchInstance(name string) (*OVirtInstance, error) { func (v *Cloud) fetchInstance(name string) (*Instance, error) {
allInstances, err := v.fetchAllInstances() allInstances, err := v.fetchAllInstances()
if err != nil { if err != nil {
return nil, err return nil, err
@ -293,7 +302,8 @@ func (v *OVirtCloud) fetchInstance(name string) (*OVirtInstance, error) {
return &instance, nil return &instance, nil
} }
func (m *OVirtInstanceMap) ListSortedNames() []string { // ListSortedNames returns the list of sorted Ovirt instances name.
func (m *InstanceMap) ListSortedNames() []string {
var names []string var names []string
for k := range *m { for k := range *m {
@ -305,11 +315,12 @@ func (m *OVirtInstanceMap) ListSortedNames() []string {
return names return names
} }
// Implementation of Instances.CurrentNodeName // CurrentNodeName is implementation of Instances.CurrentNodeName.
func (v *OVirtCloud) CurrentNodeName(ctx context.Context, hostname string) (types.NodeName, error) { func (v *Cloud) CurrentNodeName(ctx context.Context, hostname string) (types.NodeName, error) {
return types.NodeName(hostname), nil return types.NodeName(hostname), nil
} }
func (v *OVirtCloud) AddSSHKeyToAllInstances(ctx context.Context, user string, keyData []byte) error { // AddSSHKeyToAllInstances is currently not implemented.
func (v *Cloud) AddSSHKeyToAllInstances(ctx context.Context, user string, keyData []byte) error {
return cloudprovider.NotImplemented return cloudprovider.NotImplemented
} }

View File

@ -62,14 +62,14 @@ uri = https://localhost:8443/ovirt-engine/api
func TestOVirtCloudXmlParsing(t *testing.T) { func TestOVirtCloudXmlParsing(t *testing.T) {
body1 := (io.Reader)(nil) body1 := (io.Reader)(nil)
_, err1 := getInstancesFromXml(body1) _, err1 := getInstancesFromXML(body1)
if err1 == nil { if err1 == nil {
t.Fatalf("An error is expected when body is missing") t.Fatalf("An error is expected when body is missing")
} }
body2 := strings.NewReader("") body2 := strings.NewReader("")
_, err2 := getInstancesFromXml(body2) _, err2 := getInstancesFromXML(body2)
if err2 == nil { if err2 == nil {
t.Fatalf("An error is expected when body is empty") t.Fatalf("An error is expected when body is empty")
} }
@ -80,7 +80,7 @@ func TestOVirtCloudXmlParsing(t *testing.T) {
</vms> </vms>
`) `)
instances3, err3 := getInstancesFromXml(body3) instances3, err3 := getInstancesFromXML(body3)
if err3 != nil { if err3 != nil {
t.Fatalf("Unexpected error listing instances: %s", err3) t.Fatalf("Unexpected error listing instances: %s", err3)
} }
@ -111,7 +111,7 @@ func TestOVirtCloudXmlParsing(t *testing.T) {
</vms> </vms>
`) `)
instances4, err4 := getInstancesFromXml(body4) instances4, err4 := getInstancesFromXML(body4)
if err4 != nil { if err4 != nil {
t.Fatalf("Unexpected error listing instances: %s", err4) t.Fatalf("Unexpected error listing instances: %s", err4)
} }