// - // ========================LICENSE_START================================= // O-RAN-SC // %% // Copyright (C) 2021: Nordix Foundation // %% // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // ========================LICENSE_END=================================== // package restclient import ( "bytes" "errors" "fmt" "io/ioutil" "net/http" "testing" "github.com/stretchr/testify/mock" "github.com/stretchr/testify/require" "oransc.org/nonrtric/dmaapmediatorproducer/mocks/httpclient" ) func TestRequestError_Error(t *testing.T) { assertions := require.New(t) actualError := RequestError{ StatusCode: http.StatusBadRequest, Body: []byte("error"), } assertions.Equal("Request failed due to error response with status: 400 and body: error", actualError.Error()) } func TestGet(t *testing.T) { assertions := require.New(t) type args struct { url string mockReturnStatus int mockReturnBody string mockReturnError error } tests := []struct { name string args args want []byte wantedError error }{ { name: "Test Get with OK response", args: args{ url: "http://testOk", mockReturnStatus: http.StatusOK, mockReturnBody: "Response", }, want: []byte("Response"), }, { name: "Test Get with Not OK response", args: args{ url: "http://testNotOk", mockReturnStatus: http.StatusBadRequest, mockReturnBody: "Bad Response", }, want: nil, wantedError: RequestError{ StatusCode: http.StatusBadRequest, Body: []byte("Bad Response"), }, }, { name: "Test Get with error", args: args{ url: "http://testError", mockReturnError: errors.New("Failed Request"), }, want: nil, wantedError: errors.New("Failed Request"), }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { clientMock := httpclient.HTTPClient{} clientMock.On("Get", tt.args.url).Return(&http.Response{ StatusCode: tt.args.mockReturnStatus, Body: ioutil.NopCloser(bytes.NewReader([]byte(tt.args.mockReturnBody))), }, tt.args.mockReturnError) got, err := Get(tt.args.url, &clientMock) assertions.Equal(tt.wantedError, err, tt.name) assertions.Equal(tt.want, got, tt.name) clientMock.AssertCalled(t, "Get", tt.args.url) }) } } func TestPutOk(t *testing.T) { assertions := require.New(t) clientMock := httpclient.HTTPClient{} clientMock.On("Do", mock.Anything).Return(&http.Response{ StatusCode: http.StatusOK, }, nil) if err := Put("http://localhost:9990", []byte("body"), &clientMock); err != nil { t.Errorf("Put() error = %v, did not want error", err) } var actualRequest *http.Request clientMock.AssertCalled(t, "Do", mock.MatchedBy(func(req *http.Request) bool { actualRequest = req return true })) assertions.Equal(http.MethodPut, actualRequest.Method) assertions.Equal("http", actualRequest.URL.Scheme) assertions.Equal("localhost:9990", actualRequest.URL.Host) assertions.Equal("application/json; charset=utf-8", actualRequest.Header.Get("Content-Type")) body, _ := ioutil.ReadAll(actualRequest.Body) expectedBody := []byte("body") assertions.Equal(expectedBody, body) clientMock.AssertNumberOfCalls(t, "Do", 1) } func TestPostOk(t *testing.T) { assertions := require.New(t) clientMock := httpclient.HTTPClient{} clientMock.On("Do", mock.Anything).Return(&http.Response{ StatusCode: http.StatusOK, }, nil) if err := Post("http://localhost:9990", []byte("body"), &clientMock); err != nil { t.Errorf("Put() error = %v, did not want error", err) } var actualRequest *http.Request clientMock.AssertCalled(t, "Do", mock.MatchedBy(func(req *http.Request) bool { actualRequest = req return true })) assertions.Equal(http.MethodPost, actualRequest.Method) assertions.Equal("http", actualRequest.URL.Scheme) assertions.Equal("localhost:9990", actualRequest.URL.Host) assertions.Equal("application/json; charset=utf-8", actualRequest.Header.Get("Content-Type")) body, _ := ioutil.ReadAll(actualRequest.Body) expectedBody := []byte("body") assertions.Equal(expectedBody, body) clientMock.AssertNumberOfCalls(t, "Do", 1) } func Test_doErrorCases(t *testing.T) { assertions := require.New(t) type args struct { url string mockReturnStatus int mockReturnBody []byte mockReturnError error } tests := []struct { name string args args wantErr error }{ { name: "Bad request should get RequestError", args: args{ url: "badRequest", mockReturnStatus: http.StatusBadRequest, mockReturnBody: []byte("bad request"), mockReturnError: nil, }, wantErr: RequestError{ StatusCode: http.StatusBadRequest, Body: []byte("bad request"), }, }, { name: "Server unavailable should get error", args: args{ url: "serverUnavailable", mockReturnError: fmt.Errorf("Server unavailable"), }, wantErr: fmt.Errorf("Server unavailable"), }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { clientMock := httpclient.HTTPClient{} clientMock.On("Do", mock.Anything).Return(&http.Response{ StatusCode: tt.args.mockReturnStatus, Body: ioutil.NopCloser(bytes.NewReader(tt.args.mockReturnBody)), }, tt.args.mockReturnError) err := do("PUT", tt.args.url, nil, &clientMock) assertions.Equal(tt.wantErr, err, tt.name) }) } }