def __call__(self):
        """Return the right status code for Mollie and process the payment."""
        adapted = IMollieIdealMultiplePayments(self.context)
        received_transaction_id = self.request.form.get('transaction_id')

        try:
            transaction = adapted.get_transaction(received_transaction_id)
        except UnknownTransactionError:
            transaction = None
        if (not received_transaction_id or transaction is None):
            message = 'Wrong or missing transaction ID'
            self.request.response.setStatus(403, message)
            return message

        adapted.get_payment_status(received_transaction_id)
        notify(MollieIdealPaymentEvent(self.context, self.request,
                                       received_transaction_id))
        self.request.response.setStatus(200)
        return 'OK'
class TestMultiplePaymentsAdapter(unittest.TestCase):
    """Test the Mollie iDeal Multiple Payments adapter."""

    layer = COLLECTIVE_MOLLIE_INTEGRATION_TESTING

    def setUp(self):
        self.foo = Foo()
        self.adapted = IMollieIdealMultiplePayments(self.foo)
        self.adapted.ideal_wrapper.old_do_request = \
            self.adapted.ideal_wrapper._do_request
        self.partner_id = '999999'
        self.bank_id = '9999'
        self.amount = '123'  # 1.23 Euro
        self.currency = 'EUR'
        self.message = 'Testing payment'
        self.report_url = 'http://example.com/report_payment'
        self.return_url = 'http://example.com/return_url'
        self.transaction_id = '482d599bbcc7795727650330ad65fe9b'

    def tearDown(self):
        self.adapted.ideal_wrapper._do_request = \
            self.adapted.ideal_wrapper.old_do_request

    def test_adapter(self):
        """Test whether we can adapt."""
        self.assertTrue(isinstance(self.adapted, MollieIdealMultiplePayments))

    def test_get_banks(self):
        """Check we can retrieve the banks from Mollie."""
        def side_effect(*args, **kwargs):
            return mock_do_request('banks.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect)
        banks = self.adapted.get_banks()
        self.assertTrue(('0021', 'Rabobank') in banks)

    def test_get_unknown_transaction(self):
        """Check if we can retrieve data for an unknown transaction."""
        self.assertRaises(UnknownTransactionError,
                          self.adapted.get_transaction, 'foobar')

    def test_get_payment_url(self):
        """Check we can get a payment URL and the transaction ID is stored."""
        def side_effect(*args, **kwargs):
            return mock_do_request('request_payment_good.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect)
        my_transaction_id, url = self.adapted.get_payment_url(self.partner_id,
            self.bank_id, self.amount, self.message, self.report_url,
            self.return_url)
        # The right URL is returned
        self.assertEqual(url, 'https://mijn.postbank.nl/internetbankieren/' +
                              'SesamLoginServlet?sessie=ideal&trxid=' +
                              '003123456789123&random=123456789abcdefgh')
        # The right transaction_id is returned
        self.assertEqual(my_transaction_id, self.transaction_id)
        # The right transaction information is stored.
        stored_transaction = self.adapted.get_transaction(my_transaction_id)
        self.assertNotEqual(stored_transaction, None)
        self.assertEqual(stored_transaction['amount'], self.amount)
        self.assertEqual(stored_transaction['partner_id'], self.partner_id)

    def test_unknown_transaction_payment_status(self):
        """Check if we can retrieve status for unknown transaction."""
        self.assertRaises(UnknownTransactionError,
                          self.adapted.get_payment_status, 'foobar')

    def test_get_payment_status_success(self):
        """Check the best case: a successfull payment."""
        def side_effect(*args, **kwargs):
            return mock_do_request('request_payment_good.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect)
        self.adapted.get_payment_url(self.partner_id, self.bank_id,
            self.amount, self.message, self.report_url, self.return_url)

        def side_effect2(*args, **kwargs):
            return mock_do_request('payment_success.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect2)
        result = self.adapted.get_payment_status(self.transaction_id)
        transaction = self.adapted.get_transaction(self.transaction_id)
        self.assertEqual(result, 'Success')
        self.assertTrue(transaction['paid'])
        self.assertEqual(transaction['consumer']['name'], 'T. TEST')
        self.assertEqual(transaction['consumer']['account'], '0123456789')
        self.assertEqual(transaction['consumer']['city'], 'Testdorp')
        self.assertEqual(transaction['status'], 'Success')
        self.assertEqual(transaction['last_status'], 'Success')

    def test_get_payment_status_cancelled(self):
        """Check a cancelled payment."""
        def side_effect(*args, **kwargs):
            return mock_do_request('request_payment_good.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect)
        self.adapted.get_payment_url(self.partner_id, self.bank_id,
            self.amount, self.message, self.report_url, self.return_url)

        def side_effect2(*args, **kwargs):
            return mock_do_request('payment_cancelled.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect2)
        result = self.adapted.get_payment_status(self.transaction_id)
        transaction = self.adapted.get_transaction(self.transaction_id)
        self.assertEqual(result, 'Cancelled')
        self.assertFalse(transaction['paid'])
        self.assertEqual(transaction['consumer'], None)
        self.assertEqual(transaction['status'], 'Cancelled')

    def test_get_payment_status_checked_before(self):
        """Check payment twice: the result is saved."""
        def side_effect(*args, **kwargs):
            return mock_do_request('request_payment_good.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect)
        self.adapted.get_payment_url(self.partner_id, self.bank_id,
            self.amount, self.message, self.report_url, self.return_url)

        # We first check the success.
        def side_effect2(*args, **kwargs):
            return mock_do_request('payment_success.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect2)
        result = self.adapted.get_payment_status(self.transaction_id)
        self.assertEqual(result, 'Success')

        # A second check will return 'CheckedBefore' but the payment
        # status will be saved.
        def side_effect3(*args, **kwargs):
            return mock_do_request('payment_checked_before.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect3)
        result = self.adapted.get_payment_status(self.transaction_id)
        transaction = self.adapted.get_transaction(self.transaction_id)
        self.assertEqual(result, 'CheckedBefore')
        self.assertTrue(transaction['paid'])
        self.assertEqual(transaction['status'], 'Success')
        self.assertEqual(transaction['last_status'], 'CheckedBefore')

    def test_multiple_payments(self):
        """Check storing multiple payments."""
        # Request payment 1.
        def side_effect(*args, **kwargs):
            return mock_do_request('request_payment_good.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect)
        transaction_id1, url = self.adapted.get_payment_url(
            self.partner_id, self.bank_id, self.amount, self.message,
            self.report_url, self.return_url)

        # Request payment 2.
        def side_effect2(*args, **kwargs):
            return mock_do_request('request_payment_good_2.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect2)
        transaction_id2, url = self.adapted.get_payment_url(
            self.partner_id, self.bank_id, self.amount, self.message,
            self.report_url, self.return_url)

        # Process payment 1.
        def side_effect3(*args, **kwargs):
            return mock_do_request('payment_success.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect3)
        result1 = self.adapted.get_payment_status(transaction_id1)
        transaction1 = self.adapted.get_transaction(transaction_id1)

        # Process payment 2.
        def side_effect4(*args, **kwargs):
            return mock_do_request('payment_cancelled_2.xml')
        self.adapted.ideal_wrapper._do_request = MagicMock(
            side_effect=side_effect4)
        result2 = self.adapted.get_payment_status(transaction_id2)
        transaction2 = self.adapted.get_transaction(transaction_id2)

        # Check the results.
        self.assertEqual(result1, 'Success')
        self.assertTrue(transaction1['paid'])

        self.assertEqual(result2, 'Cancelled')
        self.assertFalse(transaction2['paid'])