| // +build acceptance rackspace objectstorage v1 |
| |
| package v1 |
| |
| import ( |
| "testing" |
| |
| osContainers "github.com/gophercloud/gophercloud/openstack/objectstorage/v1/containers" |
| "github.com/gophercloud/gophercloud/pagination" |
| raxContainers "github.com/gophercloud/gophercloud/rackspace/objectstorage/v1/containers" |
| th "github.com/gophercloud/gophercloud/testhelper" |
| ) |
| |
| func TestContainers(t *testing.T) { |
| c, err := createClient(t, false) |
| th.AssertNoErr(t, err) |
| |
| t.Logf("Containers Info available to the currently issued token:") |
| count := 0 |
| err = raxContainers.List(c, &osContainers.ListOpts{Full: true}).EachPage(func(page pagination.Page) (bool, error) { |
| t.Logf("--- Page %02d ---", count) |
| |
| containers, err := raxContainers.ExtractInfo(page) |
| th.AssertNoErr(t, err) |
| |
| for i, container := range containers { |
| t.Logf("[%02d] name=[%s]", i, container.Name) |
| t.Logf(" count=[%d]", container.Count) |
| t.Logf(" bytes=[%d]", container.Bytes) |
| } |
| |
| count++ |
| return true, nil |
| }) |
| th.AssertNoErr(t, err) |
| if count == 0 { |
| t.Errorf("No containers listed for your current token.") |
| } |
| |
| t.Logf("Container Names available to the currently issued token:") |
| count = 0 |
| err = raxContainers.List(c, &osContainers.ListOpts{Full: false}).EachPage(func(page pagination.Page) (bool, error) { |
| t.Logf("--- Page %02d ---", count) |
| |
| names, err := raxContainers.ExtractNames(page) |
| th.AssertNoErr(t, err) |
| |
| for i, name := range names { |
| t.Logf("[%02d] %s", i, name) |
| } |
| |
| count++ |
| return true, nil |
| }) |
| th.AssertNoErr(t, err) |
| if count == 0 { |
| t.Errorf("No containers listed for your current token.") |
| } |
| |
| createHeader, err := raxContainers.Create(c, "gophercloud-test", nil).Extract() |
| th.AssertNoErr(t, err) |
| t.Logf("Headers from Create Container request: %+v\n", createHeader) |
| defer func() { |
| deleteres := raxContainers.Delete(c, "gophercloud-test") |
| deleteHeader, err := deleteres.Extract() |
| th.AssertNoErr(t, err) |
| t.Logf("Headers from Delete Container request: %+v\n", deleteres.Header) |
| t.Logf("Headers from Delete Container request: %+v\n", deleteHeader) |
| }() |
| |
| updateHeader, err := raxContainers.Update(c, "gophercloud-test", raxContainers.UpdateOpts{Metadata: map[string]string{"white": "mountains"}}).Extract() |
| th.AssertNoErr(t, err) |
| t.Logf("Headers from Update Container request: %+v\n", updateHeader) |
| defer func() { |
| res := raxContainers.Update(c, "gophercloud-test", raxContainers.UpdateOpts{Metadata: map[string]string{"white": ""}}) |
| th.AssertNoErr(t, res.Err) |
| metadata, err := raxContainers.Get(c, "gophercloud-test").ExtractMetadata() |
| th.AssertNoErr(t, err) |
| t.Logf("Metadata from Get Container request (after update reverted): %+v\n", metadata) |
| th.CheckEquals(t, metadata["White"], "") |
| }() |
| |
| getres := raxContainers.Get(c, "gophercloud-test") |
| getHeader, err := getres.Extract() |
| th.AssertNoErr(t, err) |
| t.Logf("Headers from Get Container request (after update): %+v\n", getHeader) |
| metadata, err := getres.ExtractMetadata() |
| t.Logf("Metadata from Get Container request (after update): %+v\n", metadata) |
| th.CheckEquals(t, metadata["White"], "mountains") |
| } |