Test cleanups. Drop use_ok, change order of cleanup.

This commit is contained in:
Colin Kuskie 2010-05-22 22:48:42 -07:00
parent 095b7c7ef9
commit 59f8c0cea0

View file

@ -25,6 +25,7 @@ use WebGUI::Shop::Ship;
use WebGUI::Shop::Transaction; use WebGUI::Shop::Transaction;
use JSON; use JSON;
use HTML::Form; use HTML::Form;
use WebGUI::Shop::PayDriver::ITransact;
#---------------------------------------------------------------------------- #----------------------------------------------------------------------------
# Init # Init
@ -34,26 +35,12 @@ my $session = WebGUI::Test->session;
#---------------------------------------------------------------------------- #----------------------------------------------------------------------------
# Tests # Tests
my $tests = 28; plan tests => 28;
plan tests => 1 + $tests;
#---------------------------------------------------------------------------- #----------------------------------------------------------------------------
# figure out if the test can actually run # figure out if the test can actually run
note('Testing existence');
my $loaded = use_ok('WebGUI::Shop::PayDriver::ITransact');
my $e; my $e;
my $ship = WebGUI::Shop::Ship->new($session);
my $cart = WebGUI::Shop::Cart->newBySession($session);
my $shipper = $ship->getShipper('defaultfreeshipping000');
my $address = $cart->getAddressBook->addAddress( { firstName => 'Ellis Boyd', lastName => 'Redding'} );
$cart->update({
shippingAddressId => $address->getId,
shipperId => $shipper->getId,
});
my $transaction;
my $versionTag = WebGUI::VersionTag->getWorking($session); my $versionTag = WebGUI::VersionTag->getWorking($session);
my $home = WebGUI::Asset->getDefault($session); my $home = WebGUI::Asset->getDefault($session);
@ -82,14 +69,22 @@ my $foreignHammer = $rockHammer->setCollateral('variantsJSON', 'variantId', 'new
$versionTag->commit; $versionTag->commit;
WebGUI::Test->tagsToRollback($versionTag); WebGUI::Test->addToCleanup($versionTag);
$rockHammer = $rockHammer->cloneFromDb;
my $ship = WebGUI::Shop::Ship->new($session);
my $cart = WebGUI::Shop::Cart->newBySession($session);
WebGUI::Test->addToCleanup($cart);
my $shipper = $ship->getShipper('defaultfreeshipping000');
my $address = $cart->getAddressBook->addAddress( { firstName => 'Ellis Boyd', lastName => 'Redding'} );
$cart->update({
shippingAddressId => $address->getId,
shipperId => $shipper->getId,
});
my $hammerItem = $rockHammer->addToCart($rockHammer->getCollateral('variantsJSON', 'variantId', $smallHammer)); my $hammerItem = $rockHammer->addToCart($rockHammer->getCollateral('variantsJSON', 'variantId', $smallHammer));
SKIP: {
skip 'Unable to load module WebGUI::Shop::PayDriver::ITransact', $tests unless $loaded;
####################################################################### #######################################################################
# #
# definition # definition
@ -272,11 +267,12 @@ $driver->{_billingAddress} = {
}; };
$transaction = WebGUI::Shop::Transaction->create($session, { my $transaction = WebGUI::Shop::Transaction->create($session, {
paymentMethod => $driver, paymentMethod => $driver,
cart => $cart, cart => $cart,
isRecurring => $cart->requiresRecurringPayment, isRecurring => $cart->requiresRecurringPayment,
}); });
WebGUI::Test->addToCleanup($transaction);
my $xml = $driver->_generatePaymentRequestXML($transaction); my $xml = $driver->_generatePaymentRequestXML($transaction);
@ -292,11 +288,14 @@ TODO: {
####################################################################### #######################################################################
SKIP: { SKIP: {
skip "Skipping XML requests to ITransact due to lack of userId and password", 2 unless $hasTestAccount; skip "Skipping XML requests to ITransact due to lack of real userId and password", 2 unless $hasTestAccount;
my $response = eval { $driver->doXmlRequest($xml) };
note 'doXmlrequest'; note 'doXmlrequest';
isa_ok($response, 'HTTP::Response', 'returns a HTTP::Response object'); my $response = eval { $driver->doXmlRequest($xml) };
ok( $response->is_success, '... was successful'); my $ok_response = isa_ok($response, 'HTTP::Response', 'returns a HTTP::Response object');
SKIP: {
skip "Skipping response check since we did not get a response", 1 unless $ok_response;
ok( $response->is_success, '... was successful');
}
} }
my $hammer2 = $rockHammer->addToCart($rockHammer->getCollateral('variantsJSON', 'variantId', $foreignHammer)); my $hammer2 = $rockHammer->addToCart($rockHammer->getCollateral('variantsJSON', 'variantId', $foreignHammer));
@ -313,7 +312,6 @@ SKIP: {
my $response = eval { $driver->doXmlRequest($xml) }; my $response = eval { $driver->doXmlRequest($xml) };
isa_ok($response, 'HTTP::Response', 'returns a HTTP::Response object'); isa_ok($response, 'HTTP::Response', 'returns a HTTP::Response object');
ok( $response->is_success, '... was successful'); ok( $response->is_success, '... was successful');
note $response->content;
} }
####################################################################### #######################################################################
@ -332,13 +330,4 @@ is ($count, 0, 'delete deleted the object');
undef $driver; undef $driver;
#----------------------------------------------------------------------------
# Cleanup
}
END: {
$cart->delete;
$transaction->delete if defined $transaction;
}
#vim:ft=perl #vim:ft=perl