blob: c2f7e51e93557d7bf5a65715dd5299b5344c2d4a [file] [log] [blame]
// +build acceptance identity
package v2
import (
"testing"
tokens2 "github.com/gophercloud/gophercloud/openstack/identity/v2/tokens"
th "github.com/gophercloud/gophercloud/testhelper"
)
func TestAuthenticateAndValidate(t *testing.T) {
// 1. TestAuthenticate
ao := v2AuthOptions(t)
service := unauthenticatedClient(t)
// Authenticated!
result := tokens2.Create(service, tokens2.WrapOptions(ao))
// Extract and print the token.
token, err := result.ExtractToken()
th.AssertNoErr(t, err)
t.Logf("Acquired token: [%s]", token.ID)
t.Logf("The token will expire at: [%s]", token.ExpiresAt.String())
t.Logf("The token is valid for tenant: [%#v]", token.Tenant)
// Extract and print the service catalog.
catalog, err := result.ExtractServiceCatalog()
th.AssertNoErr(t, err)
t.Logf("Acquired service catalog listing [%d] services", len(catalog.Entries))
for i, entry := range catalog.Entries {
t.Logf("[%02d]: name=[%s], type=[%s]", i, entry.Name, entry.Type)
for _, endpoint := range entry.Endpoints {
t.Logf(" - region=[%s] publicURL=[%s]", endpoint.Region, endpoint.PublicURL)
}
}
// 2. TestValidate
client := authenticatedClient(t)
// Validate Token!
getResult := tokens2.Get(client, token.ID)
// Extract and print the user.
user, err := getResult.ExtractUser()
th.AssertNoErr(t, err)
t.Logf("Acquired User: [%s]", user.Name)
t.Logf("The User id: [%s]", user.ID)
t.Logf("The User username: [%s]", user.UserName)
t.Logf("The User roles: [%#v]", user.Roles)
}