[Bast-commits] r7096 - DBIx-Class/0.08/branches/mssql_money_type/t

caelum at dev.catalyst.perl.org caelum at dev.catalyst.perl.org
Thu Jul 23 18:09:26 GMT 2009


Author: caelum
Date: 2009-07-23 18:09:26 +0000 (Thu, 23 Jul 2009)
New Revision: 7096

Modified:
   DBIx-Class/0.08/branches/mssql_money_type/t/746mssql.t
   DBIx-Class/0.08/branches/mssql_money_type/t/74mssql.t
Log:
add money type tests to dbd::sybase+mssql tests

Modified: DBIx-Class/0.08/branches/mssql_money_type/t/746mssql.t
===================================================================
--- DBIx-Class/0.08/branches/mssql_money_type/t/746mssql.t	2009-07-23 15:01:37 UTC (rev 7095)
+++ DBIx-Class/0.08/branches/mssql_money_type/t/746mssql.t	2009-07-23 18:09:26 UTC (rev 7096)
@@ -83,7 +83,7 @@
 
 CREATE TABLE money_test (
    id INT IDENTITY PRIMARY KEY,
-   amount money
+   amount MONEY NULL
 )
 
 SQL

Modified: DBIx-Class/0.08/branches/mssql_money_type/t/74mssql.t
===================================================================
--- DBIx-Class/0.08/branches/mssql_money_type/t/74mssql.t	2009-07-23 15:01:37 UTC (rev 7095)
+++ DBIx-Class/0.08/branches/mssql_money_type/t/74mssql.t	2009-07-23 18:09:26 UTC (rev 7096)
@@ -18,7 +18,7 @@
 plan skip_all => 'Set $ENV{DBICTEST_MSSQL_DSN}, _USER and _PASS to run this test'
   unless ($dsn);
 
-plan tests => 7;
+plan tests => 13;
 
 my $schema = DBICTest::Schema->clone;
 $schema->connection($dsn, $user, $pass);
@@ -74,10 +74,48 @@
 $it->next;
 is( $it->next, undef, "next past end of resultset ok" );
 
+# test MONEY column support
+$schema->storage->dbh_do (sub {
+    my ($storage, $dbh) = @_;
+    eval { $dbh->do("DROP TABLE money_test") };
+    $dbh->do(<<'SQL');
+
+CREATE TABLE money_test (
+   id INT IDENTITY PRIMARY KEY,
+   amount MONEY NULL
+)
+
+SQL
+
+});
+
+my $rs = $schema->resultset('Money');
+
+my $row;
+lives_ok {
+  $row = $rs->create({ amount => 100 });
+} 'inserted a money value';
+
+is $rs->find($row->id)->amount, 100, 'money value round-trip';
+
+lives_ok {
+  $row->update({ amount => 200 });
+} 'updated a money value';
+
+is $rs->find($row->id)->amount, 200, 'updated money value round-trip';
+
+lives_ok {
+  $row->update({ amount => undef });
+} 'updated a money value to NULL';
+
+is $rs->find($row->id)->amount, undef,'updated money value to NULL round-trip';
+
 # clean up our mess
 END {
     $dbh->do("IF OBJECT_ID('artist', 'U') IS NOT NULL DROP TABLE artist")
         if $dbh;
     $dbh->do("IF OBJECT_ID('cd', 'U') IS NOT NULL DROP TABLE cd")
         if $dbh;
+    $dbh->do("IF OBJECT_ID('money_test', 'U') IS NOT NULL DROP TABLE money_test")
+        if $dbh;
 }




More information about the Bast-commits mailing list