summaryrefslogtreecommitdiff
path: root/t
diff options
context:
space:
mode:
Diffstat (limited to 't')
-rwxr-xr-xt/021-generate_token.t15
-rwxr-xr-xt/031-payments-card-normal_authorization.t (renamed from t/021-payments-card-normal_authorization.t)0
-rwxr-xr-xt/032-payments-card-pre-authorization-complete-void.t (renamed from t/022-payments-card-pre-authorization-complete-void.t)2
-rwxr-xr-xt/041-tokenize-card.t82
-rwxr-xr-xt/junk.t0
5 files changed, 98 insertions, 1 deletions
diff --git a/t/021-generate_token.t b/t/021-generate_token.t
new file mode 100755
index 0000000..14d38c1
--- /dev/null
+++ b/t/021-generate_token.t
@@ -0,0 +1,15 @@
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+
+use lib 't';
+use Business::OnlinePayment;
+
+my $tr;
+ok( $tr = Business::OnlinePayment->new('Bambora'), 'Instantiatiate $tr' );
+
+my $token;
+ok( $token = $tr->generate_token, "\$tr->generate_token: $token" );
+ok( $token =~ /^99\d{14}$/, 'Token matches expected format' );
+done_testing; \ No newline at end of file
diff --git a/t/021-payments-card-normal_authorization.t b/t/031-payments-card-normal_authorization.t
index f4eb89b..f4eb89b 100755
--- a/t/021-payments-card-normal_authorization.t
+++ b/t/031-payments-card-normal_authorization.t
diff --git a/t/022-payments-card-pre-authorization-complete-void.t b/t/032-payments-card-pre-authorization-complete-void.t
index 00c25f9..7c575c9 100755
--- a/t/022-payments-card-pre-authorization-complete-void.t
+++ b/t/032-payments-card-pre-authorization-complete-void.t
@@ -11,7 +11,7 @@ my $merchant_id = $ENV{BAMBORA_MERCHANT_ID};
my $api_key = $ENV{BAMBORA_API_KEY};
SKIP: {
- skip 'Missing env vars BAMBORA_MERCHANT_ID and BAMBORA_API_KEY', 3
+ skip 'Missing env vars BAMBORA_MERCHANT_ID and BAMBORA_API_KEY', 32
unless $merchant_id && $api_key;
my %content = (
diff --git a/t/041-tokenize-card.t b/t/041-tokenize-card.t
new file mode 100755
index 0000000..f8a1292
--- /dev/null
+++ b/t/041-tokenize-card.t
@@ -0,0 +1,82 @@
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+
+use lib 't';
+require 'TestFixtures.pm';
+use Business::OnlinePayment;
+
+my $merchant_id = $ENV{BAMBORA_MERCHANT_ID};
+my $api_key = $ENV{BAMBORA_API_KEY};
+
+SKIP: {
+ skip 'Missing env vars BAMBORA_MERCHANT_ID and BAMBORA_API_KEY', 32
+ unless $merchant_id && $api_key;
+
+ my %content = (
+ login => $merchant_id,
+ password => $api_key,
+ action => 'Tokenize',
+ amount => '9.99',
+
+ owner => 'Freeside Internet',
+ name => 'Mitch Jackson',
+ address => '1407 Graymalkin Lane',
+ city => 'Vancouver',
+ state => 'BC',
+ zip => '111 111',
+ country => 'CA',
+
+ invoice_number => time(),
+ card_number => '4030000010001234',
+ cvv2 => '123',
+ expiration => '1122',
+ phone => '251-300-1300',
+ email => 'mitch@freeside.biz',
+ );
+
+ my $tr;
+ ok( $tr = Business::OnlinePayment->new('Bambora'), 'Instantiatiate $tr' );
+ ok( $tr->content( %content ), 'Set transaction content onto $tr' );
+ {
+ local $@;
+ eval { $tr->submit };
+ ok( !$@, "Submit request to create Payment Profile (tokenize)" );
+ }
+
+ my $response;
+
+ my %expect = (
+ code => 1,
+ message => 'Operation Successful',
+ );
+ my @expect = qw(
+ customer_code
+ );
+
+ ok( $response = $tr->response_decoded, 'response_decoded' );
+
+ for my $k ( keys %expect ) {
+ ok(
+ $response->{$k} eq $expect{$k},
+ sprintf '$tr->%s == %s', $k, $expect{$k}
+ );
+ }
+
+ for my $k ( @expect ) {
+ ok(
+ defined $response->{$k},
+ sprintf '$r->%s (%s)',
+ $k, $response->{$k}
+ );
+ }
+
+ ok(
+ $response->{customer_code} eq $tr->card_token,
+ '$tr->card_token eq $response->{customer_code}'
+ );
+
+}
+
+done_testing; \ No newline at end of file
diff --git a/t/junk.t b/t/junk.t
new file mode 100755
index 0000000..e69de29
--- /dev/null
+++ b/t/junk.t