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"}))
}