2018-10-19 12:04:07 -04:00
|
|
|
package structs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestStructs_ACL_Convert(t *testing.T) {
|
|
|
|
|
|
|
|
acl := &ACL{
|
|
|
|
ID: "guid",
|
|
|
|
Name: "AN ACL for testing",
|
|
|
|
Type: "client",
|
|
|
|
Rules: `service "" { policy "read" }`,
|
|
|
|
}
|
|
|
|
|
|
|
|
token := acl.Convert()
|
|
|
|
require.Equal(t, "", token.AccessorID)
|
|
|
|
require.Equal(t, acl.ID, token.SecretID)
|
|
|
|
require.Equal(t, acl.Type, token.Type)
|
|
|
|
require.Equal(t, acl.Name, token.Description)
|
|
|
|
require.Nil(t, token.Policies)
|
|
|
|
require.False(t, token.Local)
|
|
|
|
require.Equal(t, acl.Rules, token.Rules)
|
|
|
|
require.Equal(t, acl.CreateIndex, token.CreateIndex)
|
|
|
|
require.Equal(t, acl.ModifyIndex, token.ModifyIndex)
|
2020-06-08 21:44:06 +02:00
|
|
|
require.NotEmpty(t, token.Hash)
|
2018-10-19 12:04:07 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestStructs_ACLToken_Convert(t *testing.T) {
|
|
|
|
|
|
|
|
t.Run("Management", func(t *testing.T) {
|
|
|
|
token := &ACLToken{
|
|
|
|
AccessorID: "6c4eb178-c7f3-4620-b899-91eb8696c265",
|
|
|
|
SecretID: "67c29ecd-cabc-42e0-a20e-771e9a1ab70c",
|
|
|
|
Description: "new token",
|
|
|
|
Policies: []ACLTokenPolicyLink{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2018-10-19 12:04:07 -04:00
|
|
|
ID: ACLPolicyGlobalManagementID,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Type: ACLTokenTypeManagement,
|
|
|
|
}
|
|
|
|
|
|
|
|
acl, err := token.Convert()
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, token.SecretID, acl.ID)
|
|
|
|
require.Equal(t, token.Type, acl.Type)
|
|
|
|
require.Equal(t, token.Description, acl.Name)
|
|
|
|
require.Equal(t, "", acl.Rules)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Client", func(t *testing.T) {
|
|
|
|
token := &ACLToken{
|
|
|
|
AccessorID: "6c4eb178-c7f3-4620-b899-91eb8696c265",
|
|
|
|
SecretID: "67c29ecd-cabc-42e0-a20e-771e9a1ab70c",
|
|
|
|
Description: "new token",
|
|
|
|
Policies: nil,
|
|
|
|
Type: ACLTokenTypeClient,
|
|
|
|
Rules: `acl = "read"`,
|
|
|
|
}
|
|
|
|
|
|
|
|
acl, err := token.Convert()
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, token.SecretID, acl.ID)
|
|
|
|
require.Equal(t, token.Type, acl.Type)
|
|
|
|
require.Equal(t, token.Description, acl.Name)
|
|
|
|
require.Equal(t, token.Rules, acl.Rules)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Unconvertible", func(t *testing.T) {
|
|
|
|
token := &ACLToken{
|
|
|
|
AccessorID: "6c4eb178-c7f3-4620-b899-91eb8696c265",
|
|
|
|
SecretID: "67c29ecd-cabc-42e0-a20e-771e9a1ab70c",
|
|
|
|
Description: "new token",
|
|
|
|
Policies: []ACLTokenPolicyLink{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2018-10-19 12:04:07 -04:00
|
|
|
ID: ACLPolicyGlobalManagementID,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
acl, err := token.Convert()
|
|
|
|
require.Error(t, err)
|
|
|
|
require.Nil(t, acl)
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|