} }) JustBeforeEach(func() { request = newTestRequest(requestBody) handler.FailActualLRP(responseRecorder, request) }) Context("when failing the actual lrp in the DB succeeds", func() { BeforeEach(func() { fakeActualLRPDB.FailActualLRPReturns(nil) }) It("fails the actual lrp by process guid and index", func() { Expect(fakeActualLRPDB.FailActualLRPCallCount()).To(Equal(1)) _, actualKey, actualErrorMessage := fakeActualLRPDB.FailActualLRPArgsForCall(0) Expect(*actualKey).To(Equal(key)) Expect(actualErrorMessage).To(Equal(errorMessage)) Expect(responseRecorder.Code).To(Equal(http.StatusOK)) response := &models.ActualLRPLifecycleResponse{} err := response.Unmarshal(responseRecorder.Body.Bytes()) Expect(err).NotTo(HaveOccurred()) Expect(response.Error).To(BeNil()) }) }) Context("when failing the actual lrp fails", func() { BeforeEach(func() {
request = newTestRequest(requestBody) handler.FailActualLRP(responseRecorder, request) }) Context("when failing the actual lrp in the DB succeeds", func() { BeforeEach(func() { fakeActualLRPDB.FailActualLRPReturns(nil) }) It("responds with 204 No Content", func() { Expect(responseRecorder.Code).To(Equal(http.StatusNoContent)) }) It("fails the actual lrp by process guid and index", func() { Expect(fakeActualLRPDB.FailActualLRPCallCount()).To(Equal(1)) _, actualRequest := fakeActualLRPDB.FailActualLRPArgsForCall(0) Expect(actualRequest).To(Equal(requestBody)) }) }) Context("when the request is invalid", func() { BeforeEach(func() { requestBody = &models.FailActualLRPRequest{} }) It("responds with 400 Bad Request", func() { Expect(responseRecorder.Code).To(Equal(http.StatusBadRequest)) }) }) Context("when parsing the body fails", func() {