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 97 98 99 100 101 102 103
|
//go:build acceptance
// +build acceptance
package v2
import (
"testing"
"github.com/gophercloud/gophercloud/acceptance/clients"
"github.com/gophercloud/gophercloud/acceptance/tools"
th "github.com/gophercloud/gophercloud/testhelper"
)
func TestShareAccessRulesGet(t *testing.T) {
client, err := clients.NewSharedFileSystemV2Client()
if err != nil {
t.Fatalf("Unable to create a shared file system client: %v", err)
}
client.Microversion = "2.49"
share, err := CreateShare(t, client)
if err != nil {
t.Fatalf("Unable to create a share: %v", err)
}
defer DeleteShare(t, client, share)
addedAccessRight, err := GrantAccess(t, client, share)
if err != nil {
t.Fatalf("Unable to grant access to share %s: %v", share.ID, err)
}
addedShareAccess := AccessRightToShareAccess(addedAccessRight)
accessRule, err := ShareAccessRuleGet(t, client, addedShareAccess.ID)
if err != nil {
t.Fatalf("Unable to get share access rule for share %s: %v", share.ID, err)
}
if err = WaitForShareAccessRule(t, client, accessRule, "active"); err != nil {
t.Fatalf("Unable to wait for share access rule to achieve 'active' state: %v", err)
}
tools.PrintResource(t, accessRule)
th.AssertEquals(t, addedShareAccess.ID, accessRule.ID)
th.AssertEquals(t, addedShareAccess.AccessType, accessRule.AccessType)
th.AssertEquals(t, addedShareAccess.AccessLevel, accessRule.AccessLevel)
th.AssertEquals(t, addedShareAccess.AccessTo, accessRule.AccessTo)
th.AssertEquals(t, addedShareAccess.AccessKey, accessRule.AccessKey)
th.AssertEquals(t, share.ID, accessRule.ShareID)
th.AssertEquals(t, "active", accessRule.State)
}
func TestShareAccessRulesList(t *testing.T) {
client, err := clients.NewSharedFileSystemV2Client()
if err != nil {
t.Fatalf("Unable to create a shared file system client: %v", err)
}
client.Microversion = "2.49"
share, err := CreateShare(t, client)
if err != nil {
t.Fatalf("Unable to create a share: %v", err)
}
defer DeleteShare(t, client, share)
addedAccessRight, err := GrantAccess(t, client, share)
if err != nil {
t.Fatalf("Unable to grant access to share %s: %v", share.ID, err)
}
addedShareAccess := AccessRightToShareAccess(addedAccessRight)
if err = WaitForShareAccessRule(t, client, addedShareAccess, "active"); err != nil {
t.Fatalf("Unable to wait for share access rule to achieve 'active' state: %v", err)
}
accessRules, err := ShareAccessRuleList(t, client, share.ID)
if err != nil {
t.Logf("Unable to list share access rules for share %s: %v", share.ID, err)
}
tools.PrintResource(t, accessRules)
th.AssertEquals(t, 1, len(accessRules))
accessRule := accessRules[0]
if err = WaitForShareAccessRule(t, client, &accessRule, "active"); err != nil {
t.Fatalf("Unable to wait for share access rule to achieve 'active' state: %v", err)
}
th.AssertEquals(t, addedShareAccess.ID, accessRule.ID)
th.AssertEquals(t, addedShareAccess.AccessType, accessRule.AccessType)
th.AssertEquals(t, addedShareAccess.AccessLevel, accessRule.AccessLevel)
th.AssertEquals(t, addedShareAccess.AccessTo, accessRule.AccessTo)
th.AssertEquals(t, addedShareAccess.AccessKey, accessRule.AccessKey)
th.AssertEquals(t, addedShareAccess.State, accessRule.State)
}
|