blob: 5589b1b2214e1c9f9445567075f59ef57574c6ce [file] [log] [blame]
// +build acceptance identity roles
package v2
import (
"testing"
"github.com/gophercloud/gophercloud/acceptance/clients"
"github.com/gophercloud/gophercloud/openstack/identity/v2/extensions/admin/roles"
"github.com/gophercloud/gophercloud/openstack/identity/v2/users"
)
func TestRolesAddToUser(t *testing.T) {
client, err := clients.NewIdentityV2AdminClient()
if err != nil {
t.Fatalf("Unable to obtain an identity client: %v", err)
}
tenant, err := FindTenant(t, client)
if err != nil {
t.Fatalf("Unable to get a tenant: %v", err)
}
role, err := FindRole(t, client)
if err != nil {
t.Fatalf("Unable to get a role: %v", err)
}
user, err := CreateUser(t, client, tenant)
if err != nil {
t.Fatalf("Unable to create a user: %v", err)
}
defer DeleteUser(t, client, user)
err = AddUserRole(t, client, tenant, user, role)
if err != nil {
t.Fatalf("Unable to add role to user: %v", err)
}
defer DeleteUserRole(t, client, tenant, user, role)
allPages, err := users.ListRoles(client, tenant.ID, user.ID).AllPages()
if err != nil {
t.Fatalf("Unable to obtain roles for user: %v", err)
}
allRoles, err := users.ExtractRoles(allPages)
if err != nil {
t.Fatalf("Unable to extract roles: %v", err)
}
t.Logf("Roles of user %s:", user.Name)
for _, role := range allRoles {
PrintUserRole(t, &role)
}
}
func TestRolesList(t *testing.T) {
client, err := clients.NewIdentityV2AdminClient()
if err != nil {
t.Fatalf("Unable to create an identity client: %v", err)
}
allPages, err := roles.List(client).AllPages()
if err != nil {
t.Fatalf("Unable to list all roles: %v", err)
}
allRoles, err := roles.ExtractRoles(allPages)
if err != nil {
t.Fatalf("Unable to extract roles: %v", err)
}
for _, r := range allRoles {
PrintRole(t, &r)
}
}