Support for symptomdata collection
[ric-plt/e2mgr.git] / E2Manager / httpserver / http_server_test.go
old mode 100644 (file)
new mode 100755 (executable)
index b798186..bbbdb14
@@ -1,6 +1,7 @@
 //
 // Copyright 2019 AT&T Intellectual Property
 // Copyright 2019 Nokia
+// Copyright (c) 2020 Samsung Electronics Co., Ltd. All Rights Reserved.
 //
 // Licensed under the Apache License, Version 2.0 (the "License");
 // you may not use this file except in compliance with the License.
@@ -30,7 +31,7 @@ import (
        "time"
 )
 
-func setupRouterAndMocks() (*mux.Router, *mocks.RootControllerMock, *mocks.NodebControllerMock, *mocks.E2TControllerMock) {
+func setupRouterAndMocks() (*mux.Router, *mocks.RootControllerMock, *mocks.NodebControllerMock, *mocks.E2TControllerMock, *mocks.SymptomdataControllerMock) {
        rootControllerMock := &mocks.RootControllerMock{}
        rootControllerMock.On("HandleHealthCheckRequest").Return(nil)
 
@@ -38,6 +39,7 @@ func setupRouterAndMocks() (*mux.Router, *mocks.RootControllerMock, *mocks.Nodeb
        nodebControllerMock.On("Shutdown").Return(nil)
        nodebControllerMock.On("GetNodeb").Return(nil)
        nodebControllerMock.On("GetNodebIdList").Return(nil)
+       nodebControllerMock.On("GetNodebId").Return(nil)
        nodebControllerMock.On("SetGeneralConfiguration").Return(nil)
        nodebControllerMock.On("DeleteEnb").Return(nil)
        nodebControllerMock.On("AddEnb").Return(nil)
@@ -45,16 +47,18 @@ func setupRouterAndMocks() (*mux.Router, *mocks.RootControllerMock, *mocks.Nodeb
        nodebControllerMock.On("HealthCheckRequest").Return(nil)
 
        e2tControllerMock := &mocks.E2TControllerMock{}
-
        e2tControllerMock.On("GetE2TInstances").Return(nil)
 
+       symptomdataControllerMock := &mocks.SymptomdataControllerMock{}
+       symptomdataControllerMock.On("GetSymptomData").Return(nil)
+
        router := mux.NewRouter()
-       initializeRoutes(router, rootControllerMock, nodebControllerMock, e2tControllerMock)
-       return router, rootControllerMock, nodebControllerMock, e2tControllerMock
+       initializeRoutes(router, rootControllerMock, nodebControllerMock, e2tControllerMock, symptomdataControllerMock)
+       return router, rootControllerMock, nodebControllerMock, e2tControllerMock, symptomdataControllerMock
 }
 
-func TestRouteGetNodebIds(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+func TestRouteGetNodebIdList(t *testing.T) {
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("GET", "/v1/nodeb/states", nil)
        if err != nil {
@@ -66,8 +70,22 @@ func TestRouteGetNodebIds(t *testing.T) {
        nodebControllerMock.AssertNumberOfCalls(t, "GetNodebIdList", 1)
 }
 
+func TestRouteGetNodebId(t *testing.T) {
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
+
+       req, err := http.NewRequest("GET", "/v1/nodeb/states/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")
+       nodebControllerMock.AssertNumberOfCalls(t, "GetNodebId", 1)
+}
+
 func TestRouteGetNodebRanName(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("GET", "/v1/nodeb/ran1", nil)
        if err != nil {
@@ -82,7 +100,7 @@ func TestRouteGetNodebRanName(t *testing.T) {
 }
 
 func TestRouteGetHealth(t *testing.T) {
-       router, rootControllerMock, _, _ := setupRouterAndMocks()
+       router, rootControllerMock, _, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("GET", "/v1/health", nil)
        if err != nil {
@@ -95,7 +113,7 @@ func TestRouteGetHealth(t *testing.T) {
 }
 
 func TestRoutePutNodebShutdown(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("PUT", "/v1/nodeb/shutdown", nil)
        if err != nil {
@@ -108,7 +126,7 @@ func TestRoutePutNodebShutdown(t *testing.T) {
 }
 
 func TestHealthCheckRequest(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("PUT", "/v1/nodeb/health", nil)
        if err != nil {
@@ -117,11 +135,12 @@ func TestHealthCheckRequest(t *testing.T) {
        rr := httptest.NewRecorder()
        router.ServeHTTP(rr, req)
 
+       assert.Equal(t, http.StatusAccepted, rr.Code, "handler returned wrong status code")
        nodebControllerMock.AssertNumberOfCalls(t, "HealthCheckRequest", 1)
 }
 
 func TestRoutePutNodebSetGeneralConfiguration(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("PUT", "/v1/nodeb/parameters", nil)
        if err != nil {
@@ -134,7 +153,7 @@ func TestRoutePutNodebSetGeneralConfiguration(t *testing.T) {
 }
 
 func TestRoutePutUpdateEnb(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("PUT", "/v1/nodeb/enb/ran1", nil)
        if err != nil {
@@ -147,7 +166,7 @@ func TestRoutePutUpdateEnb(t *testing.T) {
 }
 
 func TestRouteNotFound(t *testing.T) {
-       router, _, _, _ := setupRouterAndMocks()
+       router, _, _, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("GET", "/v1/no/such/route", nil)
        if err != nil {
@@ -161,14 +180,14 @@ func TestRouteNotFound(t *testing.T) {
 
 func TestRunError(t *testing.T) {
        log := initLog(t)
-       err := Run(log, 1234567, &mocks.RootControllerMock{}, &mocks.NodebControllerMock{}, &mocks.E2TControllerMock{})
+       err := Run(log, 1234567, &mocks.RootControllerMock{}, &mocks.NodebControllerMock{}, &mocks.E2TControllerMock{}, &mocks.SymptomdataControllerMock{})
        assert.NotNil(t, err)
 }
 
 func TestRun(t *testing.T) {
        log := initLog(t)
-       _, rootControllerMock, nodebControllerMock, e2tControllerMock := setupRouterAndMocks()
-       go Run(log, 11223, rootControllerMock, nodebControllerMock, e2tControllerMock)
+       _, rootControllerMock, nodebControllerMock, e2tControllerMock, symptomdataControllerMock := setupRouterAndMocks()
+       go Run(log, 11223, rootControllerMock, nodebControllerMock, e2tControllerMock, symptomdataControllerMock)
 
        time.Sleep(time.Millisecond * 100)
        resp, err := http.Get("http://localhost:11223/v1/health")
@@ -179,7 +198,7 @@ func TestRun(t *testing.T) {
 }
 
 func TestRouteAddEnb(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("POST", "/v1/nodeb/enb", nil)
        if err != nil {
@@ -193,7 +212,7 @@ func TestRouteAddEnb(t *testing.T) {
 }
 
 func TestRouteDeleteEnb(t *testing.T) {
-       router, _, nodebControllerMock, _ := setupRouterAndMocks()
+       router, _, nodebControllerMock, _, _ := setupRouterAndMocks()
 
        req, err := http.NewRequest("DELETE", "/v1/nodeb/enb/ran1", nil)
        if err != nil {