37 lines
1.4 KiB
Go
37 lines
1.4 KiB
Go
package authorization
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestShouldMatchACLWithSingleDomain(t *testing.T) {
|
|
assert.True(t, isDomainMatching("example.com", []string{"example.com"}))
|
|
|
|
assert.True(t, isDomainMatching("abc.example.com", []string{"*.example.com"}))
|
|
assert.True(t, isDomainMatching("abc.def.example.com", []string{"*.example.com"}))
|
|
}
|
|
|
|
func TestShouldNotMatchACLWithSingleDomain(t *testing.T) {
|
|
assert.False(t, isDomainMatching("example.com", []string{"*.example.com"}))
|
|
// Character * must be followed by . to be valid.
|
|
assert.False(t, isDomainMatching("example.com", []string{"*example.com"}))
|
|
|
|
assert.False(t, isDomainMatching("example.com", []string{"*.exampl.com"}))
|
|
|
|
assert.False(t, isDomainMatching("example.com", []string{"*.other.net"}))
|
|
assert.False(t, isDomainMatching("example.com", []string{"*other.net"}))
|
|
assert.False(t, isDomainMatching("example.com", []string{"other.net"}))
|
|
}
|
|
|
|
func TestShouldMatchACLWithMultipleDomains(t *testing.T) {
|
|
assert.True(t, isDomainMatching("example.com", []string{"*.example.com", "example.com"}))
|
|
assert.True(t, isDomainMatching("apple.example.com", []string{"*.example.com", "example.com"}))
|
|
}
|
|
|
|
func TestShouldNotMatchACLWithMultipleDomains(t *testing.T) {
|
|
assert.False(t, isDomainMatching("example.com", []string{"*.example.com", "*example.com"}))
|
|
assert.False(t, isDomainMatching("apple.example.com", []string{"*example.com", "example.com"}))
|
|
}
|