87cb8f3bc7dece20aec11a4605e2d123b207870c
[ric-plt/e2mgr.git] / E2Manager / providers / httpmsghandlerprovider / incoming_request_handler_provider_test.go
1 //
2 // Copyright 2019 AT&T Intellectual Property
3 // Copyright 2019 Nokia
4 // Copyright (c) 2020 Samsung Electronics Co., Ltd. All Rights Reserved.
5 //
6 // Licensed under the Apache License, Version 2.0 (the "License");
7 // you may not use this file except in compliance with the License.
8 // You may obtain a copy of the License at
9 //
10 //      http://www.apache.org/licenses/LICENSE-2.0
11 //
12 // Unless required by applicable law or agreed to in writing, software
13 // distributed under the License is distributed on an "AS IS" BASIS,
14 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 // See the License for the specific language governing permissions and
16 // limitations under the License.
17
18 //  This source code is part of the near-RT RIC (RAN Intelligent Controller)
19 //  platform project (RICP).
20
21 package httpmsghandlerprovider
22
23 import (
24         "e2mgr/clients"
25         "e2mgr/configuration"
26         "e2mgr/e2managererrors"
27         "e2mgr/handlers/httpmsghandlers"
28         "e2mgr/logger"
29         "e2mgr/managers"
30         "e2mgr/mocks"
31         "e2mgr/rmrCgo"
32         "e2mgr/services"
33         "e2mgr/services/rmrsender"
34         "e2mgr/tests"
35         "github.com/stretchr/testify/assert"
36         "reflect"
37         "testing"
38 )
39
40 func getRmrSender(rmrMessengerMock *mocks.RmrMessengerMock, log *logger.Logger) *rmrsender.RmrSender {
41         rmrMessenger := rmrCgo.RmrMessenger(rmrMessengerMock)
42         rmrMessengerMock.On("Init", tests.GetPort(), tests.MaxMsgSize, tests.Flags, log).Return(&rmrMessenger)
43         return rmrsender.NewRmrSender(log, rmrMessenger)
44 }
45
46 func setupTest(t *testing.T) *IncomingRequestHandlerProvider {
47         rmrMessengerMock := &mocks.RmrMessengerMock{}
48         log := initLog(t)
49         config := &configuration.Configuration{RnibRetryIntervalMs: 10, MaxRnibConnectionAttempts: 3, RnibWriter: configuration.RnibWriterConfig{StateChangeMessageChannel: "RAN_CONNECTION_STATUS_CHANGE", RanManipulationMessageChannel: "RAN_MANIPULATION"}}
50         config.RoutingManager.BaseUrl = "http://10.10.2.15:12020/routingmanager"
51         readerMock := &mocks.RnibReaderMock{}
52         writerMock := &mocks.RnibWriterMock{}
53         rnibDataService := services.NewRnibDataService(log, config, readerMock, writerMock)
54         rmrSender := getRmrSender(rmrMessengerMock, log)
55         e2tInstancesManager := managers.NewE2TInstancesManager(rnibDataService, log)
56         httpClientMock := &mocks.HttpClientMock{}
57         rmClient := clients.NewRoutingManagerClient(log, config, httpClientMock)
58         ranListManager := managers.NewRanListManager(log, rnibDataService)
59         ranAlarmService := services.NewRanAlarmService(log, config)
60         ranConnectStatusChangeManager := managers.NewRanConnectStatusChangeManager(log, rnibDataService, ranListManager, ranAlarmService)
61         nodebValidator := managers.NewNodebValidator()
62         updateEnbManager := managers.NewUpdateEnbManager(log, rnibDataService, nodebValidator)
63         updateGnbManager := managers.NewUpdateEnbManager(log, rnibDataService, nodebValidator)
64         return NewIncomingRequestHandlerProvider(log, rmrSender, configuration.ParseConfiguration(), rnibDataService, e2tInstancesManager, rmClient, ranConnectStatusChangeManager, nodebValidator, updateEnbManager, updateGnbManager, ranListManager)
65 }
66
67 func TestNewIncomingRequestHandlerProvider(t *testing.T) {
68         provider := setupTest(t)
69
70         assert.NotNil(t, provider)
71 }
72
73 func TestShutdownRequestHandler(t *testing.T) {
74         provider := setupTest(t)
75         handler, err := provider.GetHandler(ShutdownRequest)
76
77         assert.NotNil(t, provider)
78         assert.Nil(t, err)
79
80         _, ok := handler.(*httpmsghandlers.DeleteAllRequestHandler)
81
82         assert.True(t, ok)
83 }
84
85 func TestSetGeneralConfigurationHandler(t *testing.T) {
86         provider := setupTest(t)
87         handler, err := provider.GetHandler(SetGeneralConfigurationRequest)
88
89         assert.NotNil(t, provider)
90         assert.Nil(t, err)
91
92         _, ok := handler.(*httpmsghandlers.SetGeneralConfigurationHandler)
93
94         assert.True(t, ok)
95 }
96
97 func TestHealthCheckRequest(t *testing.T) {
98         provider := setupTest(t)
99         handler, err := provider.GetHandler(HealthCheckRequest)
100
101         assert.NotNil(t, provider)
102         assert.Nil(t, err)
103
104         _, ok := handler.(*httpmsghandlers.HealthCheckRequestHandler)
105
106         assert.True(t, ok)
107 }
108
109 func TestGetShutdownHandlerFailure(t *testing.T) {
110         provider := setupTest(t)
111         _, actual := provider.GetHandler("test")
112         expected := &e2managererrors.InternalError{}
113
114         assert.NotNil(t, actual)
115         if reflect.TypeOf(actual) != reflect.TypeOf(expected) {
116                 t.Errorf("Error actual = %v, and Expected = %v.", actual, expected)
117         }
118 }
119
120 func initLog(t *testing.T) *logger.Logger {
121         log, err := logger.InitLogger(logger.InfoLevel)
122         if err != nil {
123                 t.Errorf("#delete_all_request_handler_test.TestHandleSuccessFlow - failed to initialize logger, error: %s", err)
124         }
125         return log
126 }