[RIC-247] RAN Health Check Request API - Validation
[ric-plt/e2mgr.git] / E2Manager / httpserver / http_server_test.go
index c841681..b798186 100644 (file)
 //  This source code is part of the near-RT RIC (RAN Intelligent Controller)
 //  platform project (RICP).
 
-
 package httpserver
 
 import (
+       "e2mgr/logger"
        "e2mgr/mocks"
        "github.com/gorilla/mux"
        "github.com/stretchr/testify/assert"
        "net/http"
        "net/http/httptest"
        "testing"
+       "time"
 )
 
-func setupRouterAndMocks() (*mux.Router, *mocks.ControllerMock, *mocks.NodebControllerMock) {
-       controllerMock := &mocks.ControllerMock{}
-       controllerMock.On("Shutdown").Return(nil)
-       controllerMock.On("X2Reset").Return(nil)
-       controllerMock.On("X2Setup").Return(nil)
-       controllerMock.On("EndcSetup").Return(nil)
-       controllerMock.On("GetNodeb").Return(nil)
-       controllerMock.On("GetNodebIdList").Return(nil)
-
-
+func setupRouterAndMocks() (*mux.Router, *mocks.RootControllerMock, *mocks.NodebControllerMock, *mocks.E2TControllerMock) {
+       rootControllerMock := &mocks.RootControllerMock{}
+       rootControllerMock.On("HandleHealthCheckRequest").Return(nil)
 
        nodebControllerMock := &mocks.NodebControllerMock{}
+       nodebControllerMock.On("Shutdown").Return(nil)
+       nodebControllerMock.On("GetNodeb").Return(nil)
        nodebControllerMock.On("GetNodebIdList").Return(nil)
-       nodebControllerMock.On("GetNodeb").Return(nil) // TODO: remove
-       nodebControllerMock.On("HandleHealthCheckRequest").Return(nil)
+       nodebControllerMock.On("SetGeneralConfiguration").Return(nil)
+       nodebControllerMock.On("DeleteEnb").Return(nil)
+       nodebControllerMock.On("AddEnb").Return(nil)
+       nodebControllerMock.On("UpdateEnb").Return(nil)
+       nodebControllerMock.On("HealthCheckRequest").Return(nil)
+
+       e2tControllerMock := &mocks.E2TControllerMock{}
+
+       e2tControllerMock.On("GetE2TInstances").Return(nil)
 
        router := mux.NewRouter()
-       initializeRoutes(router, nodebControllerMock, controllerMock)
-       return router, controllerMock, nodebControllerMock
+       initializeRoutes(router, rootControllerMock, nodebControllerMock, e2tControllerMock)
+       return router, rootControllerMock, nodebControllerMock, e2tControllerMock
 }
 
-func TestRoutePostEndcSetup(t *testing.T) {
-       router, controllerMock, _ := setupRouterAndMocks()
+func TestRouteGetNodebIds(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("POST", "/v1/nodeb/endc-setup", nil)
+       req, err := http.NewRequest("GET", "/v1/nodeb/states", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       controllerMock.AssertNumberOfCalls(t,"EndcSetup", 1)
+       nodebControllerMock.AssertNumberOfCalls(t, "GetNodebIdList", 1)
 }
 
-func TestRoutePostX2Setup(t *testing.T) {
-       router, controllerMock, _ := setupRouterAndMocks()
+func TestRouteGetNodebRanName(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("POST", "/v1/nodeb/x2-setup", nil)
+       req, err := http.NewRequest("GET", "/v1/nodeb/ran1", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       controllerMock.AssertNumberOfCalls(t,"X2Setup", 1)
+       assert.Equal(t, http.StatusOK, rr.Code, "handler returned wrong status code")
+       assert.Equal(t, "ran1", rr.Body.String(), "handler returned wrong body")
+       nodebControllerMock.AssertNumberOfCalls(t, "GetNodeb", 1)
 }
 
-func TestRouteGetNodebIds(t *testing.T) {
-       router, controllerMock, _ := setupRouterAndMocks()
+func TestRouteGetHealth(t *testing.T) {
+       router, rootControllerMock, _, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("GET", "/v1/nodeb/ids", nil)
+       req, err := http.NewRequest("GET", "/v1/health", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       controllerMock.AssertNumberOfCalls(t, "GetNodebIdList", 1)
+       rootControllerMock.AssertNumberOfCalls(t, "HandleHealthCheckRequest", 1)
 }
 
-func TestRouteGetNodebRanName(t *testing.T) {
-       router, controllerMock,_ := setupRouterAndMocks()
+func TestRoutePutNodebShutdown(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("GET", "/v1/nodeb/ran1", nil)
+       req, err := http.NewRequest("PUT", "/v1/nodeb/shutdown", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       assert.Equal(t, http.StatusOK, rr.Code, "handler returned wrong status code")
-       assert.Equal(t, "ran1", rr.Body.String(), "handler returned wrong body")
-       controllerMock.AssertNumberOfCalls(t, "GetNodeb", 1)
+       nodebControllerMock.AssertNumberOfCalls(t, "Shutdown", 1)
 }
 
-func TestRouteGetHealth(t *testing.T) {
-       router, _, nodebControllerMock := setupRouterAndMocks()
+func TestHealthCheckRequest(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("GET", "/v1/health", nil)
+       req, err := http.NewRequest("PUT", "/v1/nodeb/health", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       nodebControllerMock.AssertNumberOfCalls(t, "HandleHealthCheckRequest", 1)
+       nodebControllerMock.AssertNumberOfCalls(t, "HealthCheckRequest", 1)
 }
 
-func TestRoutePutNodebShutdown(t *testing.T) {
-       router, controllerMock, _ := setupRouterAndMocks()
+func TestRoutePutNodebSetGeneralConfiguration(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("PUT", "/v1/nodeb/shutdown", nil)
+       req, err := http.NewRequest("PUT", "/v1/nodeb/parameters", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       controllerMock.AssertNumberOfCalls(t, "Shutdown", 1)
+       nodebControllerMock.AssertNumberOfCalls(t, "SetGeneralConfiguration", 1)
 }
 
-func TestRoutePutNodebResetRanName(t *testing.T) {
-       router, controllerMock, _ := setupRouterAndMocks()
+func TestRoutePutUpdateEnb(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
 
-       req, err := http.NewRequest("PUT", "/v1/nodeb/ran1/reset", nil)
+       req, err := http.NewRequest("PUT", "/v1/nodeb/enb/ran1", nil)
        if err != nil {
                t.Fatal(err)
        }
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
-       assert.Equal(t, http.StatusOK, rr.Code, "handler returned wrong status code")
-       assert.Equal(t, "ran1", rr.Body.String(), "handler returned wrong body")
-       controllerMock.AssertNumberOfCalls(t, "X2Reset", 1)
+       nodebControllerMock.AssertNumberOfCalls(t, "UpdateEnb", 1)
 }
 
 func TestRouteNotFound(t *testing.T) {
-       router, _, _ := setupRouterAndMocks()
+       router, _, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("GET", "/v1/no/such/route", nil)
        if err != nil {
@@ -156,4 +157,59 @@ func TestRouteNotFound(t *testing.T) {
        router.ServeHTTP(rr, req)
 
        assert.Equal(t, http.StatusNotFound, rr.Code, "handler returned wrong status code")
-}
\ No newline at end of file
+}
+
+func TestRunError(t *testing.T) {
+       log := initLog(t)
+       err := Run(log, 1234567, &mocks.RootControllerMock{}, &mocks.NodebControllerMock{}, &mocks.E2TControllerMock{})
+       assert.NotNil(t, err)
+}
+
+func TestRun(t *testing.T) {
+       log := initLog(t)
+       _, rootControllerMock, nodebControllerMock, e2tControllerMock := setupRouterAndMocks()
+       go Run(log, 11223, rootControllerMock, nodebControllerMock, e2tControllerMock)
+
+       time.Sleep(time.Millisecond * 100)
+       resp, err := http.Get("http://localhost:11223/v1/health")
+       if err != nil {
+               t.Fatalf("failed to perform GET to http://localhost:11223/v1/health")
+       }
+       assert.Equal(t, 200, resp.StatusCode)
+}
+
+func TestRouteAddEnb(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+
+       req, err := http.NewRequest("POST", "/v1/nodeb/enb", nil)
+       if err != nil {
+               t.Fatal(err)
+       }
+       rr := httptest.NewRecorder()
+       router.ServeHTTP(rr, req)
+
+       assert.Equal(t, http.StatusCreated, rr.Code, "handler returned wrong status code")
+       nodebControllerMock.AssertNumberOfCalls(t, "AddEnb", 1)
+}
+
+func TestRouteDeleteEnb(t *testing.T) {
+       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+
+       req, err := http.NewRequest("DELETE", "/v1/nodeb/enb/ran1", nil)
+       if err != nil {
+               t.Fatal(err)
+       }
+       rr := httptest.NewRecorder()
+       router.ServeHTTP(rr, req)
+
+       assert.Equal(t, http.StatusNoContent, rr.Code, "handler returned wrong status code")
+       nodebControllerMock.AssertNumberOfCalls(t, "DeleteEnb", 1)
+}
+
+func initLog(t *testing.T) *logger.Logger {
+       log, err := logger.InitLogger(logger.InfoLevel)
+       if err != nil {
+               t.Errorf("#initLog test - failed to initialize logger, error: %s", err)
+       }
+       return log
+}