[Rt-commit] r2905 - in DBIx-SearchBuilder/trunk: . t
jesse at bestpractical.com
jesse at bestpractical.com
Sun May 22 15:25:12 EDT 2005
Author: jesse
Date: Sun May 22 15:25:12 2005
New Revision: 2905
Modified:
DBIx-SearchBuilder/trunk/ (props changed)
DBIx-SearchBuilder/trunk/t/01records.t
DBIx-SearchBuilder/trunk/t/02records_object.t
Log:
r16974 at hualien: jesse | 2005-05-22 15:03:22 -0400
* Better test coverage for record objects from Ruslan
Modified: DBIx-SearchBuilder/trunk/t/01records.t
==============================================================================
--- DBIx-SearchBuilder/trunk/t/01records.t (original)
+++ DBIx-SearchBuilder/trunk/t/01records.t Sun May 22 15:25:12 2005
@@ -8,7 +8,7 @@
BEGIN { require "t/utils.pl" }
our (@AvailableDrivers);
-use constant TESTS_PER_DRIVER => 30;
+use constant TESTS_PER_DRIVER => 44;
my $total = scalar(@AvailableDrivers) * TESTS_PER_DRIVER;
plan tests => $total;
@@ -32,10 +32,13 @@
my $rec = TestApp::Address->new($handle);
isa_ok($rec, 'DBIx::SearchBuilder::Record');
- # _Accessible testings
+# _Accessible testings
is( $rec->_Accessible('id' => 'read'), 1, 'id is accessible for read' );
is( $rec->_Accessible('id' => 'write'), undef, 'id is not accessible for write' );
+ is( $rec->_Accessible('id'), undef, "any field is not accessible in undefined mode" );
is( $rec->_Accessible('unexpected_field' => 'read'), undef, "field doesn't exist and can't be accessible for read" );
+ is_deeply( [sort($rec->ReadableAttributes)], [qw(EmployeeId Name Phone id)], 'readable attributes' );
+ is_deeply( [sort($rec->WritableAttributes)], [qw(EmployeeId Name Phone)], 'writable attributes' );
can_ok($rec,'Create');
@@ -51,13 +54,13 @@
ok($val, $msg) ;
is($rec->Name, 'Obra', "We did actually change the name");
- # Validate immutability of the field id
+# Validate immutability of the field id
($val, $msg) = $rec->Setid( $rec->id + 1 );
ok(!$val, $msg);
is($msg, 'Immutable field', 'id is immutable field');
is($rec->id, $id, "The record still has its id");
- # Check some non existant field
+# Check some non existant field
ok( !eval{ $rec->SomeUnexpectedField }, "The record has no 'SomeUnexpectedField'");
{
# test produce DBI warning
@@ -71,7 +74,7 @@
ok(!$val, "$msg");
- # Validate truncation on update
+# Validate truncation on update
($val,$msg) = $rec->SetName('1234567890123456789012345678901234567890');
@@ -81,7 +84,7 @@
- # Test unicode truncation:
+# Test unicode truncation:
my $univalue = "這是個測試";
($val,$msg) = $rec->SetName($univalue.$univalue);
@@ -92,14 +95,14 @@
- # make sure we do _not_ truncate things which should not be truncated
+# make sure we do _not_ truncate things which should not be truncated
($val,$msg) = $rec->SetEmployeeId('1234567890');
ok($val, $msg) ;
is($rec->EmployeeId, '1234567890', "Did not truncate id on create");
- # make sure we do truncation on create
+# make sure we do truncation on create
my $newrec = TestApp::Address->new($handle);
my $newid = $newrec->Create( Name => '1234567890123456789012345678901234567890',
EmployeeId => '1234567890' );
@@ -110,6 +113,42 @@
is($newrec->Name, '12345678901234', "Truncated on create");
is($newrec->EmployeeId, '1234567890', "Did not truncate id on create");
+# no prefetch feature and _LoadFromSQL sub checks
+ $newrec = TestApp::Address->new($handle);
+ ($val, $msg) = $newrec->_LoadFromSQL('SELECT id FROM Address WHERE id = ?', $newid);
+ is($val, 1, 'found object');
+ is($newrec->Name, '12345678901234', "autoloaded not prefetched field");
+ is($newrec->EmployeeId, '1234567890', "autoloaded not prefetched field");
+
+# _LoadFromSQL and missing PK
+ $newrec = TestApp::Address->new($handle);
+ ($val, $msg) = $newrec->_LoadFromSQL('SELECT Name FROM Address WHERE Name = ?', '12345678901234');
+ is($val, 0, "didn't find object");
+ is($msg, "Missing a primary key?", "reason is missing PK");
+
+# _LoadFromSQL and not existant row
+ $newrec = TestApp::Address->new($handle);
+ ($val, $msg) = $newrec->_LoadFromSQL('SELECT id FROM Address WHERE id = ?', 0);
+ is($val, 0, "didn't find object");
+ is($msg, "Couldn't find row", "reason is wrong id");
+
+# _LoadFromSQL and wrong SQL
+ $newrec = TestApp::Address->new($handle);
+ {
+ local $SIG{__WARN__} = sub{return};
+ ($val, $msg) = $newrec->_LoadFromSQL('SELECT ...');
+ }
+ is($val, 0, "didn't find object");
+ is($msg, "Couldn't execute query", "reason is bad SQL");
+
+# deletes
+ $newrec = TestApp::Address->new($handle);
+ $newrec->Load( $newid );
+ is( $newrec->Delete, 1, 'successfuly delete record');
+ $newrec = TestApp::Address->new($handle);
+ $newrec->Load( $newid );
+ is( $newrec->id, undef, "record doesn't exist any more");
+
cleanup_schema( 'TestApp::Address', $handle );
}} # SKIP, foreach blocks
Modified: DBIx-SearchBuilder/trunk/t/02records_object.t
==============================================================================
--- DBIx-SearchBuilder/trunk/t/02records_object.t (original)
+++ DBIx-SearchBuilder/trunk/t/02records_object.t Sun May 22 15:25:12 2005
@@ -9,7 +9,7 @@
BEGIN { require "t/utils.pl" }
our (@AvailableDrivers);
-use constant TESTS_PER_DRIVER => 8;
+use constant TESTS_PER_DRIVER => 11;
my $total = scalar(@AvailableDrivers) * TESTS_PER_DRIVER;
plan tests => $total;
@@ -42,9 +42,15 @@
my $obj = $phone->EmployeeObj($handle);
ok($obj, "Employee #$e_id has phone #$p_id");
+ isa_ok( $obj, 'TestApp::Employee');
is($obj->id, $e_id);
is($obj->Name, 'RUZ');
+ # tests for no object mapping
+ my ($state, $msg) = $phone->ValueObj($handle);
+ ok(!$state, "State is false");
+ is( $msg, 'No object mapping for field', 'Error message is correct');
+
cleanup_schema( 'TestApp', $handle );
}} # SKIP, foreach blocks
More information about the Rt-commit
mailing list