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 TestNew_envVarsSetConfigContainSetValues(t *testing.T) {
33 assertions := require.New(t)
34 os.Setenv("CONSUMER_HOST", "consumerHost")
35 os.Setenv("CONSUMER_PORT", "8095")
36 os.Setenv("INFO_COORD_ADDR", "infoCoordAddr")
37 os.Setenv("SDNR_ADDR", "sdnrHost:3908")
38 os.Setenv("SDNR_USER", "admin")
39 os.Setenv("SDNR_PASSWORD", "pwd")
40 os.Setenv("ORU_TO_ODU_MAP_FILE", "file")
41 os.Setenv("CONSUMER_CERT_PATH", "cert")
42 os.Setenv("CONSUMER_KEY_PATH", "key")
43 os.Setenv("LOG_LEVEL", "Debug")
48 ConsumerHost: "consumerHost",
50 InfoCoordinatorAddress: "infoCoordAddr",
51 SDNRAddress: "sdnrHost:3908",
54 ORUToODUMapFile: "file",
55 ConsumerCertPath: "cert",
56 ConsumerKeyPath: "key",
57 LogLevel: log.DebugLevel,
61 assertions.Equal(&wantConfig, got)
64 func TestNew_faultyIntValueSetConfigContainDefaultValueAndWarnInLog(t *testing.T) {
65 assertions := require.New(t)
69 os.Setenv("CONSUMER_PORT", "wrong")
71 log.SetOutput(os.Stderr)
77 InfoCoordinatorAddress: "http://enrichmentservice:8083",
78 SDNRAddress: "http://localhost:3904",
80 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
81 ORUToODUMapFile: "o-ru-to-o-du-map.csv",
82 ConsumerCertPath: "security/consumer.crt",
83 ConsumerKeyPath: "security/consumer.key",
84 LogLevel: log.InfoLevel,
88 assertions.Equal(&wantConfig, got)
90 logString := buf.String()
91 assertions.Contains(logString, "Invalid int value: wrong for variable: CONSUMER_PORT. Default value: 0 will be used")
94 func TestNew_envFaultyLogLevelConfigContainDefaultValues(t *testing.T) {
95 assertions := require.New(t)
99 os.Setenv("LOG_LEVEL", "wrong")
101 log.SetOutput(os.Stderr)
104 wantConfig := Config{
107 InfoCoordinatorAddress: "http://enrichmentservice:8083",
108 SDNRAddress: "http://localhost:3904",
110 SDNPassword: "Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U",
111 ORUToODUMapFile: "o-ru-to-o-du-map.csv",
112 ConsumerCertPath: "security/consumer.crt",
113 ConsumerKeyPath: "security/consumer.key",
114 LogLevel: log.InfoLevel,
117 assertions.Equal(&wantConfig, got)
118 logString := buf.String()
119 assertions.Contains(logString, "Invalid log level: wrong. Log level will be Info!")