forked from baron/baron-sso
slug 명칭 한글 수정
This commit is contained in:
@@ -54,3 +54,62 @@ func TestValidateSlug_Format(t *testing.T) {
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestGenerateSlug(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
expected string
|
||||
}{
|
||||
{"Hello World", "hello-world"},
|
||||
{"My Company!@#", "my-company"},
|
||||
{"---Test---", "test"},
|
||||
{" Spaces ", "spaces"},
|
||||
{"A VERY LONG NAME THAT EXCEEDS THIRTY TWO CHARACTERS", "a-very-long-name-that-exc"},
|
||||
{"한글 테스트", "tenant"}, // Non-ascii characters will be replaced by hyphens and trimmed to empty, then fallback to "tenant"
|
||||
{"Test 한글 Mix", "test-mix"},
|
||||
{"", "tenant"},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
slug := GenerateSlug(tt.name)
|
||||
assert.Equal(t, tt.expected, slug)
|
||||
// Ensure generated slug is valid (unless it's reserved like "slug" wasn't reserved, but let's check format)
|
||||
if !reservedSlugs[slug] {
|
||||
valid, _ := ValidateSlug(slug)
|
||||
assert.True(t, valid, "Generated slug should be valid format")
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestGenerateUniqueSlug(t *testing.T) {
|
||||
existingSlugs := map[string]bool{
|
||||
"my-company": true,
|
||||
"my-company-1": true,
|
||||
"test": true,
|
||||
}
|
||||
|
||||
existsFunc := func(slug string) bool {
|
||||
return existingSlugs[slug]
|
||||
}
|
||||
|
||||
tests := []struct {
|
||||
name string
|
||||
expected string
|
||||
}{
|
||||
{"My Company", "my-company-2"},
|
||||
{"Test", "test-1"},
|
||||
{"New Company", "new-company"},
|
||||
{"admin", "admin-1"}, // "admin" is reserved, so it should append suffix
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
slug := GenerateUniqueSlug(tt.name, existsFunc)
|
||||
assert.Equal(t, tt.expected, slug)
|
||||
valid, _ := ValidateSlug(slug)
|
||||
assert.True(t, valid, "Generated unique slug should be valid")
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user