Add R5 content to master
[ric-plt/e2mgr.git] / E2Manager / httpserver / http_server_test.go
1 //
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.
16
17 //  This source code is part of the near-RT RIC (RAN Intelligent Controller)
18 //  platform project (RICP).
19
20
21 package httpserver
22
23 import (
24         "e2mgr/logger"
25         "e2mgr/mocks"
26         "github.com/gorilla/mux"
27         "github.com/stretchr/testify/assert"
28         "net/http"
29         "net/http/httptest"
30         "testing"
31         "time"
32 )
33
34 func setupRouterAndMocks() (*mux.Router, *mocks.RootControllerMock, *mocks.NodebControllerMock, *mocks.E2TControllerMock) {
35         rootControllerMock := &mocks.RootControllerMock{}
36         rootControllerMock.On("HandleHealthCheckRequest").Return(nil)
37
38         nodebControllerMock := &mocks.NodebControllerMock{}
39         nodebControllerMock.On("Shutdown").Return(nil)
40         nodebControllerMock.On("GetNodeb").Return(nil)
41         nodebControllerMock.On("GetNodebIdList").Return(nil)
42         nodebControllerMock.On("SetGeneralConfiguration").Return(nil)
43
44         e2tControllerMock := &mocks.E2TControllerMock{}
45
46         e2tControllerMock.On("GetE2TInstances").Return(nil)
47
48         router := mux.NewRouter()
49         initializeRoutes(router, rootControllerMock, nodebControllerMock, e2tControllerMock)
50         return router, rootControllerMock, nodebControllerMock, e2tControllerMock
51 }
52
53 func TestRouteGetNodebIds(t *testing.T) {
54         router, _, nodebControllerMock, _ := setupRouterAndMocks()
55
56         req, err := http.NewRequest("GET", "/v1/nodeb/ids", nil)
57         if err != nil {
58                 t.Fatal(err)
59         }
60         rr := httptest.NewRecorder()
61         router.ServeHTTP(rr, req)
62
63         nodebControllerMock.AssertNumberOfCalls(t, "GetNodebIdList", 1)
64 }
65
66 func TestRouteGetNodebRanName(t *testing.T) {
67         router, _, nodebControllerMock, _ := setupRouterAndMocks()
68
69         req, err := http.NewRequest("GET", "/v1/nodeb/ran1", nil)
70         if err != nil {
71                 t.Fatal(err)
72         }
73         rr := httptest.NewRecorder()
74         router.ServeHTTP(rr, req)
75
76         assert.Equal(t, http.StatusOK, rr.Code, "handler returned wrong status code")
77         assert.Equal(t, "ran1", rr.Body.String(), "handler returned wrong body")
78         nodebControllerMock.AssertNumberOfCalls(t, "GetNodeb", 1)
79 }
80
81 func TestRouteGetHealth(t *testing.T) {
82         router, rootControllerMock, _, _ := setupRouterAndMocks()
83
84         req, err := http.NewRequest("GET", "/v1/health", nil)
85         if err != nil {
86                 t.Fatal(err)
87         }
88         rr := httptest.NewRecorder()
89         router.ServeHTTP(rr, req)
90
91         rootControllerMock.AssertNumberOfCalls(t, "HandleHealthCheckRequest", 1)
92 }
93
94 func TestRoutePutNodebShutdown(t *testing.T) {
95         router, _, nodebControllerMock, _ := setupRouterAndMocks()
96
97         req, err := http.NewRequest("PUT", "/v1/nodeb/shutdown", nil)
98         if err != nil {
99                 t.Fatal(err)
100         }
101         rr := httptest.NewRecorder()
102         router.ServeHTTP(rr, req)
103
104         nodebControllerMock.AssertNumberOfCalls(t, "Shutdown", 1)
105 }
106
107 func TestRoutePutNodebSetGeneralConfiguration(t *testing.T) {
108         router, _, nodebControllerMock, _ := setupRouterAndMocks()
109
110         req, err := http.NewRequest("PUT", "/v1/nodeb/parameters", nil)
111         if err != nil {
112                 t.Fatal(err)
113         }
114         rr := httptest.NewRecorder()
115         router.ServeHTTP(rr, req)
116
117         nodebControllerMock.AssertNumberOfCalls(t, "SetGeneralConfiguration", 1)
118 }
119
120 func TestRouteNotFound(t *testing.T) {
121         router, _, _,_ := setupRouterAndMocks()
122
123         req, err := http.NewRequest("GET", "/v1/no/such/route", nil)
124         if err != nil {
125                 t.Fatal(err)
126         }
127         rr := httptest.NewRecorder()
128         router.ServeHTTP(rr, req)
129
130         assert.Equal(t, http.StatusNotFound, rr.Code, "handler returned wrong status code")
131 }
132
133 func TestRunError(t *testing.T) {
134         log := initLog(t)
135         err := Run(log, 1234567, &mocks.RootControllerMock{}, &mocks.NodebControllerMock{}, &mocks.E2TControllerMock{})
136         assert.NotNil(t, err)
137 }
138
139 func TestRun(t *testing.T) {
140         log := initLog(t)
141         _, rootControllerMock, nodebControllerMock, e2tControllerMock := setupRouterAndMocks()
142         go Run(log, 11223, rootControllerMock, nodebControllerMock, e2tControllerMock)
143
144         time.Sleep(time.Millisecond * 100)
145         resp, err := http.Get("http://localhost:11223/v1/health")
146         if err != nil {
147                 t.Fatalf("failed to perform GET to http://localhost:11223/v1/health")
148         }
149         assert.Equal(t, 200, resp.StatusCode)
150 }
151
152 func initLog(t *testing.T) *logger.Logger {
153         log, err := logger.InitLogger(logger.InfoLevel)
154         if err != nil {
155                 t.Errorf("#initLog test - failed to initialize logger, error: %s", err)
156         }
157         return log
158 }