mirror of
https://github.com/internetee/registry.git
synced 2025-07-22 18:56:05 +02:00
Add tests for Payments::BankLink
This commit is contained in:
parent
663214ee49
commit
5dea92c0d8
12 changed files with 294 additions and 150 deletions
|
@ -1,13 +1,22 @@
|
|||
require 'test_helper'
|
||||
|
||||
class BankLinkTest < ActiveSupport::TestCase
|
||||
# Note: Files stored in: test/fixtures/files/seb_seller_key.pem
|
||||
# test/fixtures/files/seb_bank_cert.pem
|
||||
# are autogenerated, they will not work against production or even staging.
|
||||
def setup
|
||||
super
|
||||
@invoice = invoices(:valid)
|
||||
params = { return_url: 'return.url', response_url: 'response.url' }
|
||||
@bank_link = Payments::BankLink.new('seb', @invoice, params)
|
||||
|
||||
travel_to '2018-04-01 00:30'
|
||||
@invoice = invoices(:for_payments_test)
|
||||
invoice_item = invoice_items(:one)
|
||||
|
||||
@invoice.invoice_items << invoice_item
|
||||
@invoice.invoice_items << invoice_item
|
||||
|
||||
travel_to '2018-04-01 00:30 +0300'
|
||||
create_new_bank_link
|
||||
create_completed_bank_link
|
||||
create_cancelled_bank_link
|
||||
end
|
||||
|
||||
def teardown
|
||||
|
@ -15,7 +24,97 @@ class BankLinkTest < ActiveSupport::TestCase
|
|||
travel_back
|
||||
end
|
||||
|
||||
def test_response_is_not_valid_without_response
|
||||
assert_equal false, @bank_link.valid_response?
|
||||
def create_completed_bank_link
|
||||
params = {
|
||||
"VK_SERVICE": "1111",
|
||||
"VK_VERSION": "008",
|
||||
"VK_SND_ID": "testvpos",
|
||||
"VK_REC_ID": "seb",
|
||||
"VK_STAMP": 1,
|
||||
"VK_T_NO": "1",
|
||||
"VK_AMOUNT": "12.00",
|
||||
"VK_CURR": "EUR",
|
||||
"VK_REC_ACC": "1234",
|
||||
"VK_REC_NAME": "Eesti Internet",
|
||||
"VK_SND_ACC": "1234",
|
||||
"VK_SND_NAME": "John Doe",
|
||||
"VK_REF": "",
|
||||
"VK_MSG": "Order nr 1",
|
||||
"VK_T_DATETIME": "2018-04-01T00:30:00+0300",
|
||||
"VK_MAC": "CZZvcptkxfuOxRR88JmT4N+Lw6Hs4xiQfhBWzVYldAcRTQbcB/lPf9MbJzBE4e1/HuslQgkdCFt5g1xW2lJwrVDBQTtP6DAHfvxU3kkw7dbk0IcwhI4whUl68/QCwlXEQTAVDv1AFnGVxXZ40vbm/aLKafBYgrirB5SUe8+g9FE=",
|
||||
"VK_ENCODING": "UTF-8",
|
||||
"VK_LANG": "ENG"
|
||||
}.with_indifferent_access
|
||||
|
||||
@completed_bank_link = Payments::BankLink.new(
|
||||
'seb', @invoice, { response: params }
|
||||
)
|
||||
end
|
||||
|
||||
def create_cancelled_bank_link
|
||||
params = {
|
||||
"VK_SERVICE": "1911",
|
||||
"VK_VERSION": "008",
|
||||
"VK_SND_ID": "testvpos",
|
||||
"VK_REC_ID": "seb",
|
||||
"VK_STAMP": 1,
|
||||
"VK_REF": "",
|
||||
"VK_MSG": "Order nr 1",
|
||||
"VK_MAC": "PElE2mYXXN50q2UBvTuYU1rN0BmOQcbafPummDnWfNdm9qbaGQkGyOn0XaaFGlrdEcldXaHBbZKUS0HegIgjdDfl2NOk+wkLNNH0Iu38KzZaxHoW9ga7vqiyKHC8dcxkHiO9HsOnz77Sy/KpWCq6cz48bi3fcMgo+MUzBMauWoQ=",
|
||||
"VK_ENCODING": "UTF-8",
|
||||
"VK_LANG": "ENG"
|
||||
}.with_indifferent_access
|
||||
|
||||
@cancelled_bank_link = Payments::BankLink.new(
|
||||
'seb', @invoice, { response: params }
|
||||
)
|
||||
end
|
||||
|
||||
def create_new_bank_link
|
||||
params = { return_url: 'return.url', response_url: 'response.url' }
|
||||
@new_bank_link = Payments::BankLink.new('seb', @invoice, params)
|
||||
end
|
||||
|
||||
def test_response_is_not_valid_when_it_is_missing
|
||||
refute(false, @new_bank_link.valid_response_from_intermediary?)
|
||||
end
|
||||
|
||||
def test_form_fields
|
||||
expected_response = {
|
||||
"VK_SERVICE": "1012",
|
||||
"VK_VERSION": "008",
|
||||
"VK_SND_ID": "testvpos",
|
||||
"VK_STAMP": 1,
|
||||
"VK_AMOUNT": "12.00",
|
||||
"VK_CURR": "EUR",
|
||||
"VK_REF": "",
|
||||
"VK_MSG": "Order nr. 1",
|
||||
"VK_RETURN": "return.url",
|
||||
"VK_CANCEL": "return.url",
|
||||
"VK_DATETIME": "2018-04-01T00:30:00+0300",
|
||||
"VK_MAC": "q70UNFV4ih1qYij2+CyrHaApc3OE66igy3ijuR1m9dl0Cg+lIrAUsP47JChAF7PRErwZ78vSuZwrg0Vabhlp3WoC934ik2FiE04BBxUUTndONvguaNR1wvl0FiwfXFljLncX7TOmRraywJljKC5vTnIRNT2+1HXvmv0v576PGao=",
|
||||
"VK_ENCODING": "UTF-8",
|
||||
"VK_LANG": "ENG"
|
||||
}.with_indifferent_access
|
||||
|
||||
assert_equal(expected_response, @new_bank_link.form_fields)
|
||||
end
|
||||
|
||||
def test_valid_success_response_from_intermediary?
|
||||
assert(@completed_bank_link.valid_response_from_intermediary?)
|
||||
end
|
||||
|
||||
def test_valid_cancellation_response_from_intermediary?
|
||||
assert(@cancelled_bank_link.valid_response_from_intermediary?)
|
||||
end
|
||||
|
||||
def test_settled_payment?
|
||||
assert(@completed_bank_link.settled_payment?)
|
||||
refute(@cancelled_bank_link.settled_payment?)
|
||||
end
|
||||
|
||||
def test_complete_transaction_returns_account_activity_or_nil
|
||||
assert_instance_of(AccountActivity, @completed_bank_link.complete_transaction)
|
||||
assert_nil(@cancelled_bank_link.complete_transaction)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -59,9 +59,9 @@ class EveryPayTest < ActiveSupport::TestCase
|
|||
end
|
||||
end
|
||||
|
||||
def test_valid_response?
|
||||
assert(@every_pay.valid_response?)
|
||||
refute(@other_pay.valid_response?)
|
||||
def test_valid_response_from_intermediary?
|
||||
assert(@every_pay.valid_response_from_intermediary?)
|
||||
refute(@other_pay.valid_response_from_intermediary?)
|
||||
end
|
||||
|
||||
def test_settled_payment?
|
||||
|
@ -72,12 +72,8 @@ class EveryPayTest < ActiveSupport::TestCase
|
|||
refute(other_pay.settled_payment?)
|
||||
end
|
||||
|
||||
def test_valid_response?
|
||||
assert(@every_pay.valid_response?)
|
||||
refute(@other_pay.valid_response?)
|
||||
end
|
||||
|
||||
def test_complete_transaction_returns_account_activity_or_nil
|
||||
# skip('Figure out what fails in Travis')
|
||||
assert_instance_of(AccountActivity, @every_pay.complete_transaction)
|
||||
refute(@other_pay.complete_transaction)
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue