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
|
//go:build acceptance || clustering || policies
// +build acceptance clustering policies
package v1
import (
"testing"
"github.com/gophercloud/gophercloud/acceptance/clients"
"github.com/gophercloud/gophercloud/acceptance/tools"
"github.com/gophercloud/gophercloud/openstack/clustering/v1/receivers"
th "github.com/gophercloud/gophercloud/testhelper"
)
func TestReceiversCRUD(t *testing.T) {
client, err := clients.NewClusteringV1Client()
th.AssertNoErr(t, err)
profile, err := CreateProfile(t, client)
th.AssertNoErr(t, err)
defer DeleteProfile(t, client, profile.ID)
cluster, err := CreateCluster(t, client, profile.ID)
th.AssertNoErr(t, err)
defer DeleteCluster(t, client, cluster.ID)
receiver, err := CreateWebhookReceiver(t, client, cluster.ID)
th.AssertNoErr(t, err)
defer DeleteReceiver(t, client, receiver.ID)
// Test listing receivers
allPages, err := receivers.List(client, nil).AllPages()
th.AssertNoErr(t, err)
allReceivers, err := receivers.ExtractReceivers(allPages)
th.AssertNoErr(t, err)
var found bool
for _, v := range allReceivers {
if v.ID == receiver.ID {
found = true
}
}
th.AssertEquals(t, found, true)
// Test updating receivers
newName := receiver.Name + "-UPDATED"
updateOpts := receivers.UpdateOpts{
Name: newName,
}
receiver, err = receivers.Update(client, receiver.ID, updateOpts).Extract()
th.AssertNoErr(t, err)
tools.PrintResource(t, receiver)
tools.PrintResource(t, receiver.UpdatedAt)
th.AssertEquals(t, receiver.Name, newName)
}
func TestReceiversNotify(t *testing.T) {
t.Parallel()
client, err := clients.NewClusteringV1Client()
th.AssertNoErr(t, err)
profile, err := CreateProfile(t, client)
th.AssertNoErr(t, err)
defer DeleteProfile(t, client, profile.ID)
cluster, err := CreateCluster(t, client, profile.ID)
th.AssertNoErr(t, err)
defer DeleteCluster(t, client, cluster.ID)
receiver, err := CreateMessageReceiver(t, client, cluster.ID)
th.AssertNoErr(t, err)
defer DeleteReceiver(t, client, receiver.ID)
t.Logf("Created Mesage Receiver Name:[%s] Message Receiver ID:[%s]", receiver.Name, receiver.ID)
requestID, err := receivers.Notify(client, receiver.ID).Extract()
th.AssertNoErr(t, err)
t.Logf("Receiver Notify Service Request ID: %s", requestID)
}
|