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")
41 os.Setenv("NODE_ID", "o-du-1122")
46 MRHost: "consumerHost",
48 SDNRAddress: "http://localhost:3904",
50 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
52 LogLevel: log.DebugLevel,
57 assertions.Equal(&wantConfig, got)
60 func TestNewFaultyIntValueSetConfigContainDefaultValueAndWarnInLog(t *testing.T) {
61 assertions := require.New(t)
65 os.Setenv("Polltime", "wrong")
67 log.SetOutput(os.Stderr)
73 SDNRAddress: "http://localhost:3904",
75 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
77 LogLevel: log.InfoLevel,
82 assertions.Equal(&wantConfig, got)
84 logString := buf.String()
85 assertions.Contains(logString, "Invalid int value: wrong for variable: Polltime. Default value: 30 will be used")
88 func TestNewEnvFaultyLogLevelConfigContainDefaultValues(t *testing.T) {
89 assertions := require.New(t)
93 os.Setenv("LOG_LEVEL", "wrong")
95 log.SetOutput(os.Stderr)
101 SDNRAddress: "http://localhost:3904",
103 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
105 LogLevel: log.InfoLevel,
109 assertions.Equal(&wantConfig, got)
110 logString := buf.String()
111 assertions.Contains(logString, "Invalid log level: wrong. Log level will be Info!")