1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
//go:build acceptance || blockstorage
// +build acceptance blockstorage
package extensions
import (
"testing"
"github.com/gophercloud/gophercloud/acceptance/clients"
blockstorage "github.com/gophercloud/gophercloud/acceptance/openstack/blockstorage/v3"
"github.com/gophercloud/gophercloud/openstack/blockstorage/extensions/volumetenants"
"github.com/gophercloud/gophercloud/openstack/blockstorage/v3/volumes"
th "github.com/gophercloud/gophercloud/testhelper"
)
func TestVolumeTenants(t *testing.T) {
type volumeWithTenant struct {
volumes.Volume
volumetenants.VolumeTenantExt
}
var allVolumes []volumeWithTenant
client, err := clients.NewBlockStorageV3Client()
th.AssertNoErr(t, err)
listOpts := volumes.ListOpts{
Name: "I SHOULD NOT EXIST",
}
allPages, err := volumes.List(client, listOpts).AllPages()
th.AssertNoErr(t, err)
err = volumes.ExtractVolumesInto(allPages, &allVolumes)
th.AssertNoErr(t, err)
th.AssertEquals(t, 0, len(allVolumes))
volume1, err := blockstorage.CreateVolume(t, client)
th.AssertNoErr(t, err)
defer blockstorage.DeleteVolume(t, client, volume1)
allPages, err = volumes.List(client, nil).AllPages()
th.AssertNoErr(t, err)
err = volumes.ExtractVolumesInto(allPages, &allVolumes)
th.AssertNoErr(t, err)
th.AssertEquals(t, true, len(allVolumes) > 0)
}
|