def test_filters_is_overdue(self): today = datetime.now(pytz.utc).date() yesterday = today - timedelta(days=1) tomorrow = today + timedelta(days=1) customer = CustomerFactory() payment_unpaid_overdue = PaymentFactory.create( customer=customer, due_date=yesterday, status=Payment.Status.Unpaid) payment_unpaied_not_due = PaymentFactory.create( customer=customer, due_date=tomorrow, status=Payment.Status.Unpaid) payment_paid_not_due = PaymentFactory.create( customer=payment_unpaid_overdue.customer, due_date=tomorrow, status=Payment.Status.Paid) payment_canceled = PaymentFactory.create( customer=customer, due_date=yesterday, status=Payment.Status.Canceled) url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) overdue_url = url + '?is_overdue=True' not_overdue_url = url + '?is_overdue=False' self.assert_get_data(overdue_url, [payment_unpaid_overdue]) self.assert_get_data( not_overdue_url, [payment_unpaied_not_due, payment_paid_not_due, payment_canceled])
def test_filter_visible(self): customer = CustomerFactory() payment_visible = PaymentFactory.create(customer=customer, visible=True) payment_not_visible = PaymentFactory.create(customer=customer, visible=False) url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) visible_url = url + '?visible=True' not_visible_url = url + '?visible=False' self.assert_get_data(visible_url, [payment_visible]) self.assert_get_data(not_visible_url, [payment_not_visible])
def test_filter_disabled(self): customer = CustomerFactory.create() payment = PaymentFactory.create(customer=customer, amount=100) payment_method = PaymentMethodFactory.create( payment_processor='someprocessor', customer=customer) transaction = TransactionFactory.create(payment_method=payment_method, payment=payment, disabled=False) transaction_data = self._transaction_data(customer, payment, payment_method, transaction) urls = [ reverse('payment-method-transaction-list', kwargs={ 'customer_pk': customer.pk, 'payment_method_id': payment_method.pk }), reverse('transaction-list', kwargs={'customer_pk': customer.pk}) ] for url in urls: url_not_disabled = url + '?disabled=False' url_no_output = url + '?disabled=True' response = self.client.get(url_not_disabled, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data[0], transaction_data) response = self.client.get(url_no_output, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data, [])
def test_create_one_without_required_fields(self): customer = CustomerFactory.create() payment_method = PaymentMethodFactory.create(customer=customer) payment = PaymentFactory.create(customer=customer) transaction = TransactionFactory.create(payment_method=payment_method, payment=payment) valid_until = datetime.now() url = reverse('transaction-detail', kwargs={ 'customer_pk': customer.id, 'transaction_uuid': transaction.uuid }) data = { 'payment': reverse('payment-detail', kwargs={ 'customer_pk': customer.id, 'payment_pk': payment.id }), 'valid_until': valid_until } url = reverse('payment-method-transaction-list', kwargs={ 'customer_pk': customer.id, 'payment_method_id': payment_method.id }) response = self.client.post(url, format='json', data=data) self.assertEqual(response.data['payment_method'], ['This field is required.'])
def test_patch_other_than_status_fail_and_get(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) initial_payment = self.client.get(url, content_type='application/json').data data = {'amount': 100.00, 'currency': u'RON'} self.client.patch(url, json.dumps(data), content_type='application/json') response = self.client.get(url, content_type='application/json') assert response.status_code == status.HTTP_200_OK assert response.data == initial_payment
def test_get_payment_detail(self): payment = PaymentFactory.create() payment.amount = Decimal('10.00') payment.save() customer = payment.customer proforma = payment.proforma invoice = payment.invoice provider = payment.provider url = reverse( 'payment-detail', kwargs={'customer_pk': payment.customer.pk, 'payment_pk': payment.pk} ) response = self.client.get(url, format='json') assert response.status_code == status.HTTP_200_OK assert response.data == { 'customer': 'http://testserver/customers/%d/' % customer.pk, 'provider': 'http://testserver/providers/%d/' % provider.pk, 'due_date': None, 'url': 'http://testserver/customers/%d/payments/%d/' % ( customer.pk, payment.pk ), 'proforma': 'http://testserver/proformas/%d/' % proforma.pk, 'visible': True, 'amount': u'10.00', 'currency': 'USD', 'status': 'unpaid', 'invoice': 'http://testserver/invoices/%d/' % invoice.pk, 'id': payment.pk, }
def test_final_status_failed_update(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) initial_payment = self.client.get(url, content_type='application/json').data initial_currency = initial_payment['currency'] for final_status in Payment.Status.FinalStatuses: payment.status = final_status payment.save() data = {'currency': 'DZD'} self.client.patch(url, json.dumps(data), content_type='application/json') response = self.client.get(url, content_type='application/json') assert response.status_code == status.HTTP_200_OK assert response.data.get('currency') == initial_currency
def test_valid_status_transition_from_unpaid_to_paid(self): process_mock = MagicMock() fail_mock = MagicMock() succeed_mock = MagicMock() cancel_mock = MagicMock() with patch.multiple('silver.models.payments.Payment', process=process_mock, fail=fail_mock, succeed=succeed_mock, cancel=cancel_mock): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) data = {'status': payment.Status.Paid} response = self.client.patch(url, json.dumps(data), content_type='application/json') assert response.status_code == status.HTTP_200_OK assert succeed_mock.call_count == 1
def test_modify_one(self): customer = CustomerFactory.create() payment_method = PaymentMethodFactory.create(customer=customer) payment = PaymentFactory.create(customer=customer) transaction_1 = TransactionFactory.create( payment_method=payment_method, payment=payment) valid_until = datetime.now() url = reverse('transaction-detail', kwargs={ 'customer_pk': customer.id, 'transaction_uuid': transaction_1.uuid }) data = { 'payment': reverse('payment-detail', kwargs={ 'customer_pk': customer.id, 'payment_pk': payment_method.id }), 'valid_until': valid_until } response = self.client.put(url, format='json', data=data) self.assertEqual(response.data['detail'], 'Method "PUT" not allowed.') response = self.client.post(url, format='json', data=data) self.assertEqual(response.data['detail'], 'Method "POST" not allowed.') response = self.client.patch(url, format='json', data=data) self.assertEqual(response.data['detail'], 'Method "PATCH" not allowed.')
def test_canceled_status_payment_no_updates_on_get(self): payment = PaymentFactory.create() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) payment.status = payment.Status.Canceled payment.save() initial_payment = self.client.get(url, content_type='application/json').data data = { 'due_date': '2016-10-20', 'visible': False, } self.client.patch(url, json.dumps(data), content_type='application/json') response = self.client.get(url, content_type='application/json') assert response.status_code == status.HTTP_200_OK assert response.data == initial_payment
def test_patch_payment(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) final_payment = self.client.get(url, content_type='application/json').data final_payment['status'] = 'paid' data = {'status': payment.Status.Paid} response = self.client.patch(url, json.dumps(data), content_type='application/json') assert response.status_code == status.HTTP_200_OK assert response.data == final_payment
def test_patch_other_than_status_fail(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) data = {'amount': 100.00, 'currency': u'RON'} response = self.client.patch(url, json.dumps(data), content_type='application/json') assert response.status_code == status.HTTP_400_BAD_REQUEST assert response.data == { u'non_field_errors': [ u"Existing payments only accept updating their status. [u'amount', u'currency'] given." ] }
def test_put_payment_not_allowed(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) data = { 'customer': 'http://testserver/customers/%d/' % payment.customer.pk, 'amount': 0.10, 'currency': 'RON', 'provider': 'http://testserver/providers/%d/' % payment.provider.pk } response = self.client.put(url, json.dumps(data), content_type='application/json') assert response.status_code == status.HTTP_405_METHOD_NOT_ALLOWED assert response.data == {u'detail': u'Method "PUT" not allowed.'}
def test_put_payment_not_allowed_get(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) initial_payment = self.client.get(url, content_type='application/json').data data = { 'customer': 'http://testserver/customers/%d/' % payment.customer.pk, 'amount': 0.10, 'currency': 'RON', 'provider': 'http://testserver/providers/%d/' % payment.provider.pk } self.client.put(url, json.dumps(data), content_type='application/json') response = self.client.get(url, content_type='application/json') assert response.status_code == status.HTTP_200_OK assert response.data == initial_payment
def test_get_after_valid_status_transition_from_unpaid_to_paid(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse('payment-detail', kwargs={ 'customer_pk': payment.customer.pk, 'payment_pk': payment.pk }) data = {'status': payment.Status.Paid} self.client.patch(url, json.dumps(data), content_type='application/json') response = self.client.get(url, content_type='application/json') assert response.status_code == status.HTTP_200_OK assert response.data.get('status') == 'paid'
def test_filter_flow(self): customer = CustomerFactory() payment_flow_invoice = PaymentFactory.create( customer=customer, provider__flow=Provider.FLOWS.INVOICE) payment_flow_proforma = PaymentFactory.create( customer=customer, provider__flow=Provider.FLOWS.PROFORMA) url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) invoice_url = url + '?flow=' + Provider.FLOWS.INVOICE proforma_url = url + '?flow=' + Provider.FLOWS.PROFORMA url_no_output = url + '?flow=RANDOM' self.assert_get_data(invoice_url, [payment_flow_invoice]) self.assert_get_data(proforma_url, [payment_flow_proforma]) self.assert_get_data(url_no_output, [])
def test_filters_currency(self): customer = CustomerFactory() payment_usd = PaymentFactory.create(customer=customer, currency='USD') payment_std = PaymentFactory.create(customer=customer, currency='STD') url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) url_usd_iexact = url + '?currency=UsD' url_usd_exact = url + '?currency=USD' url_std = url + '?currency=STD' url_no_output = url + '?currency=RANDOM' self.assert_get_data(url_usd_iexact, [payment_usd]) self.assert_get_data(url_usd_exact, [payment_usd]) self.assert_get_data(url_std, [payment_std]) self.assert_get_data(url_no_output, [])
def test_filter_status(self): customer = CustomerFactory() payment_paid_status = PaymentFactory.create(customer=customer, status=Payment.Status.Paid) payment_canceled_status = PaymentFactory.create( customer=customer, status=Payment.Status.Canceled) url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) url_paid_only = url + '?status=' + Payment.Status.Paid url_canceled_only = url + '?status=' + Payment.Status.Canceled url_no_output = url + '?status=RANDOM' self.assert_get_data(url_paid_only, [payment_paid_status]) self.assert_get_data(url_canceled_only, [payment_canceled_status]) self.assert_get_data(url_no_output, [])
def test_filters_min_max_amount(self): customer = CustomerFactory() payment_below_min = PaymentFactory.create(customer=customer, amount=9.99) payment_min = PaymentFactory.create(customer=customer, amount=10.00) payment_above_min = PaymentFactory.create(customer=customer, amount=10.01) payment_center = PaymentFactory.create(customer=customer, amount=60) payment_below_max = PaymentFactory.create(customer=customer, amount=99.99) payment_max = PaymentFactory.create(customer=customer, amount=100.00) payment_above_max = PaymentFactory.create(customer=customer, amount=100.01) url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) url_range_slice = url + '?min_amount=10&max_amount=100' url_range_all_entries = url + '?min_amount=9.99&max_amount=100.01' url_exact_amount = url + '?min_amount=60&max_amount=60' url_no_intersection = url + '?min_amount=100&max_amount=0' self.assert_get_data(url_range_slice, [ payment_min, payment_above_min, payment_center, payment_below_max, payment_max ]) self.assert_get_data(url_range_all_entries, [ payment_below_min, payment_min, payment_above_min, payment_center, payment_below_max, payment_max, payment_above_max ]) self.assert_get_data(url_exact_amount, [payment_center]) self.assert_get_data(url_no_intersection, [])
def test_get_payment_list(self): initial_payment = PaymentFactory.create() initial_payment.amount = Decimal('10.00') initial_payment.save() customer = initial_payment.customer proforma = initial_payment.proforma invoice = initial_payment.invoice provider = initial_payment.provider url = reverse( 'payment-list', kwargs={'customer_pk': initial_payment.customer.pk} ) response = self.client.get(url, format='json') assert response.status_code == status.HTTP_200_OK assert response.data == [OrderedDict([ ('id', initial_payment.pk), ('url', 'http://testserver/customers/%d/payments/%d/' % ( customer.pk, initial_payment.pk )), ('customer', 'http://testserver/customers/%d/' % customer.pk), ('provider', 'http://testserver/providers/%d/' % provider.pk), ('amount', u'10.00'), ('currency', 'USD'), ('due_date', None), ('status', 'unpaid'), ('visible', True), ('proforma', 'http://testserver/proformas/%d/' % proforma.pk), ('invoice', 'http://testserver/invoices/%d/' % invoice.pk) ])] payments = PaymentFactory.create_batch(2) for payment in payments: payment.customer = initial_payment.customer payment.save() response = self.client.get(url, format='json') assert response.status_code == status.HTTP_200_OK assert len(response.data) == 3
def test_pay_documents_on_payment_succeed(self): payment = PaymentFactory.create() with patch.object(Invoice, '_save_pdf', return_value=None), \ patch.object(Proforma, '_save_pdf', return_value=None): payment.invoice.issue() payment.succeed() assert payment.status == Payment.Status.Paid assert payment.invoice.state == BillingDocument.STATES.PAID
def test_filter_provider(self): customer = CustomerFactory() payment = PaymentFactory.create(customer=customer, provider__name='Gigel') url = reverse('payment-list', kwargs={'customer_pk': customer.pk}) iexact_url = url + '?provider=gigel' exact_url = url + '?provider=Gigel' url_no_output = url + '?provider=RANDOM' self.assert_get_data(iexact_url, [payment]) self.assert_get_data(exact_url, [payment]) self.assert_get_data(url_no_output, [])
def test_payment_overdue_since_last_month_queryset(self): payments = PaymentFactory.create_batch(3) payments[0].due_date = date.today().replace(day=1) payments[0].save() payments[1].status = Payment.Status.Pending payments[1].due_date = date.today().replace(day=1) payments[1].save() payments[2].status = Payment.Status.Unpaid payments[2].due_date = date.today() - timedelta(days=31) payments[2].save() queryset = Payment.objects.overdue_since_last_month() assert queryset.count() == 1 assert payments[2] in queryset
def test_payment_overdue_queryset(self): payments = PaymentFactory.create_batch(3) payments[0].due_date = date.today() - timedelta(days=1) payments[0].save() payments[1].status = Payment.Status.Pending payments[1].due_date = date.today() - timedelta(days=3) payments[1].save() payments[2].status = Payment.Status.Paid payments[2].due_date = date.today() - timedelta(days=31) payments[2].save() queryset = Payment.objects.overdue() assert queryset.count() == 2 for payment in payments[0:1]: assert payment in queryset
def test_add_transaction(self): customer = CustomerFactory.create() payment_method = PaymentMethodFactory.create(customer=customer) payment = PaymentFactory.create(customer=customer) valid_until = datetime.now() payment_method_url = reverse('payment-method-detail', kwargs={ 'customer_pk': customer.pk, 'payment_method_id': payment_method.id }) payment_url = reverse('payment-detail', kwargs={ 'customer_pk': customer.pk, 'payment_pk': payment.pk }) url = reverse('payment-method-transaction-list', kwargs={ 'customer_pk': customer.pk, 'payment_method_id': payment_method.pk }) data = { 'payment_method': reverse('payment-method-detail', kwargs={ 'customer_pk': customer.pk, 'payment_method_id': payment_method.id }), 'payment': reverse('payment-detail', kwargs={ 'customer_pk': customer.pk, 'payment_pk': payment.pk }), 'valid_until': valid_until } response = self.client.post(url, format='json', data=data).data self.assertEqual(response['payment_method'], payment_method_url) self.assertEqual(response['payment'], payment_url) self.assertEqual(response['valid_until'][:-1], valid_until.isoformat()) self.assertEqual(response['is_usable'], False)
def test_filter_min_max_amount(self): customer = CustomerFactory.create() payment = PaymentFactory.create(customer=customer, amount=100) payment_method_ok = PaymentMethodFactory.create( payment_processor='someprocessor', customer=customer) transaction = TransactionFactory.create( payment_method=payment_method_ok, payment=payment) transaction_data = self._transaction_data(customer, payment, payment_method_ok, transaction) urls = [ reverse('payment-method-transaction-list', kwargs={ 'customer_pk': customer.pk, 'payment_method_id': payment_method_ok.pk }), reverse('transaction-list', kwargs={'customer_pk': customer.pk}) ] for url in urls: url_with_filterable_data = url + '?min_amount=10' url_no_output = url + '?min_amount=150' response = self.client.get(url_with_filterable_data, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data[0], transaction_data) response = self.client.get(url_no_output, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data, []) url_with_filterable_data = url + '?max_amount=1050' url_no_output = url + '?max_amount=10' response = self.client.get(url_with_filterable_data, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data[0], transaction_data) response = self.client.get(url_no_output, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data, [])
def test_transaction_list(self): customer = CustomerFactory.create() payment_method = PaymentMethodFactory.create(customer=customer) payment = PaymentFactory.create(customer=customer) transaction_1 = TransactionFactory.create( payment_method=payment_method, payment=payment) expected_t1 = self._transaction_data(customer, payment, payment_method, transaction_1) transaction_2 = TransactionFactory.create( payment_method=payment_method, payment=payment) expected_t2 = self._transaction_data(customer, payment, payment_method, transaction_2) url = reverse('transaction-list', kwargs={'customer_pk': customer.pk}) response = self.client.get(url, format='json') self.assertEqual(response.data[0], expected_t1) self.assertEqual(response.data[1], expected_t2)
def test_patch_payment(self): payment = PaymentFactory.create() invoice = payment.invoice proforma = payment.proforma invoice.proforma = proforma invoice.save() payment.provider = invoice.provider payment.customer = invoice.customer payment.save() url = reverse( 'payment-detail', kwargs={'customer_pk': payment.customer.pk, 'payment_pk': payment.pk} ) data = { 'due_date': '2016-10-20', 'visible': False, 'amount': 330.00, 'currency': 'RON', } response = self.client.patch( url, json.dumps(data), content_type='application/json' ) assert response.status_code == status.HTTP_200_OK assert response.data == { 'customer': u'http://testserver/customers/%d/' % payment.customer.pk, 'due_date': '2016-10-20', 'visible': False, 'url': u'http://testserver/customers/%d/payments/%d/' % (payment.customer.pk, payment.pk), 'currency': u'RON', 'amount': u'330.00', 'status': 'unpaid', 'proforma': u'http://testserver/proformas/%d/' % proforma.pk, 'invoice': u'http://testserver/invoices/%d/' % invoice.pk, 'provider': u'http://testserver/providers/%d/' % payment.provider.pk, 'id': payment.pk }
def test_payment_due_this_month_queryset(self): payments = PaymentFactory.create_batch(4) payments[0].due_date = date.today().replace(day=20) payments[0].save() payments[1].status = Payment.Status.Pending payments[1].due_date = date.today().replace(day=1) payments[1].save() payments[2].due_date = date.today() - timedelta(days=31) payments[2].save() payments[3].status = Payment.Status.Canceled payments[3].save() queryset = Payment.objects.due_this_month() assert queryset.count() == 2 for payment in payments[0:1]: assert payment in queryset
def test_filter_payment_method(self): customer = CustomerFactory.create() payment = PaymentFactory.create(customer=customer) payment_method = PaymentMethodFactory.create( payment_processor='someprocessor', customer=customer) transaction1 = TransactionFactory.create(payment_method=payment_method, payment=payment) transaction_data_1 = self._transaction_data(customer, payment, payment_method, transaction1) transaction2 = TransactionFactory.create(payment_method=payment_method, payment=payment) transaction_data_2 = self._transaction_data(customer, payment, payment_method, transaction2) urls = [ reverse('payment-method-transaction-list', kwargs={ 'customer_pk': customer.pk, 'payment_method_id': payment_method.pk }), reverse('transaction-list', kwargs={'customer_pk': customer.pk}) ] for url in urls: url_method_someprocessor = url + '?payment_method=someprocessor' url_no_output = url + '?payment_method=Random' response = self.client.get(url_method_someprocessor, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data[0], transaction_data_1) self.assertEqual(response.data[1], transaction_data_2) response = self.client.get(url_no_output, format='json') self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.data, [])