X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=E2Manager%2Fhttpserver%2Fhttp_server_test.go;h=6378f8cf5cd87761bad8507b5382b68ef6fb41f4;hb=e0106ffb1e1e5b133752b073372d663c49101370;hp=c841681fab5f79cfed865b117400abb854d5d3c0;hpb=15d3982b5eda43a5b5b9054d7ecb026448c6ca16;p=ric-plt%2Fe2mgr.git diff --git a/E2Manager/httpserver/http_server_test.go b/E2Manager/httpserver/http_server_test.go index c841681..6378f8c 100644 --- a/E2Manager/httpserver/http_server_test.go +++ b/E2Manager/httpserver/http_server_test.go @@ -17,143 +17,171 @@ // 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) + + 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/ids", 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 TestRoutePutNodebSetGeneralConfiguration(t *testing.T) { + router, _, nodebControllerMock, _ := setupRouterAndMocks() - req, err := http.NewRequest("GET", "/v1/health", nil) + req, err := http.NewRequest("PUT", "/v1/nodeb/parameters", nil) if err != nil { t.Fatal(err) } rr := httptest.NewRecorder() router.ServeHTTP(rr, req) - nodebControllerMock.AssertNumberOfCalls(t, "HandleHealthCheckRequest", 1) + nodebControllerMock.AssertNumberOfCalls(t, "SetGeneralConfiguration", 1) } -func TestRoutePutNodebShutdown(t *testing.T) { - router, controllerMock, _ := setupRouterAndMocks() +func TestRouteNotFound(t *testing.T) { + router, _, _, _ := setupRouterAndMocks() - req, err := http.NewRequest("PUT", "/v1/nodeb/shutdown", nil) + req, err := http.NewRequest("GET", "/v1/no/such/route", nil) if err != nil { t.Fatal(err) } rr := httptest.NewRecorder() router.ServeHTTP(rr, req) - controllerMock.AssertNumberOfCalls(t, "Shutdown", 1) + assert.Equal(t, http.StatusNotFound, rr.Code, "handler returned wrong status code") +} + +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 TestRoutePutNodebResetRanName(t *testing.T) { - router, controllerMock, _ := setupRouterAndMocks() +func TestRouteAddEnb(t *testing.T) { + router, _, nodebControllerMock, _ := setupRouterAndMocks() - req, err := http.NewRequest("PUT", "/v1/nodeb/ran1/reset", nil) + 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.StatusOK, rr.Code, "handler returned wrong status code") - assert.Equal(t, "ran1", rr.Body.String(), "handler returned wrong body") - controllerMock.AssertNumberOfCalls(t, "X2Reset", 1) + assert.Equal(t, http.StatusCreated, rr.Code, "handler returned wrong status code") + nodebControllerMock.AssertNumberOfCalls(t, "AddEnb", 1) } -func TestRouteNotFound(t *testing.T) { - router, _, _ := setupRouterAndMocks() +func TestRouteDeleteEnb(t *testing.T) { + router, _, nodebControllerMock, _ := setupRouterAndMocks() - req, err := http.NewRequest("GET", "/v1/no/such/route", nil) + 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.StatusNotFound, rr.Code, "handler returned wrong status code") -} \ No newline at end of file + 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 +}