Add unit test for delete object handler

This commit is contained in:
Lena Fuhrimann 2017-04-03 08:44:09 +02:00
parent 6273ee201c
commit 42dc5a3dec
2 changed files with 52 additions and 1 deletions

View file

@ -20,6 +20,6 @@ func DeleteHandler(s3 datasources.S3Client) http.Handler {
return return
} }
w.WriteHeader(http.StatusOK) w.WriteHeader(http.StatusNoContent)
}) })
} }

View file

@ -0,0 +1,51 @@
package objects_test
import (
"errors"
"net/http"
"net/http/httptest"
"testing"
"github.com/mastertinner/s3-manager/mock"
"github.com/mastertinner/s3-manager/objects"
"github.com/stretchr/testify/assert"
)
func TestDeleteHandler(t *testing.T) {
assert := assert.New(t)
tests := []struct {
description string
s3Client *mock.S3Client
expectedStatusCode int
expectedBody string
}{
{
description: "success",
s3Client: &mock.S3Client{},
expectedStatusCode: http.StatusNoContent,
expectedBody: "",
},
{
description: "s3 error",
s3Client: &mock.S3Client{
Err: errors.New("internal S3 error"),
},
expectedStatusCode: http.StatusInternalServerError,
expectedBody: "error removing object\n",
},
}
for _, tc := range tests {
req, err := http.NewRequest("DELETE", "/api/buckets/bucketName/objects/objectName", nil)
assert.NoError(err)
rr := httptest.NewRecorder()
handler := objects.DeleteHandler(tc.s3Client)
handler.ServeHTTP(rr, req)
assert.Equal(tc.expectedStatusCode, rr.Code, tc.description)
assert.Equal(tc.expectedBody, rr.Body.String(), tc.description)
}
}