summaryrefslogtreecommitdiff
path: root/t/transaction.t
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2015-02-12 14:27:41 -0800
committerIvan Kohler <ivan@freeside.biz>2015-02-12 14:27:41 -0800
commit28425f2f6ecee736d64cf6a45a74dc4f4992edbd (patch)
tree0087ff57298a6a175a95c0d3ec647fd28404e6a6 /t/transaction.t
parent59dc9c0128f8c9258c9ec80f11754dd1e7ecf26e (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.t64
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;