def test_outgoing_failure_indefinite_retry(self, process_sms_delay_mock, enqueue_directly_mock): timestamp = datetime(2016, 1, 1, 12, 0) RETRY_SMS_INDEFINITELY.set(self.domain, True, NAMESPACE_DOMAIN) with patch_datetime_api(timestamp): send_sms(self.domain, None, '+999123', 'test outgoing') self.assertEqual(enqueue_directly_mock.call_count, 1) self.assertEqual(self.queued_sms_count, 1) self.assertEqual(self.reporting_sms_count, 0) for i in range(settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS): queued_sms = self.get_queued_sms() self.assertEqual(queued_sms.domain, self.domain) self.assertEqual(queued_sms.phone_number, '+999123') self.assertEqual(queued_sms.text, 'test outgoing') self.assertEqual(queued_sms.datetime_to_process, timestamp) self.assertEqual(queued_sms.processed, False) self.assertEqual(queued_sms.error, False) self.assertEqual(queued_sms.num_processing_attempts, i) with patch_failed_send() as send_mock, patch_datetime_tasks(timestamp + timedelta(seconds=1)): process_sms(queued_sms.pk) self.assertEqual(process_sms_delay_mock.call_count, 0) self.assertBillableDoesNotExist(queued_sms.couch_id) self.assertEqual(send_mock.call_count, 1) self.assertEqual(self.queued_sms_count, 1) self.assertEqual(self.reporting_sms_count, 0) timestamp += timedelta(minutes=settings.SMS_QUEUE_REPROCESS_INTERVAL) timestamp += ( timedelta(minutes=settings.SMS_QUEUE_REPROCESS_INDEFINITELY_INTERVAL) - timedelta(minutes=settings.SMS_QUEUE_REPROCESS_INTERVAL) ) queued_sms = self.get_queued_sms() self.assertEqual(queued_sms.domain, self.domain) self.assertEqual(queued_sms.phone_number, '+999123') self.assertEqual(queued_sms.text, 'test outgoing') self.assertEqual(queued_sms.datetime_to_process, timestamp) self.assertEqual(queued_sms.processed, False) self.assertEqual(queued_sms.error, False) self.assertEqual(queued_sms.num_processing_attempts, settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS) with patch_successful_send() as send_mock, patch_datetime_tasks(timestamp + timedelta(seconds=1)): process_sms(queued_sms.pk) self.assertEqual(send_mock.call_count, 1) self.assertEqual(self.queued_sms_count, 0) self.assertEqual(self.reporting_sms_count, 1) reporting_sms = self.get_reporting_sms() self.assertEqual(reporting_sms.processed, True) self.assertEqual(reporting_sms.error, False) self.assertEqual(reporting_sms.num_processing_attempts, settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS + 1) self.assertEqual(process_sms_delay_mock.call_count, 0) self.assertBillableExists(reporting_sms.couch_id)
def handle_unsuccessful_processing_attempt(msg): msg.num_processing_attempts += 1 if msg.num_processing_attempts < settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS: delay_processing(msg, settings.SMS_QUEUE_REPROCESS_INTERVAL) elif msg.direction == OUTGOING and RETRY_SMS_INDEFINITELY.enabled(msg.domain): delay_processing(msg, settings.SMS_QUEUE_REPROCESS_INDEFINITELY_INTERVAL) else: msg.set_system_error(SMS.ERROR_TOO_MANY_UNSUCCESSFUL_ATTEMPTS) remove_from_queue(msg)
def test_outgoing_failure_indefinite_retry(self, process_sms_delay_mock, enqueue_directly_mock): timestamp = datetime(2016, 1, 1, 12, 0) RETRY_SMS_INDEFINITELY.set(self.domain, True, NAMESPACE_DOMAIN) with patch_datetime_api(timestamp): send_sms(self.domain, None, '+999123', 'test outgoing') self.assertEqual(enqueue_directly_mock.call_count, 1) self.assertEqual(self.queued_sms_count, 1) self.assertEqual(self.reporting_sms_count, 0) for i in range(settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS): queued_sms = self.get_queued_sms() self.assertEqual(queued_sms.domain, self.domain) self.assertEqual(queued_sms.phone_number, '+999123') self.assertEqual(queued_sms.text, 'test outgoing') self.assertEqual(queued_sms.datetime_to_process, timestamp) self.assertEqual(queued_sms.processed, False) self.assertEqual(queued_sms.error, False) self.assertEqual(queued_sms.num_processing_attempts, i) with patch_failed_send() as send_mock, patch_datetime_tasks( timestamp + timedelta(seconds=1)): process_sms(queued_sms.pk) self.assertEqual(process_sms_delay_mock.call_count, 0) self.assertBillableDoesNotExist(queued_sms.couch_id) self.assertEqual(send_mock.call_count, 1) self.assertEqual(self.queued_sms_count, 1) self.assertEqual(self.reporting_sms_count, 0) timestamp += timedelta( minutes=settings.SMS_QUEUE_REPROCESS_INTERVAL) timestamp += (timedelta( minutes=settings.SMS_QUEUE_REPROCESS_INDEFINITELY_INTERVAL) - timedelta(minutes=settings.SMS_QUEUE_REPROCESS_INTERVAL)) queued_sms = self.get_queued_sms() self.assertEqual(queued_sms.domain, self.domain) self.assertEqual(queued_sms.phone_number, '+999123') self.assertEqual(queued_sms.text, 'test outgoing') self.assertEqual(queued_sms.datetime_to_process, timestamp) self.assertEqual(queued_sms.processed, False) self.assertEqual(queued_sms.error, False) self.assertEqual(queued_sms.num_processing_attempts, settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS) with patch_successful_send() as send_mock, patch_datetime_tasks( timestamp + timedelta(seconds=1)): process_sms(queued_sms.pk) self.assertEqual(send_mock.call_count, 1) self.assertEqual(self.queued_sms_count, 0) self.assertEqual(self.reporting_sms_count, 1) reporting_sms = self.get_reporting_sms() self.assertEqual(reporting_sms.processed, True) self.assertEqual(reporting_sms.error, False) self.assertEqual(reporting_sms.num_processing_attempts, settings.SMS_QUEUE_MAX_PROCESSING_ATTEMPTS + 1) self.assertEqual(process_sms_delay_mock.call_count, 0) self.assertBillableExists(reporting_sms.couch_id)