It("logs the error and continues", func() { response := models.EvacuationResponse{} err := response.Unmarshal(responseRecorder.Body.Bytes()) Expect(err).NotTo(HaveOccurred()) Expect(response.KeepContainer).To(BeFalse()) Expect(response.Error).To(BeNil()) Expect(logger).To(gbytes.Say("failed-removing-evacuating-actual-lrp")) }) }) Context("when crashing the actual lrp fails", func() { Context("when the DB returns an unrecoverable error", func() { BeforeEach(func() { fakeActualLRPDB.CrashActualLRPReturns(nil, nil, false, models.NewUnrecoverableError(nil)) }) It("logs and writes to the exit channel", func() { Eventually(logger).Should(gbytes.Say("unrecoverable-error")) Eventually(exitCh).Should(Receive()) }) }) Context("because the error does not exist", func() { BeforeEach(func() { fakeActualLRPDB.CrashActualLRPReturns(nil, nil, false, models.ErrResourceNotFound) }) It("does not return an error or keep the container", func() { response := models.EvacuationResponse{}