160 lines
4.6 KiB
Go
160 lines
4.6 KiB
Go
package common
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestNewMapFlag(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
defaultValue map[string]string
|
|
expected map[string]string
|
|
}{
|
|
{
|
|
name: "default empty",
|
|
defaultValue: map[string]string{},
|
|
expected: map[string]string{},
|
|
},
|
|
{
|
|
name: "default with values",
|
|
defaultValue: map[string]string{"key1": "value1", "key2": "value2"},
|
|
expected: map[string]string{"key1": "value1", "key2": "value2"},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
flag := NewMapFlag(tt.defaultValue)
|
|
|
|
// Check initial state
|
|
assert.Equal(t, tt.expected, flag.Value(), "Value should match default")
|
|
assert.False(t, flag.WasExplicitlySet(), "New flag should not be marked as explicitly set")
|
|
|
|
// Ensure the default value is copied, not referenced
|
|
if len(tt.defaultValue) > 0 {
|
|
original := make(map[string]string)
|
|
for k, v := range tt.defaultValue {
|
|
original[k] = v
|
|
}
|
|
|
|
// Modify the original
|
|
for k := range tt.defaultValue {
|
|
tt.defaultValue[k] = "modified"
|
|
break
|
|
}
|
|
|
|
// Flag value should remain unchanged
|
|
assert.Equal(t, original, flag.Value(), "Flag value should be a copy, not a reference")
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestMapFlag_ValueImmutability(t *testing.T) {
|
|
// Test that modifying the returned value doesn't affect the internal state
|
|
flag := NewMapFlag(map[string]string{"key1": "value1", "key2": "value2"})
|
|
|
|
// Get the value and modify it
|
|
value := flag.Value()
|
|
value["key1"] = "modified"
|
|
|
|
// Check that the flag's internal state is unchanged
|
|
expected := map[string]string{"key1": "value1", "key2": "value2"}
|
|
assert.Equal(t, expected, flag.Value(), "Modifying the returned value should not affect the flag's internal state")
|
|
}
|
|
|
|
func TestMapFlag_Set(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
defaultValue map[string]string
|
|
setValue map[string]string
|
|
expected map[string]string
|
|
}{
|
|
{
|
|
name: "default empty, set values",
|
|
defaultValue: map[string]string{},
|
|
setValue: map[string]string{"key1": "value1", "key2": "value2"},
|
|
expected: map[string]string{"key1": "value1", "key2": "value2"},
|
|
},
|
|
{
|
|
name: "default with values, set new values",
|
|
defaultValue: map[string]string{"key1": "value1", "key2": "value2"},
|
|
setValue: map[string]string{"key3": "value3", "key4": "value4"},
|
|
expected: map[string]string{"key3": "value3", "key4": "value4"},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
flag := NewMapFlag(tt.defaultValue)
|
|
|
|
// Set the value
|
|
flag.Set(tt.setValue)
|
|
|
|
// Check state after setting
|
|
assert.Equal(t, tt.expected, flag.Value(), "Value should match set value")
|
|
assert.True(t, flag.WasExplicitlySet(), "Flag should be marked as explicitly set")
|
|
|
|
// Ensure the set value is copied, not referenced
|
|
if len(tt.setValue) > 0 {
|
|
original := make(map[string]string)
|
|
for k, v := range tt.setValue {
|
|
original[k] = v
|
|
}
|
|
|
|
// Modify the original
|
|
for k := range tt.setValue {
|
|
tt.setValue[k] = "modified"
|
|
break
|
|
}
|
|
|
|
// Flag value should remain unchanged
|
|
assert.Equal(t, original, flag.Value(), "Flag value should be a copy, not a reference")
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestMapFlag_SetKey(t *testing.T) {
|
|
flag := NewMapFlag(map[string]string{"existing": "value"})
|
|
|
|
// Initial state
|
|
assert.Equal(t, map[string]string{"existing": "value"}, flag.Value())
|
|
assert.False(t, flag.WasExplicitlySet())
|
|
|
|
// Set a new key
|
|
flag.SetKey("new", "value")
|
|
assert.Equal(t, map[string]string{"existing": "value", "new": "value"}, flag.Value())
|
|
assert.True(t, flag.WasExplicitlySet())
|
|
|
|
// Override an existing key
|
|
flag.SetKey("existing", "updated")
|
|
assert.Equal(t, map[string]string{"existing": "updated", "new": "value"}, flag.Value())
|
|
assert.True(t, flag.WasExplicitlySet())
|
|
}
|
|
|
|
func TestMapFlag_MultipleSet(t *testing.T) {
|
|
flag := NewMapFlag(map[string]string{"initial": "value"})
|
|
|
|
// Initial state
|
|
assert.Equal(t, map[string]string{"initial": "value"}, flag.Value())
|
|
assert.False(t, flag.WasExplicitlySet())
|
|
|
|
// First set
|
|
flag.Set(map[string]string{"first": "set"})
|
|
assert.Equal(t, map[string]string{"first": "set"}, flag.Value())
|
|
assert.True(t, flag.WasExplicitlySet())
|
|
|
|
// Second set
|
|
flag.Set(map[string]string{"second": "set"})
|
|
assert.Equal(t, map[string]string{"second": "set"}, flag.Value())
|
|
assert.True(t, flag.WasExplicitlySet(), "Flag should remain explicitly set")
|
|
}
|
|
|
|
func TestMapFlag_Implementation(t *testing.T) {
|
|
// Test that mapFlag properly implements MapFlag interface
|
|
var _ MapFlag = &mapFlag{}
|
|
}
|