diff --git a/agent/app/run.go b/agent/app/run.go index e6fdb37ca32..0ee12573c40 100644 --- a/agent/app/run.go +++ b/agent/app/run.go @@ -60,9 +60,11 @@ func Run(arguments []string) int { } if *parsedArgs.LogLevel != "" { - logger.SetLevel(*parsedArgs.LogLevel, *parsedArgs.LogLevel) + logger.SetDriverLogLevel(*parsedArgs.LogLevel) + logger.SetInstanceLogLevel(*parsedArgs.LogLevel) } else { - logger.SetLevel(*parsedArgs.DriverLogLevel, *parsedArgs.InstanceLogLevel) + logger.SetDriverLogLevel(*parsedArgs.DriverLogLevel) + logger.SetInstanceLogLevel(*parsedArgs.InstanceLogLevel) } // Create an Agent object diff --git a/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/logger/log.go b/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/logger/log.go index fc7025f823c..ab915149736 100644 --- a/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/logger/log.go +++ b/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/logger/log.go @@ -44,18 +44,34 @@ const ( DEFAULT_TIMESTAMP_FORMAT = time.RFC3339 DEFAULT_MAX_FILE_SIZE float64 = 10 DEFAULT_MAX_ROLL_COUNT int = 24 + DEFAULT_LOGTO_STDOUT = true ) +// Because timestamp format will be called in the custom formatter +// for each log message processed, it should not be handled +// with an explicitly write protected configuration. +var timestampFormat = DEFAULT_TIMESTAMP_FORMAT + +// logLevels is the mapping from ECS_LOGLEVEL to Seelog provided levels. +var logLevels = map[string]string{ + "debug": "debug", + "info": "info", + "warn": "warn", + "error": "error", + "crit": "critical", + "none": "off", +} + type logConfig struct { - RolloverType string - MaxRollCount int - MaxFileSizeMB float64 - logfile string - driverLevel string - instanceLevel string - outputFormat string - timestampFormat string - lock sync.Mutex + RolloverType string + MaxRollCount int + MaxFileSizeMB float64 + logfile string + driverLevel string + instanceLevel string + outputFormat string + logToStdout bool + lock sync.Mutex } var Config *logConfig @@ -89,7 +105,7 @@ func logfmtFormatter(params string) seelog.FormatterFunc { buf.WriteString(level.String()) buf.WriteByte(' ') buf.WriteString("time=") - buf.WriteString(context.CallTime().UTC().Format(Config.timestampFormat)) + buf.WriteString(context.CallTime().UTC().Format(timestampFormat)) buf.WriteByte(' ') // temporary measure to make this change backwards compatible as we update to structured logs if strings.HasPrefix(message, structuredTxtFormatPrefix) { @@ -114,7 +130,7 @@ func jsonFormatter(params string) seelog.FormatterFunc { buf.WriteString(`{"level":"`) buf.WriteString(level.String()) buf.WriteString(`","time":"`) - buf.WriteString(context.CallTime().UTC().Format(Config.timestampFormat)) + buf.WriteString(context.CallTime().UTC().Format(timestampFormat)) buf.WriteString(`",`) // temporary measure to make this change backwards compatible as we update to structured logs if strings.HasPrefix(message, structuredJsonFormatPrefix) { @@ -140,18 +156,26 @@ func reloadConfig() { seelog.Error(err) return } + fmt.Println(seelogConfig()) setGlobalLogger(logger, Config.outputFormat) } func seelogConfig() string { + platformLogConfig := platformLogConfig() c := ` - + ` + if platformLogConfig != "" || Config.logToStdout { + c += ` - ` - c += platformLogConfig() - c += ` + ` + if Config.logToStdout { + c += ` ` + } + c += platformLogConfig + c += ` ` + } if Config.logfile != "" { c += ` ` @@ -159,10 +183,13 @@ func seelogConfig() string { c += ` ` - } else { + } else if Config.RolloverType == "date" { c += ` ` + } else { + c += ` + ` } c += ` ` @@ -191,33 +218,6 @@ func getLevelList(fileLevel string) string { return levelLists[fileLevel] } -// SetLevel sets the log levels for logging -func SetLevel(driverLogLevel, instanceLogLevel string) { - levels := map[string]string{ - "debug": "debug", - "info": "info", - "warn": "warn", - "error": "error", - "crit": "critical", - "none": "off", - } - - parsedDriverLevel, driverOk := levels[strings.ToLower(driverLogLevel)] - parsedInstanceLevel, instanceOk := levels[strings.ToLower(instanceLogLevel)] - - if instanceOk || driverOk { - Config.lock.Lock() - defer Config.lock.Unlock() - if instanceOk { - Config.instanceLevel = parsedInstanceLevel - } - if driverOk { - Config.driverLevel = parsedDriverLevel - } - reloadConfig() - } -} - // GetLevel gets the log level func GetLevel() string { Config.lock.Lock() @@ -236,34 +236,76 @@ func setInstanceLevelDefault() string { return DEFAULT_LOGLEVEL } +// SetInstanceLogLevel explicitly sets the log level for instance logs. +func SetInstanceLogLevel(instanceLogLevel string) { + parsedLevel, ok := logLevels[strings.ToLower(instanceLogLevel)] + if ok { + Config.lock.Lock() + defer Config.lock.Unlock() + Config.instanceLevel = parsedLevel + reloadConfig() + } else { + seelog.Error("Instance log level mapping not found") + } +} + +// SetDriverLogLevel explicitly sets the log level for a custom driver. +func SetDriverLogLevel(driverLogLevel string) { + parsedLevel, ok := logLevels[strings.ToLower(driverLogLevel)] + if ok { + Config.lock.Lock() + defer Config.lock.Unlock() + Config.driverLevel = parsedLevel + reloadConfig() + } else { + seelog.Error("Driver log level mapping not found") + } +} + // SetConfigLogFile sets the default output file of the logger. func SetConfigLogFile(logFile string) { - Config.lock.Lock() - defer Config.lock.Unlock() + if logFile != "" { + Config.lock.Lock() + defer Config.lock.Unlock() - Config.logfile = logFile + Config.logfile = logFile + reloadConfig() + } } -// SetConfigLogFormat sets the output format of the logger. +// SetConfigOutputFormat sets the output format of the logger. // e.g. json, xml, etc. -func SetConfigLogFormat(logFormat string) { +func SetConfigOutputFormat(outputFormat string) { Config.lock.Lock() defer Config.lock.Unlock() - os.Setenv(LOG_OUTPUT_FORMAT_ENV_VAR, logFormat) - Config.outputFormat = logFormat + Config.outputFormat = outputFormat + reloadConfig() } // SetConfigMaxFileSizeMB sets the max file size of a log file // in Megabytes before the logger rotates to a new file. func SetConfigMaxFileSizeMB(maxSizeInMB float64) { - Config.lock.Lock() - defer Config.lock.Unlock() + if maxSizeInMB > 0 { + Config.lock.Lock() + defer Config.lock.Unlock() - // Parse unit as string to set as environment variable. - strsize := strconv.FormatFloat(maxSizeInMB, 'f', -1, 64) - os.Setenv(LOG_MAX_FILE_SIZE_ENV_VAR, strsize) - Config.MaxFileSizeMB = maxSizeInMB + Config.MaxFileSizeMB = maxSizeInMB + reloadConfig() + } +} + +// SetRolloverType sets the logging rollover constraint. +// This should be either size or date. Logger will roll +// to a new log file based on this constraint. +func SetRolloverType(rolloverType string) { + if rolloverType == "date" || rolloverType == "size" { + Config.lock.Lock() + defer Config.lock.Unlock() + + Config.RolloverType = rolloverType + reloadConfig() + } } // SetTimestampFormat sets the time formatting @@ -271,27 +313,38 @@ func SetConfigMaxFileSizeMB(maxSizeInMB float64) { // a valid time format such as time.RFC3339 // or "2006-01-02T15:04:05.000". func SetTimestampFormat(format string) { + if format != "" { + timestampFormat = format + } +} + +// SetlogToStdout decides whether the logger +// should write to stdout using the tag +// in addition to logfiles that are set up. +func SetlogToStdout(duplicate bool) { Config.lock.Lock() defer Config.lock.Unlock() - if format != "" { - Config.timestampFormat = format - } + Config.logToStdout = duplicate + reloadConfig() } func init() { Config = &logConfig{ - logfile: os.Getenv(LOGFILE_ENV_VAR), - driverLevel: DEFAULT_LOGLEVEL, - instanceLevel: setInstanceLevelDefault(), - RolloverType: DEFAULT_ROLLOVER_TYPE, - outputFormat: DEFAULT_OUTPUT_FORMAT, - MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, - MaxRollCount: DEFAULT_MAX_ROLL_COUNT, - timestampFormat: DEFAULT_TIMESTAMP_FORMAT, + logfile: os.Getenv(LOGFILE_ENV_VAR), + driverLevel: DEFAULT_LOGLEVEL, + instanceLevel: setInstanceLevelDefault(), + RolloverType: DEFAULT_ROLLOVER_TYPE, + outputFormat: DEFAULT_OUTPUT_FORMAT, + MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, + MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } } +// InitSeelog registers custom logging formats, updates the internal Config struct +// and reloads the global logger. This should only be called once, as external +// callers should use the Config struct over environment variables directly. func InitSeelog() { if err := seelog.RegisterCustomFormatter("EcsAgentLogfmt", logfmtFormatter); err != nil { seelog.Error(err) @@ -303,8 +356,12 @@ func InitSeelog() { seelog.Error(err) } - SetLevel(os.Getenv(LOGLEVEL_ENV_VAR), os.Getenv(LOGLEVEL_ON_INSTANCE_ENV_VAR)) - + if DriverLogLevel := os.Getenv(LOGLEVEL_ENV_VAR); DriverLogLevel != "" { + SetDriverLogLevel(DriverLogLevel) + } + if InstanceLogLevel := os.Getenv(LOGLEVEL_ON_INSTANCE_ENV_VAR); InstanceLogLevel != "" { + SetInstanceLogLevel(InstanceLogLevel) + } if RolloverType := os.Getenv(LOG_ROLLOVER_TYPE_ENV_VAR); RolloverType != "" { Config.RolloverType = RolloverType } diff --git a/ecs-agent/logger/log.go b/ecs-agent/logger/log.go index fc7025f823c..7c19f20669d 100644 --- a/ecs-agent/logger/log.go +++ b/ecs-agent/logger/log.go @@ -44,18 +44,34 @@ const ( DEFAULT_TIMESTAMP_FORMAT = time.RFC3339 DEFAULT_MAX_FILE_SIZE float64 = 10 DEFAULT_MAX_ROLL_COUNT int = 24 + DEFAULT_LOGTO_STDOUT = true ) +// Because timestamp format will be called in the custom formatter +// for each log message processed, it should not be handled +// with an explicitly write protected configuration. +var timestampFormat = DEFAULT_TIMESTAMP_FORMAT + +// logLevels is the mapping from ECS_LOGLEVEL to Seelog provided levels. +var logLevels = map[string]string{ + "debug": "debug", + "info": "info", + "warn": "warn", + "error": "error", + "crit": "critical", + "none": "off", +} + type logConfig struct { - RolloverType string - MaxRollCount int - MaxFileSizeMB float64 - logfile string - driverLevel string - instanceLevel string - outputFormat string - timestampFormat string - lock sync.Mutex + RolloverType string + MaxRollCount int + MaxFileSizeMB float64 + logfile string + driverLevel string + instanceLevel string + outputFormat string + logToStdout bool + lock sync.Mutex } var Config *logConfig @@ -89,7 +105,7 @@ func logfmtFormatter(params string) seelog.FormatterFunc { buf.WriteString(level.String()) buf.WriteByte(' ') buf.WriteString("time=") - buf.WriteString(context.CallTime().UTC().Format(Config.timestampFormat)) + buf.WriteString(context.CallTime().UTC().Format(timestampFormat)) buf.WriteByte(' ') // temporary measure to make this change backwards compatible as we update to structured logs if strings.HasPrefix(message, structuredTxtFormatPrefix) { @@ -114,7 +130,7 @@ func jsonFormatter(params string) seelog.FormatterFunc { buf.WriteString(`{"level":"`) buf.WriteString(level.String()) buf.WriteString(`","time":"`) - buf.WriteString(context.CallTime().UTC().Format(Config.timestampFormat)) + buf.WriteString(context.CallTime().UTC().Format(timestampFormat)) buf.WriteString(`",`) // temporary measure to make this change backwards compatible as we update to structured logs if strings.HasPrefix(message, structuredJsonFormatPrefix) { @@ -144,14 +160,21 @@ func reloadConfig() { } func seelogConfig() string { + platformLogConfig := platformLogConfig() c := ` - + ` + if platformLogConfig != "" || Config.logToStdout { + c += ` - ` - c += platformLogConfig() - c += ` + ` + if Config.logToStdout { + c += ` ` + } + c += platformLogConfig + c += ` ` + } if Config.logfile != "" { c += ` ` @@ -159,10 +182,13 @@ func seelogConfig() string { c += ` ` - } else { + } else if Config.RolloverType == "date" { c += ` ` + } else { + c += ` + ` } c += ` ` @@ -191,33 +217,6 @@ func getLevelList(fileLevel string) string { return levelLists[fileLevel] } -// SetLevel sets the log levels for logging -func SetLevel(driverLogLevel, instanceLogLevel string) { - levels := map[string]string{ - "debug": "debug", - "info": "info", - "warn": "warn", - "error": "error", - "crit": "critical", - "none": "off", - } - - parsedDriverLevel, driverOk := levels[strings.ToLower(driverLogLevel)] - parsedInstanceLevel, instanceOk := levels[strings.ToLower(instanceLogLevel)] - - if instanceOk || driverOk { - Config.lock.Lock() - defer Config.lock.Unlock() - if instanceOk { - Config.instanceLevel = parsedInstanceLevel - } - if driverOk { - Config.driverLevel = parsedDriverLevel - } - reloadConfig() - } -} - // GetLevel gets the log level func GetLevel() string { Config.lock.Lock() @@ -236,34 +235,76 @@ func setInstanceLevelDefault() string { return DEFAULT_LOGLEVEL } +// SetInstanceLogLevel explicitly sets the log level for instance logs. +func SetInstanceLogLevel(instanceLogLevel string) { + parsedLevel, ok := logLevels[strings.ToLower(instanceLogLevel)] + if ok { + Config.lock.Lock() + defer Config.lock.Unlock() + Config.instanceLevel = parsedLevel + reloadConfig() + } else { + seelog.Error("Instance log level mapping not found") + } +} + +// SetDriverLogLevel explicitly sets the log level for a custom driver. +func SetDriverLogLevel(driverLogLevel string) { + parsedLevel, ok := logLevels[strings.ToLower(driverLogLevel)] + if ok { + Config.lock.Lock() + defer Config.lock.Unlock() + Config.driverLevel = parsedLevel + reloadConfig() + } else { + seelog.Error("Driver log level mapping not found") + } +} + // SetConfigLogFile sets the default output file of the logger. func SetConfigLogFile(logFile string) { - Config.lock.Lock() - defer Config.lock.Unlock() + if logFile != "" { + Config.lock.Lock() + defer Config.lock.Unlock() - Config.logfile = logFile + Config.logfile = logFile + reloadConfig() + } } -// SetConfigLogFormat sets the output format of the logger. +// SetConfigOutputFormat sets the output format of the logger. // e.g. json, xml, etc. -func SetConfigLogFormat(logFormat string) { +func SetConfigOutputFormat(outputFormat string) { Config.lock.Lock() defer Config.lock.Unlock() - os.Setenv(LOG_OUTPUT_FORMAT_ENV_VAR, logFormat) - Config.outputFormat = logFormat + Config.outputFormat = outputFormat + reloadConfig() } // SetConfigMaxFileSizeMB sets the max file size of a log file // in Megabytes before the logger rotates to a new file. func SetConfigMaxFileSizeMB(maxSizeInMB float64) { - Config.lock.Lock() - defer Config.lock.Unlock() + if maxSizeInMB > 0 { + Config.lock.Lock() + defer Config.lock.Unlock() - // Parse unit as string to set as environment variable. - strsize := strconv.FormatFloat(maxSizeInMB, 'f', -1, 64) - os.Setenv(LOG_MAX_FILE_SIZE_ENV_VAR, strsize) - Config.MaxFileSizeMB = maxSizeInMB + Config.MaxFileSizeMB = maxSizeInMB + reloadConfig() + } +} + +// SetRolloverType sets the logging rollover constraint. +// This should be either size or date. Logger will roll +// to a new log file based on this constraint. +func SetRolloverType(rolloverType string) { + if rolloverType == "date" || rolloverType == "size" { + Config.lock.Lock() + defer Config.lock.Unlock() + + Config.RolloverType = rolloverType + reloadConfig() + } } // SetTimestampFormat sets the time formatting @@ -271,27 +312,38 @@ func SetConfigMaxFileSizeMB(maxSizeInMB float64) { // a valid time format such as time.RFC3339 // or "2006-01-02T15:04:05.000". func SetTimestampFormat(format string) { + if format != "" { + timestampFormat = format + } +} + +// SetlogToStdout decides whether the logger +// should write to stdout using the tag +// in addition to logfiles that are set up. +func SetlogToStdout(duplicate bool) { Config.lock.Lock() defer Config.lock.Unlock() - if format != "" { - Config.timestampFormat = format - } + Config.logToStdout = duplicate + reloadConfig() } func init() { Config = &logConfig{ - logfile: os.Getenv(LOGFILE_ENV_VAR), - driverLevel: DEFAULT_LOGLEVEL, - instanceLevel: setInstanceLevelDefault(), - RolloverType: DEFAULT_ROLLOVER_TYPE, - outputFormat: DEFAULT_OUTPUT_FORMAT, - MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, - MaxRollCount: DEFAULT_MAX_ROLL_COUNT, - timestampFormat: DEFAULT_TIMESTAMP_FORMAT, + logfile: os.Getenv(LOGFILE_ENV_VAR), + driverLevel: DEFAULT_LOGLEVEL, + instanceLevel: setInstanceLevelDefault(), + RolloverType: DEFAULT_ROLLOVER_TYPE, + outputFormat: DEFAULT_OUTPUT_FORMAT, + MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, + MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } } +// InitSeelog registers custom logging formats, updates the internal Config struct +// and reloads the global logger. This should only be called once, as external +// callers should use the Config struct over environment variables directly. func InitSeelog() { if err := seelog.RegisterCustomFormatter("EcsAgentLogfmt", logfmtFormatter); err != nil { seelog.Error(err) @@ -303,8 +355,12 @@ func InitSeelog() { seelog.Error(err) } - SetLevel(os.Getenv(LOGLEVEL_ENV_VAR), os.Getenv(LOGLEVEL_ON_INSTANCE_ENV_VAR)) - + if DriverLogLevel := os.Getenv(LOGLEVEL_ENV_VAR); DriverLogLevel != "" { + SetDriverLogLevel(DriverLogLevel) + } + if InstanceLogLevel := os.Getenv(LOGLEVEL_ON_INSTANCE_ENV_VAR); InstanceLogLevel != "" { + SetInstanceLogLevel(InstanceLogLevel) + } if RolloverType := os.Getenv(LOG_ROLLOVER_TYPE_ENV_VAR); RolloverType != "" { Config.RolloverType = RolloverType } diff --git a/ecs-agent/logger/log_test.go b/ecs-agent/logger/log_test.go index 2881a0b9b34..a41ddbfbf12 100644 --- a/ecs-agent/logger/log_test.go +++ b/ecs-agent/logger/log_test.go @@ -142,7 +142,7 @@ func TestJSONFormat_Structured_Timestamp(t *testing.T) { require.JSONEq(t, `{"level": "debug", "time": "2018-10-01T01:02:03.000", "msg": "This is my log message"}`, s) } -func TestSetLevel(t *testing.T) { +func TestSetLogLevels(t *testing.T) { resetEnv := func() { os.Unsetenv(LOGLEVEL_ENV_VAR) os.Unsetenv(LOGLEVEL_ON_INSTANCE_ENV_VAR) @@ -241,8 +241,11 @@ func TestSetLevel(t *testing.T) { MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, } - SetLevel(os.Getenv(LOGLEVEL_ENV_VAR), os.Getenv(LOGLEVEL_ON_INSTANCE_ENV_VAR)) + + SetDriverLogLevel(test.loglevel) require.Equal(t, test.expectedLoglevel, Config.driverLevel) + + SetInstanceLogLevel(test.loglevelInstance) require.Equal(t, test.expectedLoglevelInstance, Config.instanceLevel) }) } @@ -291,3 +294,11 @@ func (l *LogContextMock) CallTime() time.Time { func (l *LogContextMock) CustomContext() interface{} { return map[string]string{} } + +func updateLogConfig(config *logConfig) string { + mutex := Config.lock + mutex.Lock() + Config = config + mutex.Unlock() + return seelogConfig() +} diff --git a/ecs-agent/logger/log_unix_test.go b/ecs-agent/logger/log_unix_test.go index 0b063d1837b..cee54520fb2 100644 --- a/ecs-agent/logger/log_unix_test.go +++ b/ecs-agent/logger/log_unix_test.go @@ -32,6 +32,7 @@ func TestSeelogConfig_Default(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -61,6 +62,7 @@ func TestSeelogConfig_WithoutLogFile(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -78,6 +80,33 @@ func TestSeelogConfig_WithoutLogFile(t *testing.T) { `, c) } +func TestSeeLogConfig_WithoutStdout(t *testing.T) { + Config = &logConfig{ + logfile: "foo.log", + driverLevel: DEFAULT_LOGLEVEL, + instanceLevel: DEFAULT_LOGLEVEL, + RolloverType: "none", + outputFormat: DEFAULT_OUTPUT_FORMAT, + MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, + MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: false, + } + c := seelogConfig() + require.Equal(t, ` + + + + + + + + + + + +`, c) +} + func TestSeelogConfig_DebugLevel(t *testing.T) { Config = &logConfig{ logfile: "foo.log", @@ -87,6 +116,7 @@ func TestSeelogConfig_DebugLevel(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -117,6 +147,7 @@ func TestSeelogConfig_SizeRollover(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -147,6 +178,7 @@ func TestSeelogConfig_SizeRolloverFileSizeChange(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: 15, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -177,6 +209,7 @@ func TestSeelogConfig_SizeRolloverRollCountChange(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: 15, MaxRollCount: 10, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -207,6 +240,7 @@ func TestSeelogConfig_JSONOutput(t *testing.T) { outputFormat: "json", MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: 10, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -228,6 +262,64 @@ func TestSeelogConfig_JSONOutput(t *testing.T) { `, c) } +func TestSeelogConfig_JSONNoStdout(t *testing.T) { + Config = &logConfig{ + logfile: "foo.log", + driverLevel: DEFAULT_LOGLEVEL, + instanceLevel: DEFAULT_LOGLEVEL, + RolloverType: DEFAULT_ROLLOVER_TYPE, + outputFormat: "json", + MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, + MaxRollCount: 10, + logToStdout: false, + } + c := seelogConfig() + require.Equal(t, ` + + + + + + + + + + + +`, c) +} + +func TestSeelogConfig_JSONNoRollover(t *testing.T) { + Config = &logConfig{ + logfile: "foo.log", + driverLevel: DEFAULT_LOGLEVEL, + instanceLevel: DEFAULT_LOGLEVEL, + RolloverType: "none", + outputFormat: "json", + MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, + MaxRollCount: 10, + logToStdout: DEFAULT_LOGTO_STDOUT, + } + c := seelogConfig() + require.Equal(t, ` + + + + + + + + + + + + + + +`, c) +} + func TestSeelogConfig_NoOnInstanceLog(t *testing.T) { Config = &logConfig{ logfile: "foo.log", @@ -237,6 +329,7 @@ func TestSeelogConfig_NoOnInstanceLog(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -267,6 +360,7 @@ func TestSeelogConfig_DifferentLevels(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -300,6 +394,7 @@ func TestSeelogConfig_FileLevelDefault(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` diff --git a/ecs-agent/logger/log_windows_test.go b/ecs-agent/logger/log_windows_test.go index c763d595ac8..8dcd5fe4369 100644 --- a/ecs-agent/logger/log_windows_test.go +++ b/ecs-agent/logger/log_windows_test.go @@ -32,6 +32,7 @@ func TestSeelogConfigWindows_Default(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -62,6 +63,7 @@ func TestSeelogConfigWindows_WithoutLogFile(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -89,6 +91,7 @@ func TestSeelogConfigWindows_DebugLevel(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -120,6 +123,7 @@ func TestSeelogConfigWindows_SizeRollover(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -151,6 +155,7 @@ func TestSeelogConfigWindows_SizeRolloverFileSizeChange(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: 15, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -182,6 +187,7 @@ func TestSeelogConfigWindows_SizeRolloverRollCountChange(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: 15, MaxRollCount: 10, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -213,6 +219,7 @@ func TestSeelogConfigWindows_JSONOutput(t *testing.T) { outputFormat: "json", MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: 10, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -244,6 +251,7 @@ func TestSeelogConfigWindows_NoOnInstanceLog(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -275,6 +283,7 @@ func TestSeelogConfigWindows_DifferentLevels(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, ` @@ -309,6 +318,7 @@ func TestSeelogConfigWindows_FileLevelDefault(t *testing.T) { outputFormat: DEFAULT_OUTPUT_FORMAT, MaxFileSizeMB: DEFAULT_MAX_FILE_SIZE, MaxRollCount: DEFAULT_MAX_ROLL_COUNT, + logToStdout: DEFAULT_LOGTO_STDOUT, } c := seelogConfig() require.Equal(t, `