blob: 42d0bdf5596c70df17729a47dcf785383834f658 [file] [log] [blame]
ss412gde190682019-10-24 09:29:26 +03001//
2// Copyright 2019 AT&T Intellectual Property
3// Copyright 2019 Nokia
4//
5// Licensed under the Apache License, Version 2.0 (the "License");
6// you may not use this file except in compliance with the License.
7// You may obtain a copy of the License at
8//
9// http://www.apache.org/licenses/LICENSE-2.0
10//
11// Unless required by applicable law or agreed to in writing, software
12// distributed under the License is distributed on an "AS IS" BASIS,
13// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14// See the License for the specific language governing permissions and
15// limitations under the License.
nm755n15d39822019-11-28 16:56:00 +000016
17// This source code is part of the near-RT RIC (RAN Intelligent Controller)
18// platform project (RICP).
19
ss412gde190682019-10-24 09:29:26 +030020
21package controllers
22
23import (
24 "e2mgr/configuration"
25 "e2mgr/logger"
26 "e2mgr/mocks"
ss412gde190682019-10-24 09:29:26 +030027 "e2mgr/services"
28 "fmt"
29 "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/common"
30 "gerrit.o-ran-sc.org/r/ric-plt/nodeb-rnib.git/entities"
ss412gde190682019-10-24 09:29:26 +030031 "github.com/stretchr/testify/assert"
32 "net"
33 "net/http"
34 "net/http/httptest"
35 "testing"
36)
37
38func setupNodebControllerTest(t *testing.T) (services.RNibDataService, *mocks.RnibReaderMock){
39 logger, err := logger.InitLogger(logger.DebugLevel)
40 if err != nil {
41 t.Errorf("#... - failed to initialize logger, error: %s", err)
42 }
43 config := &configuration.Configuration{RnibRetryIntervalMs: 10, MaxRnibConnectionAttempts: 3}
44 readerMock := &mocks.RnibReaderMock{}
ss412gefcb4522019-12-02 16:59:19 +020045
46 writerMock := &mocks.RnibWriterMock{}
47
48 rnibDataService := services.NewRnibDataService(logger, config, readerMock, writerMock)
ss412gde190682019-10-24 09:29:26 +030049 return rnibDataService, readerMock
50}
51
52func TestNewRequestController(t *testing.T) {
53 rnibDataService, _ := setupNodebControllerTest(t)
54 assert.NotNil(t, NewRootController(rnibDataService))
55}
56
57func TestHandleHealthCheckRequestGood(t *testing.T) {
58 rnibDataService, rnibReaderMock := setupNodebControllerTest(t)
59
60 var nbList []*entities.NbIdentity
61 rnibReaderMock.On("GetListNodebIds").Return(nbList, nil)
62
63 rc := NewRootController(rnibDataService)
64 writer := httptest.NewRecorder()
65 rc.HandleHealthCheckRequest(writer, nil)
66 assert.Equal(t, http.StatusOK, writer.Result().StatusCode)
67}
68
69func TestHandleHealthCheckRequestOtherError(t *testing.T) {
70 rnibDataService, rnibReaderMock := setupNodebControllerTest(t)
71
72 mockOtherErr := &common.InternalError{Err: fmt.Errorf("non connection error")}
73 var nbList []*entities.NbIdentity
74 rnibReaderMock.On("GetListNodebIds").Return(nbList, mockOtherErr)
75
76 rc := NewRootController(rnibDataService)
77 writer := httptest.NewRecorder()
78 rc.HandleHealthCheckRequest(writer, nil)
79 assert.Equal(t, http.StatusOK, writer.Result().StatusCode)
80}
81
82func TestHandleHealthCheckRequestConnError(t *testing.T) {
83 rnibDataService, rnibReaderMock := setupNodebControllerTest(t)
84
85 mockConnErr := &common.InternalError{Err: &net.OpError{Err: fmt.Errorf("connection error")}}
86 var nbList []*entities.NbIdentity
87 rnibReaderMock.On("GetListNodebIds").Return(nbList, mockConnErr)
88
89
90 rc := NewRootController(rnibDataService)
91 writer := httptest.NewRecorder()
92 rc.HandleHealthCheckRequest(writer, nil)
93 assert.Equal(t, http.StatusInternalServerError, writer.Result().StatusCode)
94}