Fix tests for worker

This commit is contained in:
ErickSkrauch 2020-04-15 17:52:13 +03:00
parent c9f6079d90
commit 0c81494559
No known key found for this signature in database
GPG Key ID: 669339FCBB30EE0E
2 changed files with 9 additions and 4 deletions

View File

@ -20,7 +20,7 @@ type UUIDsWorker struct {
} }
func (ctx *UUIDsWorker) CreateHandler() *mux.Router { func (ctx *UUIDsWorker) CreateHandler() *mux.Router {
requestEventsMiddleware := CreateRequestEventsMiddleware(ctx.Emitter, "skinsystem") requestEventsMiddleware := CreateRequestEventsMiddleware(ctx.Emitter, "skinsystem") // This prefix should be unified
router := mux.NewRouter().StrictSlash(true) router := mux.NewRouter().StrictSlash(true)
router.Use(requestEventsMiddleware) router.Use(requestEventsMiddleware)
@ -39,7 +39,6 @@ func (ctx *UUIDsWorker) GetUUID(response http.ResponseWriter, request *http.Requ
username := parseUsername(mux.Vars(request)["username"]) username := parseUsername(mux.Vars(request)["username"])
profile, err := ctx.UUIDsProvider.GetUuid(username) profile, err := ctx.UUIDsProvider.GetUuid(username)
if err != nil { if err != nil {
ctx.Emit("uuids_provider:error", err) // TODO: do I need emitter here?
if _, ok := err.(*mojang.TooManyRequestsError); ok { if _, ok := err.(*mojang.TooManyRequestsError); ok {
response.WriteHeader(http.StatusTooManyRequests) response.WriteHeader(http.StatusTooManyRequests)
return return

View File

@ -87,6 +87,8 @@ var getUuidTestsCases = []*uuidsWorkerTestCase{
{ {
Name: "Success provider response", Name: "Success provider response",
BeforeTest: func(suite *uuidsWorkerTestSuite) { BeforeTest: func(suite *uuidsWorkerTestSuite) {
suite.Emitter.On("Emit", "skinsystem:before_request", mock.Anything)
suite.Emitter.On("Emit", "skinsystem:after_request", mock.Anything, 200)
suite.UuidsProvider.On("GetUuid", "mock_username").Return(&mojang.ProfileInfo{ suite.UuidsProvider.On("GetUuid", "mock_username").Return(&mojang.ProfileInfo{
Id: "0fcc38620f1845f3a54e1b523c1bd1c7", Id: "0fcc38620f1845f3a54e1b523c1bd1c7",
Name: "mock_username", Name: "mock_username",
@ -105,6 +107,8 @@ var getUuidTestsCases = []*uuidsWorkerTestCase{
{ {
Name: "Receive empty response from UUIDs provider", Name: "Receive empty response from UUIDs provider",
BeforeTest: func(suite *uuidsWorkerTestSuite) { BeforeTest: func(suite *uuidsWorkerTestSuite) {
suite.Emitter.On("Emit", "skinsystem:before_request", mock.Anything)
suite.Emitter.On("Emit", "skinsystem:after_request", mock.Anything, 204)
suite.UuidsProvider.On("GetUuid", "mock_username").Return(nil, nil) suite.UuidsProvider.On("GetUuid", "mock_username").Return(nil, nil)
}, },
AfterTest: func(suite *uuidsWorkerTestSuite, response *http.Response) { AfterTest: func(suite *uuidsWorkerTestSuite, response *http.Response) {
@ -116,9 +120,10 @@ var getUuidTestsCases = []*uuidsWorkerTestCase{
{ {
Name: "Receive error from UUIDs provider", Name: "Receive error from UUIDs provider",
BeforeTest: func(suite *uuidsWorkerTestSuite) { BeforeTest: func(suite *uuidsWorkerTestSuite) {
suite.Emitter.On("Emit", "skinsystem:before_request", mock.Anything)
suite.Emitter.On("Emit", "skinsystem:after_request", mock.Anything, 500)
err := errors.New("this is an error") err := errors.New("this is an error")
suite.UuidsProvider.On("GetUuid", "mock_username").Return(nil, err) suite.UuidsProvider.On("GetUuid", "mock_username").Return(nil, err)
suite.Emitter.On("Emit", "uuids_provider:error", err).Times(1)
}, },
AfterTest: func(suite *uuidsWorkerTestSuite, response *http.Response) { AfterTest: func(suite *uuidsWorkerTestSuite, response *http.Response) {
suite.Equal(500, response.StatusCode) suite.Equal(500, response.StatusCode)
@ -132,9 +137,10 @@ var getUuidTestsCases = []*uuidsWorkerTestCase{
{ {
Name: "Receive Too Many Requests from UUIDs provider", Name: "Receive Too Many Requests from UUIDs provider",
BeforeTest: func(suite *uuidsWorkerTestSuite) { BeforeTest: func(suite *uuidsWorkerTestSuite) {
suite.Emitter.On("Emit", "skinsystem:before_request", mock.Anything)
suite.Emitter.On("Emit", "skinsystem:after_request", mock.Anything, 429)
err := &mojang.TooManyRequestsError{} err := &mojang.TooManyRequestsError{}
suite.UuidsProvider.On("GetUuid", "mock_username").Return(nil, err) suite.UuidsProvider.On("GetUuid", "mock_username").Return(nil, err)
suite.Emitter.On("Emit", "uuids_provider:error", err).Times(1)
}, },
AfterTest: func(suite *uuidsWorkerTestSuite, response *http.Response) { AfterTest: func(suite *uuidsWorkerTestSuite, response *http.Response) {
suite.Equal(429, response.StatusCode) suite.Equal(429, response.StatusCode)