package godo import ( "encoding/json" "fmt" "net/http" "reflect" "testing" ) func TestDroplets_ListDroplets(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"droplets": [{"id":1},{"id":2}]}`) }) droplets, _, err := client.Droplets.List(nil) if err != nil { t.Errorf("Droplets.List returned error: %v", err) } expected := []Droplet{{ID: 1}, {ID: 2}} if !reflect.DeepEqual(droplets, expected) { t.Errorf("Droplets.List returned %+v, expected %+v", droplets, expected) } } func TestDroplets_ListDropletsMultiplePages(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") dr := dropletsRoot{ Droplets: []Droplet{ {ID: 1}, {ID: 2}, }, Links: &Links{ Pages: &Pages{Next: "http://example.com/v2/droplets/?page=2"}, }, } b, err := json.Marshal(dr) if err != nil { t.Fatal(err) } fmt.Fprint(w, string(b)) }) _, resp, err := client.Droplets.List(nil) if err != nil { t.Fatal(err) } checkCurrentPage(t, resp, 1) } func TestDroplets_RetrievePageByNumber(t *testing.T) { setup() defer teardown() jBlob := ` { "droplets": [{"id":1},{"id":2}], "links":{ "pages":{ "next":"http://example.com/v2/droplets/?page=3", "prev":"http://example.com/v2/droplets/?page=1", "last":"http://example.com/v2/droplets/?page=3", "first":"http://example.com/v2/droplets/?page=1" } } }` mux.HandleFunc("/v2/droplets", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, jBlob) }) opt := &ListOptions{Page: 2} _, resp, err := client.Droplets.List(opt) if err != nil { t.Fatal(err) } checkCurrentPage(t, resp, 2) } func TestDroplets_GetDroplet(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"droplet":{"id":12345}}`) }) droplets, _, err := client.Droplets.Get(12345) if err != nil { t.Errorf("Droplet.Get returned error: %v", err) } expected := &Droplet{ID: 12345} if !reflect.DeepEqual(droplets, expected) { t.Errorf("Droplets.Get returned %+v, expected %+v", droplets, expected) } } func TestDroplets_Create(t *testing.T) { setup() defer teardown() createRequest := &DropletCreateRequest{ Name: "name", Region: "region", Size: "size", Image: DropletCreateImage{ ID: 1, }, } mux.HandleFunc("/v2/droplets", func(w http.ResponseWriter, r *http.Request) { expected := map[string]interface{}{ "name": "name", "region": "region", "size": "size", "image": float64(1), "ssh_keys": nil, "backups": false, "ipv6": false, "private_networking": false, } var v map[string]interface{} err := json.NewDecoder(r.Body).Decode(&v) if err != nil { t.Fatalf("decode json: %v", err) } if !reflect.DeepEqual(v, expected) { t.Errorf("Request body = %#v, expected %#v", v, expected) } fmt.Fprintf(w, `{"droplet":{"id":1}, "links":{"actions": [{"id": 1, "href": "http://example.com", "rel": "create"}]}}`) }) droplet, resp, err := client.Droplets.Create(createRequest) if err != nil { t.Errorf("Droplets.Create returned error: %v", err) } if id := droplet.ID; id != 1 { t.Errorf("expected id '%d', received '%d'", 1, id) } if a := resp.Links.Actions[0]; a.ID != 1 { t.Errorf("expected action id '%d', received '%d'", 1, a.ID) } } func TestDroplets_Destroy(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "DELETE") }) _, err := client.Droplets.Delete(12345) if err != nil { t.Errorf("Droplet.Delete returned error: %v", err) } } func TestDroplets_Kernels(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345/kernels", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"kernels": [{"id":1},{"id":2}]}`) }) opt := &ListOptions{Page: 2} kernels, _, err := client.Droplets.Kernels(12345, opt) if err != nil { t.Errorf("Droplets.Kernels returned error: %v", err) } expected := []Kernel{{ID: 1}, {ID: 2}} if !reflect.DeepEqual(kernels, expected) { t.Errorf("Droplets.Kernels returned %+v, expected %+v", kernels, expected) } } func TestDroplets_Snapshots(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345/snapshots", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"snapshots": [{"id":1},{"id":2}]}`) }) opt := &ListOptions{Page: 2} snapshots, _, err := client.Droplets.Snapshots(12345, opt) if err != nil { t.Errorf("Droplets.Snapshots returned error: %v", err) } expected := []Image{{ID: 1}, {ID: 2}} if !reflect.DeepEqual(snapshots, expected) { t.Errorf("Droplets.Snapshots returned %+v, expected %+v", snapshots, expected) } } func TestDroplets_Backups(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345/backups", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"backups": [{"id":1},{"id":2}]}`) }) opt := &ListOptions{Page: 2} backups, _, err := client.Droplets.Backups(12345, opt) if err != nil { t.Errorf("Droplets.Backups returned error: %v", err) } expected := []Image{{ID: 1}, {ID: 2}} if !reflect.DeepEqual(backups, expected) { t.Errorf("Droplets.Backups returned %+v, expected %+v", backups, expected) } } func TestDroplets_Actions(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345/actions", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"actions": [{"id":1},{"id":2}]}`) }) opt := &ListOptions{Page: 2} actions, _, err := client.Droplets.Actions(12345, opt) if err != nil { t.Errorf("Droplets.Actions returned error: %v", err) } expected := []Action{{ID: 1}, {ID: 2}} if !reflect.DeepEqual(actions, expected) { t.Errorf("Droplets.Actions returned %+v, expected %+v", actions, expected) } } func TestDroplets_Neighbors(t *testing.T) { setup() defer teardown() mux.HandleFunc("/v2/droplets/12345/neighbors", func(w http.ResponseWriter, r *http.Request) { testMethod(t, r, "GET") fmt.Fprint(w, `{"droplets": [{"id":1},{"id":2}]}`) }) neighbors, _, err := client.Droplets.Neighbors(12345) if err != nil { t.Errorf("Droplets.Neighbors returned error: %v", err) } expected := []Droplet{{ID: 1}, {ID: 2}} if !reflect.DeepEqual(neighbors, expected) { t.Errorf("Droplets.Neighbors returned %+v, expected %+v", neighbors, expected) } } func TestNetworkV4_String(t *testing.T) { network := &NetworkV4{ IPAddress: "192.168.1.2", Netmask: "255.255.255.0", Gateway: "192.168.1.1", } stringified := network.String() expected := `godo.NetworkV4{IPAddress:"192.168.1.2", Netmask:"255.255.255.0", Gateway:"192.168.1.1", Type:""}` if expected != stringified { t.Errorf("NetworkV4.String returned %+v, expected %+v", stringified, expected) } } func TestNetworkV6_String(t *testing.T) { network := &NetworkV6{ IPAddress: "2604:A880:0800:0010:0000:0000:02DD:4001", Netmask: 64, Gateway: "2604:A880:0800:0010:0000:0000:0000:0001", } stringified := network.String() expected := `godo.NetworkV6{IPAddress:"2604:A880:0800:0010:0000:0000:02DD:4001", Netmask:64, Gateway:"2604:A880:0800:0010:0000:0000:0000:0001", Type:""}` if expected != stringified { t.Errorf("NetworkV6.String returned %+v, expected %+v", stringified, expected) } } func TestDroplet_String(t *testing.T) { region := &Region{ Slug: "region", Name: "Region", Sizes: []string{"1", "2"}, Available: true, } image := &Image{ ID: 1, Name: "Image", Type: "snapshot", Distribution: "Ubuntu", Slug: "image", Public: true, Regions: []string{"one", "two"}, MinDiskSize: 20, } size := &Size{ Slug: "size", PriceMonthly: 123, PriceHourly: 456, Regions: []string{"1", "2"}, } network := &NetworkV4{ IPAddress: "192.168.1.2", Netmask: "255.255.255.0", Gateway: "192.168.1.1", } networks := &Networks{ V4: []NetworkV4{*network}, } droplet := &Droplet{ ID: 1, Name: "droplet", Memory: 123, Vcpus: 456, Disk: 789, Region: region, Image: image, Size: size, BackupIDs: []int{1}, SnapshotIDs: []int{1}, ActionIDs: []int{1}, Locked: false, Status: "active", Networks: networks, SizeSlug: "1gb", } stringified := droplet.String() expected := `godo.Droplet{ID:1, Name:"droplet", Memory:123, Vcpus:456, Disk:789, Region:godo.Region{Slug:"region", Name:"Region", Sizes:["1" "2"], Available:true}, Image:godo.Image{ID:1, Name:"Image", Type:"snapshot", Distribution:"Ubuntu", Slug:"image", Public:true, Regions:["one" "two"], MinDiskSize:20}, Size:godo.Size{Slug:"size", Memory:0, Vcpus:0, Disk:0, PriceMonthly:123, PriceHourly:456, Regions:["1" "2"], Available:false, Transfer:0}, SizeSlug:"1gb", BackupIDs:[1], SnapshotIDs:[1], Locked:false, Status:"active", Networks:godo.Networks{V4:[godo.NetworkV4{IPAddress:"192.168.1.2", Netmask:"255.255.255.0", Gateway:"192.168.1.1", Type:""}]}, ActionIDs:[1], Created:""}` if expected != stringified { t.Errorf("Droplet.String returned %+v, expected %+v", stringified, expected) } }