mirror of
https://github.com/photoprism/photoprism.git
synced 2025-09-27 05:08:13 +08:00
287 lines
7.8 KiB
Go
287 lines
7.8 KiB
Go
package config
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
func TestCliFlags_Cli(t *testing.T) {
|
|
cliFlags := Flags.Cli()
|
|
standard := Flags.Find([]string{})
|
|
|
|
assert.GreaterOrEqual(t, len(cliFlags), len(standard))
|
|
}
|
|
|
|
func TestCliFlags_Find(t *testing.T) {
|
|
cliFlags := Flags.Cli()
|
|
standard := Flags.Find([]string{})
|
|
essentials := Flags.Find([]string{Essentials})
|
|
other := Flags.Find([]string{"other"})
|
|
|
|
assert.Equal(t, len(standard), len(other))
|
|
assert.GreaterOrEqual(t, len(cliFlags), len(essentials))
|
|
assert.Equal(t, len(other), len(essentials))
|
|
}
|
|
|
|
func TestCliFlags_Replace(t *testing.T) {
|
|
originalPublicFlag := CliFlag{Flag: &cli.BoolFlag{
|
|
Name: "public",
|
|
Aliases: []string{"p"},
|
|
Hidden: true,
|
|
Usage: "disables authentication, advanced settings, and WebDAV remote access",
|
|
EnvVars: EnvVars("PUBLIC"),
|
|
}}
|
|
|
|
newPublicFlag := CliFlag{Flag: &cli.BoolFlag{
|
|
Name: "public",
|
|
Hidden: false,
|
|
Usage: "disables authentication, advanced settings, and WebDAV remote access",
|
|
EnvVars: EnvVars("PUBLIC"),
|
|
}}
|
|
|
|
cliFlags := CliFlags{
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "auth-mode",
|
|
Aliases: []string{"a"},
|
|
Usage: "authentication `MODE` (public, password)",
|
|
Value: "password",
|
|
EnvVars: EnvVars("AUTH_MODE"),
|
|
}},
|
|
originalPublicFlag,
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "admin-user",
|
|
Aliases: []string{"login"},
|
|
Usage: "`USERNAME` of the superadmin account that is created on first startup",
|
|
Value: "admin",
|
|
EnvVars: EnvVars("ADMIN_USER"),
|
|
}}}
|
|
|
|
assert.Equal(t, 3, len(cliFlags))
|
|
assert.Equal(t, originalPublicFlag.String(), cliFlags[1].String())
|
|
assert.Equal(t, originalPublicFlag.Hidden(), cliFlags[1].Hidden())
|
|
|
|
t.Run("WrongName", func(t *testing.T) {
|
|
|
|
r := cliFlags.Replace("xxx", newPublicFlag)
|
|
|
|
assert.Equal(t, 3, len(r))
|
|
assert.Equal(t, "auth-mode, a", r[0].String())
|
|
assert.Equal(t, originalPublicFlag.String(), r[1].String())
|
|
assert.Equal(t, "admin-user, login", r[2].String())
|
|
})
|
|
t.Run("Success", func(t *testing.T) {
|
|
|
|
r := cliFlags.Replace("public, p", newPublicFlag)
|
|
|
|
assert.Equal(t, 3, len(r))
|
|
assert.Equal(t, newPublicFlag.String(), r[1].String())
|
|
assert.Equal(t, newPublicFlag.Hidden(), r[1].Hidden())
|
|
})
|
|
}
|
|
|
|
func TestCliFlags_Remove(t *testing.T) {
|
|
cliFlags := CliFlags{
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "auth-mode",
|
|
Aliases: []string{"a"},
|
|
Usage: "authentication `MODE` (public, password)",
|
|
Value: "password",
|
|
EnvVars: EnvVars("AUTH_MODE"),
|
|
}},
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "admin-user",
|
|
Aliases: []string{"login"},
|
|
Usage: "`USERNAME` of the superadmin account that is created on first startup",
|
|
Value: "admin",
|
|
EnvVars: EnvVars("ADMIN_USER"),
|
|
}}}
|
|
|
|
assert.Equal(t, 2, len(cliFlags))
|
|
|
|
result := cliFlags.Remove([]string{"auth-mode, a"})
|
|
|
|
assert.Equal(t, 1, len(result))
|
|
}
|
|
|
|
func TestCliFlags_Insert(t *testing.T) {
|
|
PublicFlag := CliFlag{Flag: &cli.BoolFlag{
|
|
Name: "public",
|
|
Aliases: []string{"p"},
|
|
Hidden: true,
|
|
Usage: "disables authentication, advanced settings, and WebDAV remote access",
|
|
EnvVars: EnvVars("PUBLIC"),
|
|
}}
|
|
|
|
cliFlags := CliFlags{
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "auth-mode",
|
|
Aliases: []string{"a"},
|
|
Usage: "authentication `MODE` (public, password)",
|
|
Value: "password",
|
|
EnvVars: EnvVars("AUTH_MODE"),
|
|
}},
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "admin-user",
|
|
Aliases: []string{"login"},
|
|
Usage: "`USERNAME` of the superadmin account that is created on first startup",
|
|
Value: "admin",
|
|
EnvVars: EnvVars("ADMIN_USER"),
|
|
}}}
|
|
|
|
assert.Equal(t, 2, len(cliFlags))
|
|
|
|
t.Run("Success", func(t *testing.T) {
|
|
result := cliFlags.Insert("auth-mode, a", []CliFlag{PublicFlag})
|
|
|
|
assert.Equal(t, 3, len(result))
|
|
|
|
assert.Equal(t, "auth-mode, a", result[0].String())
|
|
assert.Equal(t, PublicFlag.String(), result[1].String())
|
|
assert.Equal(t, "admin-user, login", result[2].String())
|
|
})
|
|
t.Run("WrongName", func(t *testing.T) {
|
|
result := cliFlags.Insert("xxx", []CliFlag{PublicFlag})
|
|
|
|
assert.Equal(t, 3, len(result))
|
|
|
|
assert.Equal(t, "auth-mode, a", result[0].String())
|
|
assert.Equal(t, "admin-user, login", result[1].String())
|
|
assert.Equal(t, PublicFlag.String(), result[2].String())
|
|
})
|
|
}
|
|
|
|
func TestCliFlags_InsertBefore(t *testing.T) {
|
|
PublicFlag := CliFlag{Flag: &cli.BoolFlag{
|
|
Name: "public",
|
|
Aliases: []string{"p"},
|
|
Hidden: true,
|
|
Usage: "disables authentication, advanced settings, and WebDAV remote access",
|
|
EnvVars: EnvVars("PUBLIC"),
|
|
}}
|
|
|
|
cliFlags := CliFlags{
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "auth-mode",
|
|
Aliases: []string{"a"},
|
|
Usage: "authentication `MODE` (public, password)",
|
|
Value: "password",
|
|
EnvVars: EnvVars("AUTH_MODE"),
|
|
}},
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "admin-user",
|
|
Aliases: []string{"login"},
|
|
Usage: "`USERNAME` of the superadmin account that is created on first startup",
|
|
Value: "admin",
|
|
EnvVars: EnvVars("ADMIN_USER"),
|
|
}}}
|
|
|
|
assert.Equal(t, 2, len(cliFlags))
|
|
|
|
t.Run("Success", func(t *testing.T) {
|
|
result := cliFlags.InsertBefore("auth-mode, a", []CliFlag{PublicFlag})
|
|
|
|
assert.Equal(t, 3, len(result))
|
|
|
|
assert.Equal(t, "auth-mode, a", result[1].String())
|
|
assert.Equal(t, PublicFlag.String(), result[0].String())
|
|
assert.Equal(t, "admin-user, login", result[2].String())
|
|
})
|
|
t.Run("WrongName", func(t *testing.T) {
|
|
result := cliFlags.InsertBefore("xxx", []CliFlag{PublicFlag})
|
|
|
|
assert.Equal(t, 3, len(result))
|
|
|
|
t.Logf("flags: %#v", result)
|
|
|
|
assert.Equal(t, "auth-mode, a", result[0].String())
|
|
assert.Equal(t, "admin-user, login", result[1].String())
|
|
assert.Equal(t, PublicFlag.String(), result[2].String())
|
|
})
|
|
}
|
|
|
|
func TestCliFlags_Prepend(t *testing.T) {
|
|
PublicFlag := CliFlag{Flag: &cli.BoolFlag{
|
|
Name: "public",
|
|
Aliases: []string{"p"},
|
|
Hidden: true,
|
|
Usage: "disables authentication, advanced settings, and WebDAV remote access",
|
|
EnvVars: EnvVars("PUBLIC"),
|
|
}}
|
|
|
|
cliFlags := CliFlags{
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "auth-mode",
|
|
Aliases: []string{"a"},
|
|
Usage: "authentication `MODE` (public, password)",
|
|
Value: "password",
|
|
EnvVars: EnvVars("AUTH_MODE"),
|
|
}},
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "admin-user",
|
|
Aliases: []string{"login"},
|
|
Usage: "`USERNAME` of the superadmin account that is created on first startup",
|
|
Value: "admin",
|
|
EnvVars: EnvVars("ADMIN_USER"),
|
|
}}}
|
|
|
|
assert.Equal(t, 2, len(cliFlags))
|
|
|
|
r := cliFlags.Prepend([]CliFlag{PublicFlag})
|
|
|
|
assert.Equal(t, "auth-mode, a", r[1].String())
|
|
assert.Equal(t, PublicFlag.String(), r[0].String())
|
|
assert.Equal(t, "admin-user, login", r[2].String())
|
|
}
|
|
|
|
func TestCliFlags_SetHidden(t *testing.T) {
|
|
cliFlags := CliFlags{
|
|
{
|
|
Flag: &cli.BoolFlag{
|
|
Name: "public",
|
|
Aliases: []string{"p"},
|
|
Hidden: true,
|
|
Usage: "disables authentication, advanced settings, and WebDAV remote access",
|
|
EnvVars: EnvVars("PUBLIC"),
|
|
}},
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "auth-mode",
|
|
Aliases: []string{"a"},
|
|
Usage: "authentication `MODE` (public, password)",
|
|
Value: "password",
|
|
EnvVars: EnvVars("AUTH_MODE"),
|
|
}},
|
|
{
|
|
Flag: &cli.StringFlag{
|
|
Name: "admin-user",
|
|
Aliases: []string{"login"},
|
|
Usage: "`USERNAME` of the superadmin account that is created on first startup",
|
|
Value: "admin",
|
|
EnvVars: EnvVars("ADMIN_USER"),
|
|
}}}
|
|
|
|
t.Logf("public hidden flag before: %#v", cliFlags[0].Hidden())
|
|
t.Logf("auth-mode hidden flag before: %#v", cliFlags[1].Hidden())
|
|
|
|
assert.True(t, cliFlags[0].Hidden())
|
|
assert.False(t, cliFlags[1].Hidden())
|
|
result := cliFlags.SetHidden(true, "auth-mode").SetHidden(false, "public")
|
|
assert.False(t, result[0].Hidden())
|
|
assert.True(t, cliFlags[1].Hidden())
|
|
|
|
t.Logf("public hidden flag after: %#v", result[0].Hidden())
|
|
t.Logf("auth-mode hidden flag after: %#v", cliFlags[1].Hidden())
|
|
}
|