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
|
//go:build acceptance
// +build acceptance
package v3
import (
"testing"
"github.com/gophercloud/gophercloud/acceptance/clients"
"github.com/gophercloud/gophercloud/acceptance/tools"
"github.com/gophercloud/gophercloud/openstack"
"github.com/gophercloud/gophercloud/openstack/identity/v3/extensions/ec2credentials"
"github.com/gophercloud/gophercloud/openstack/identity/v3/tokens"
th "github.com/gophercloud/gophercloud/testhelper"
)
func TestEC2CredentialsCRD(t *testing.T) {
client, err := clients.NewIdentityV3Client()
th.AssertNoErr(t, err)
ao, err := openstack.AuthOptionsFromEnv()
th.AssertNoErr(t, err)
authOptions := tokens.AuthOptions{
Username: ao.Username,
Password: ao.Password,
DomainName: ao.DomainName,
DomainID: ao.DomainID,
// We need a scope to get the token roles list
Scope: tokens.Scope{
ProjectID: ao.TenantID,
ProjectName: ao.TenantName,
DomainID: ao.DomainID,
DomainName: ao.DomainName,
},
}
res := tokens.Create(client, &authOptions)
th.AssertNoErr(t, res.Err)
token, err := res.Extract()
th.AssertNoErr(t, err)
tools.PrintResource(t, token)
user, err := res.ExtractUser()
th.AssertNoErr(t, err)
tools.PrintResource(t, user)
project, err := res.ExtractProject()
th.AssertNoErr(t, err)
tools.PrintResource(t, project)
createOpts := ec2credentials.CreateOpts{
TenantID: project.ID,
}
ec2credential, err := ec2credentials.Create(client, user.ID, createOpts).Extract()
th.AssertNoErr(t, err)
defer ec2credentials.Delete(client, user.ID, ec2credential.Access)
tools.PrintResource(t, ec2credential)
access := ec2credential.Access
secret := ec2credential.Secret
if access == "" {
t.Fatalf("EC2 credential access was not generated")
}
if secret == "" {
t.Fatalf("EC2 credential secret was not generated")
}
th.AssertEquals(t, ec2credential.UserID, user.ID)
th.AssertEquals(t, ec2credential.TenantID, project.ID)
// Get an ec2 credential
getEC2Credential, err := ec2credentials.Get(client, user.ID, ec2credential.Access).Extract()
th.AssertNoErr(t, err)
tools.PrintResource(t, getEC2Credential)
th.AssertEquals(t, getEC2Credential.UserID, user.ID)
th.AssertEquals(t, getEC2Credential.TenantID, project.ID)
th.AssertEquals(t, getEC2Credential.Access, access)
th.AssertEquals(t, getEC2Credential.Secret, secret)
allPages, err := ec2credentials.List(client, user.ID).AllPages()
th.AssertNoErr(t, err)
credentials, err := ec2credentials.ExtractCredentials(allPages)
th.AssertNoErr(t, err)
if v := len(credentials); v != 1 {
t.Fatalf("expected to list one credential, got %d", v)
}
th.AssertEquals(t, credentials[0].UserID, user.ID)
th.AssertEquals(t, credentials[0].TenantID, project.ID)
th.AssertEquals(t, credentials[0].Access, access)
th.AssertEquals(t, credentials[0].Secret, secret)
}
|