public void HandleMessageFailed() { var scheduleId = Guid.NewGuid(); var ravenDocStore = MockRepository.GenerateMock<IRavenDocStore>(); ravenDocStore.Expect(r => r.GetStore()).Return(DocumentStore); var tracker = new ScheduleTracker { RavenStore = ravenDocStore }; using (var session = DocumentStore.OpenSession()) { session.Store(new ScheduleTrackingData { ScheduleId = scheduleId, MessageStatus = MessageStatus.Scheduled }, scheduleId.ToString()); session.SaveChanges(); } var scheduleFailed = new ScheduledSmsFailed { ScheduledSmsId = scheduleId }; tracker.Handle(scheduleFailed); using (var session = DocumentStore.OpenSession()) { var scheduleTracking = session.Load<ScheduleTrackingData>(scheduleId.ToString()); Assert.That(scheduleTracking.MessageStatus, Is.EqualTo(MessageStatus.Failed)); } }
public void CoordinateMessagesOneMessageFailed() { var coordinatorId = Guid.NewGuid(); const string updatedNumber = "04040044"; using (var session = DocumentStore.OpenSession()) { var message = new CoordinatorCreated { CoordinatorId = coordinatorId, ScheduledMessages = new List<MessageSchedule> { new MessageSchedule { Number = updatedNumber, ScheduledTimeUtc = DateTime.Now.AddMinutes(5)}, new MessageSchedule { Number = "07777777", ScheduledTimeUtc = DateTime.Now.AddMinutes(10)} } }; var coordinatorTrackingData = new CoordinatorTrackingData { CoordinatorId = message.CoordinatorId, MessageStatuses = message.ScheduledMessages .Select(s => new MessageSendingStatus { Number = s.Number, ScheduledSendingTimeUtc = s.ScheduledTimeUtc }). ToList() }; session.Store(coordinatorTrackingData, message.CoordinatorId.ToString()); session.SaveChanges(); } var messageFailed = new ScheduledSmsFailed { CoordinatorId = coordinatorId, Number = updatedNumber, SmsFailedData = new SmsFailed(string.Empty, string.Empty, string.Empty, string.Empty, string.Empty) }; var ravenDocStore = MockRepository.GenerateMock<IRavenDocStore>(); ravenDocStore.Expect(r => r.GetStore()).Return(DocumentStore); var coordinatorTracker = new ScheduleTracker { RavenStore = ravenDocStore }; coordinatorTracker.Handle(messageFailed); using (var session = DocumentStore.OpenSession()) { var trackingData = session.Load<CoordinatorTrackingData>(coordinatorId.ToString()); var updatedMessageData = trackingData.MessageStatuses.First(m => m.Number == updatedNumber); Assert.That(updatedMessageData.Status, Is.EqualTo(MessageStatusTracking.CompletedFailure)); Assert.That(updatedMessageData.ActualSentTimeUtc, Is.Null); Assert.That(updatedMessageData.Cost, Is.Null); Assert.That(updatedMessageData.FailureData.Message, Is.EqualTo(messageFailed.SmsFailedData.Message)); Assert.That(updatedMessageData.FailureData.MoreInfo, Is.EqualTo(messageFailed.SmsFailedData.MoreInfo)); } }