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 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
|
package noauth
import (
"testing"
"github.com/gophercloud/gophercloud/acceptance/clients"
v1 "github.com/gophercloud/gophercloud/acceptance/openstack/baremetal/v1"
"github.com/gophercloud/gophercloud/openstack/baremetal/v1/nodes"
"github.com/gophercloud/gophercloud/pagination"
th "github.com/gophercloud/gophercloud/testhelper"
)
func TestNodesCreateDestroy(t *testing.T) {
clients.RequireLong(t)
client, err := clients.NewBareMetalV1NoAuthClient()
th.AssertNoErr(t, err)
client.Microversion = "1.50"
node, err := v1.CreateNode(t, client)
th.AssertNoErr(t, err)
defer v1.DeleteNode(t, client, node)
found := false
err = nodes.List(client, nodes.ListOpts{}).EachPage(func(page pagination.Page) (bool, error) {
nodeList, err := nodes.ExtractNodes(page)
if err != nil {
return false, err
}
for _, n := range nodeList {
if n.UUID == node.UUID {
found = true
return true, nil
}
}
return false, nil
})
th.AssertNoErr(t, err)
th.AssertEquals(t, found, true)
}
func TestNodesUpdate(t *testing.T) {
clients.RequireLong(t)
client, err := clients.NewBareMetalV1NoAuthClient()
th.AssertNoErr(t, err)
client.Microversion = "1.50"
node, err := v1.CreateNode(t, client)
th.AssertNoErr(t, err)
defer v1.DeleteNode(t, client, node)
updated, err := nodes.Update(client, node.UUID, nodes.UpdateOpts{
nodes.UpdateOperation{
Op: nodes.ReplaceOp,
Path: "/maintenance",
Value: "true",
},
}).Extract()
th.AssertNoErr(t, err)
th.AssertEquals(t, updated.Maintenance, true)
}
func TestNodesRAIDConfig(t *testing.T) {
clients.SkipReleasesBelow(t, "stable/ussuri")
clients.RequireLong(t)
client, err := clients.NewBareMetalV1NoAuthClient()
th.AssertNoErr(t, err)
client.Microversion = "1.50"
node, err := v1.CreateNode(t, client)
th.AssertNoErr(t, err)
defer v1.DeleteNode(t, client, node)
sizeGB := 100
isTrue := true
err = nodes.SetRAIDConfig(client, node.UUID, nodes.RAIDConfigOpts{
LogicalDisks: []nodes.LogicalDisk{
{
SizeGB: &sizeGB,
IsRootVolume: &isTrue,
RAIDLevel: nodes.RAID5,
DiskType: nodes.HDD,
NumberOfPhysicalDisks: 5,
},
},
}).ExtractErr()
th.AssertNoErr(t, err)
}
|