// Copyright 2015 CoreOS, Inc. // // 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 digitalocean import ( "fmt" "net" "reflect" "testing" "github.com/rancher/os/config/cloudinit/datasource" "github.com/rancher/os/config/cloudinit/datasource/metadata" "github.com/rancher/os/config/cloudinit/datasource/metadata/test" "github.com/rancher/os/config/cloudinit/pkg" "github.com/rancher/os/pkg/netconf" ) func TestType(t *testing.T) { want := "digitalocean-metadata-service" if kind := (MetadataService{}).Type(); kind != want { t.Fatalf("bad type: want %q, got %q", want, kind) } } func TestFetchMetadata(t *testing.T) { for _, tt := range []struct { root string metadataPath string resources map[string]string expect datasource.Metadata clientErr error expectErr error }{ { root: "/", metadataPath: "v1.json", resources: map[string]string{ "/v1.json": "bad", }, expectErr: fmt.Errorf("invalid character 'b' looking for beginning of value"), }, { root: "/", metadataPath: "v1.json", resources: map[string]string{ "/v1.json": `{ "droplet_id": 1, "user_data": "hello", "vendor_data": "hello", "public_keys": [ "publickey1", "publickey2" ], "region": "nyc2", "interfaces": { "public": [ { "ipv4": { "ip_address": "192.168.1.2", "netmask": "255.255.255.0", "gateway": "192.168.1.1" }, "ipv6": { "ip_address": "fe00::", "cidr": 126, "gateway": "fe00::" }, "mac": "ab:cd:ef:gh:ij", "type": "public" } ] } }`, }, expect: datasource.Metadata{ PublicIPv4: net.ParseIP("192.168.1.2"), PublicIPv6: net.ParseIP("fe00::"), SSHPublicKeys: map[string]string{ "0": "publickey1", "1": "publickey2", }, NetworkConfig: netconf.NetworkConfig{ Interfaces: map[string]netconf.InterfaceConfig{ "eth0": netconf.InterfaceConfig{ Addresses: []string{ "192.168.1.2/24", "fe00::/126", }, //Netmask: "255.255.255.0", Gateway: "192.168.1.1", //Cidr: 126, GatewayIpv6: "fe00::", //MAC: "ab:cd:ef:gh:ij", //Type: "public", }, }, //PublicKeys: []string{"publickey1", "publickey2"}, }, }, }, { clientErr: pkg.ErrTimeout{Err: fmt.Errorf("test error")}, expectErr: pkg.ErrTimeout{Err: fmt.Errorf("test error")}, }, } { service := &MetadataService{ Service: metadata.Service{ Root: tt.root, Client: &test.HTTPClient{Resources: tt.resources, Err: tt.clientErr}, MetadataPath: tt.metadataPath, }, } metadata, err := service.FetchMetadata() if Error(err) != Error(tt.expectErr) { t.Fatalf("bad error (%q): \nwant %#v,\n got %#v", tt.resources, tt.expectErr, err) } if !reflect.DeepEqual(tt.expect, metadata) { t.Fatalf("bad fetch (%q): \nwant %#v,\n got %#v", tt.resources, tt.expect, metadata) } } } func Error(err error) string { if err != nil { return err.Error() } return "" }