88 lines
3.9 KiB
Python
88 lines
3.9 KiB
Python
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
|
|
|
from unittest.mock import patch
|
|
|
|
from odoo.exceptions import ValidationError
|
|
from odoo.tests import tagged
|
|
from odoo.tools import mute_logger
|
|
|
|
from odoo.addons.payment.tests.http_common import PaymentHttpCommon
|
|
from odoo.addons.payment_paypal.controllers.main import PaypalController
|
|
from odoo.addons.payment_paypal.tests.common import PaypalCommon
|
|
|
|
|
|
@tagged('post_install', '-at_install')
|
|
class PaypalTest(PaypalCommon, PaymentHttpCommon):
|
|
|
|
def test_processing_values(self):
|
|
tx = self._create_transaction(flow='direct')
|
|
with patch(
|
|
'odoo.addons.payment_paypal.models.payment_provider.PaymentProvider'
|
|
'._paypal_make_request', return_value={'id': self.order_id},
|
|
):
|
|
processing_values = tx._get_processing_values()
|
|
self.assertEqual(processing_values['order_id'], self.order_id)
|
|
|
|
@mute_logger('odoo.addons.payment_paypal.controllers.main')
|
|
def test_complete_order_confirms_transaction(self):
|
|
""" Test the processing of a webhook notification. """
|
|
tx = self._create_transaction('direct')
|
|
normalized_data = PaypalController._normalize_paypal_data(self, self.completed_order)
|
|
self.env['payment.transaction']._handle_notification_data('paypal', normalized_data)
|
|
self.assertEqual(tx.state, 'done')
|
|
self.assertEqual(tx.provider_reference, normalized_data['id'])
|
|
|
|
def test_feedback_processing(self):
|
|
normalized_data = PaypalController._normalize_paypal_data(
|
|
self, self.notification_data.get('resource'), from_webhook=True
|
|
)
|
|
# Unknown transaction
|
|
with self.assertRaises(ValidationError):
|
|
self.env['payment.transaction']._handle_notification_data('paypal', normalized_data)
|
|
|
|
# Confirmed transaction
|
|
tx = self._create_transaction('direct')
|
|
self.env['payment.transaction']._handle_notification_data('paypal', normalized_data)
|
|
self.assertEqual(tx.state, 'done')
|
|
self.assertEqual(tx.provider_reference, normalized_data['id'])
|
|
|
|
# Pending transaction
|
|
self.reference = 'Test Transaction 2'
|
|
tx = self._create_transaction('direct')
|
|
payload = {
|
|
**normalized_data,
|
|
'reference_id': self.reference,
|
|
'status': 'PENDING',
|
|
'pending_reason': 'multi_currency',
|
|
}
|
|
self.env['payment.transaction']._handle_notification_data('paypal', payload)
|
|
self.assertEqual(tx.state, 'pending')
|
|
self.assertEqual(tx.state_message, payload['pending_reason'])
|
|
|
|
@mute_logger('odoo.addons.payment_paypal.controllers.main')
|
|
def test_webhook_notification_confirms_transaction(self):
|
|
""" Test the processing of a webhook notification. """
|
|
tx = self._create_transaction('direct')
|
|
url = self._build_url(PaypalController._webhook_url)
|
|
with patch(
|
|
'odoo.addons.payment_paypal.controllers.main.PaypalController'
|
|
'._verify_notification_origin'
|
|
):
|
|
self._make_json_request(url, data=self.notification_data)
|
|
self.assertEqual(tx.state, 'done')
|
|
|
|
@mute_logger('odoo.addons.payment_paypal.controllers.main')
|
|
def test_webhook_notification_triggers_origin_check(self):
|
|
""" Test that receiving a webhook notification triggers an origin check. """
|
|
self._create_transaction('direct')
|
|
url = self._build_url(PaypalController._webhook_url)
|
|
with patch(
|
|
'odoo.addons.payment_paypal.controllers.main.PaypalController'
|
|
'._verify_notification_origin'
|
|
) as origin_check_mock, patch(
|
|
'odoo.addons.payment.models.payment_transaction.PaymentTransaction'
|
|
'._handle_notification_data'
|
|
):
|
|
self._make_json_request(url, data=self.notification_data)
|
|
self.assertEqual(origin_check_mock.call_count, 1)
|