diff options
author | Ivan Kohler <ivan@freeside.biz> | 2015-02-12 14:27:41 -0800 |
---|---|---|
committer | Ivan Kohler <ivan@freeside.biz> | 2015-02-12 14:27:41 -0800 |
commit | 28425f2f6ecee736d64cf6a45a74dc4f4992edbd (patch) | |
tree | 0087ff57298a6a175a95c0d3ec647fd28404e6a6 /t/transaction.t | |
parent | 59dc9c0128f8c9258c9ec80f11754dd1e7ecf26e (diff) |
- Update for production URL
- Use username/password for auth like other B:OP modules
- Fix tests
- Remove extraneous extra/ stuff in repo
Diffstat (limited to 't/transaction.t')
-rw-r--r-- | t/transaction.t | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/t/transaction.t b/t/transaction.t new file mode 100644 index 0000000..087bd02 --- /dev/null +++ b/t/transaction.t @@ -0,0 +1,64 @@ +#!/usr/bin/perl + +use strict; +use warnings; +use POSIX qw(strftime); +use Test::More; +use Business::OnlinePayment; +require "t/lib/test_account.pl"; + +my %opts = test_account('card'); + +if (!$opts{'login'} || !$opts{'password'}) { + plan skip_all => "no test credentials provided; fill out t/lib/test_account.pl to test communication with the gateway.", + 1; + exit(0); +} + +plan tests => 2; + +### +# Purchase +### +my %content = ( + login => delete($opts{'login'}), + password => delete($opts{'password'}), + action => 'Normal Authorization', + description => 'Business::OnlinePayment visa test', + card_number => '4111111111111111', + cvv2 => '111', + expiration => expiration_date(), + amount => '24.42', + name => 'Murphy Law', + email => 'fake@acme.com', + address => '123 Anystreet', + zip => '84058', +); + +my $tx = new Business::OnlinePayment( 'vSecureProcessing', %opts ); + +$tx->content( %content ); + +$tx->test_transaction(1); + +$tx->submit; + +is( $tx->is_success, 1, 'purchase' ) + or diag('Gateway error: '. $tx->error_message); + +### +# Refund +### +my $auth = $tx->authorization; +$tx = new Business::OnlinePayment( 'vSecureProcessing', %opts ); +$tx->content( %content, + action => 'Credit', + authorization => $auth ); +$tx->test_transaction(1); + +$tx->submit; + +is( $tx->is_success, 1, 'refund' ) + or diag('Gateway error: '. $tx->error_message); + +1; |