2 // ========================LICENSE_START=================================
5 // Copyright (C) 2021: Nordix Foundation
7 // Licensed under the Apache License, Version 2.0 (the "License");
8 // you may not use this file except in compliance with the License.
9 // You may obtain a copy of the License at
11 // http://www.apache.org/licenses/LICENSE-2.0
13 // Unless required by applicable law or agreed to in writing, software
14 // distributed under the License is distributed on an "AS IS" BASIS,
15 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 // See the License for the specific language governing permissions and
17 // limitations under the License.
18 // ========================LICENSE_END===================================
28 log "github.com/sirupsen/logrus"
29 "github.com/stretchr/testify/require"
32 func TestNewEnvVarsSetConfigContainSetValues(t *testing.T) {
33 assertions := require.New(t)
34 os.Setenv("MR_HOST", "consumerHost")
35 os.Setenv("MR_PORT", "8095")
36 os.Setenv("SDNR_ADDR", "http://localhost:3904")
37 os.Setenv("SDNR_USER", "admin")
38 os.Setenv("SDNR_PASSWORD", "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U")
39 os.Setenv("Polltime", "30")
40 os.Setenv("LOG_LEVEL", "Debug")
45 MRHost: "consumerHost",
47 SDNRAddress: "http://localhost:3904",
49 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
51 LogLevel: log.DebugLevel,
55 assertions.Equal(&wantConfig, got)
58 func TestNewFaultyIntValueSetConfigContainDefaultValueAndWarnInLog(t *testing.T) {
59 assertions := require.New(t)
63 os.Setenv("Polltime", "wrong")
65 log.SetOutput(os.Stderr)
71 SDNRAddress: "http://localhost:3904",
73 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
75 LogLevel: log.InfoLevel,
79 assertions.Equal(&wantConfig, got)
81 logString := buf.String()
82 assertions.Contains(logString, "Invalid int value: wrong for variable: Polltime. Default value: 30 will be used")
85 func TestNewEnvFaultyLogLevelConfigContainDefaultValues(t *testing.T) {
86 assertions := require.New(t)
90 os.Setenv("LOG_LEVEL", "wrong")
92 log.SetOutput(os.Stderr)
98 SDNRAddress: "http://localhost:3904",
100 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
102 LogLevel: log.InfoLevel,
105 assertions.Equal(&wantConfig, got)
106 logString := buf.String()
107 assertions.Contains(logString, "Invalid log level: wrong. Log level will be Info!")