updated ezconf
This commit is contained in:
@@ -360,3 +360,46 @@ func TestPrintEnvVarsStdout_NoEnvVars(t *testing.T) {
|
||||
t.Error("expected error when no env vars are loaded")
|
||||
}
|
||||
}
|
||||
|
||||
func TestPrintEnvVars_AfterParseEnvVars(t *testing.T) {
|
||||
loader := New()
|
||||
|
||||
// Add some env vars manually to simulate ParseEnvVars
|
||||
loader.envVars = []EnvVar{
|
||||
{
|
||||
Name: "LOG_LEVEL",
|
||||
Description: "Log level for the application",
|
||||
Required: false,
|
||||
Default: "info",
|
||||
CurrentValue: "",
|
||||
},
|
||||
{
|
||||
Name: "DATABASE_URL",
|
||||
Description: "Database connection string",
|
||||
Required: true,
|
||||
Default: "",
|
||||
CurrentValue: "",
|
||||
},
|
||||
}
|
||||
|
||||
// Test that PrintEnvVars works after ParseEnvVars (without Load)
|
||||
buf := &bytes.Buffer{}
|
||||
err := loader.PrintEnvVars(buf, false)
|
||||
if err != nil {
|
||||
t.Fatalf("PrintEnvVars failed: %v", err)
|
||||
}
|
||||
|
||||
output := buf.String()
|
||||
if !strings.Contains(output, "LOG_LEVEL") {
|
||||
t.Error("output should contain LOG_LEVEL")
|
||||
}
|
||||
if !strings.Contains(output, "DATABASE_URL") {
|
||||
t.Error("output should contain DATABASE_URL")
|
||||
}
|
||||
if !strings.Contains(output, "(required)") {
|
||||
t.Error("output should indicate required variables")
|
||||
}
|
||||
if !strings.Contains(output, "(default: info)") {
|
||||
t.Error("output should contain default value")
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user