* Port maintenance/cdb-test.php to PHPUnit
authorAlexandre Emsenhuber <ialex@users.mediawiki.org>
Thu, 4 Feb 2010 17:57:40 +0000 (17:57 +0000)
committerAlexandre Emsenhuber <ialex@users.mediawiki.org>
Thu, 4 Feb 2010 17:57:40 +0000 (17:57 +0000)
* Reduced entries from 100000 to 1000 so that the test doesn't need hours to complete :)

maintenance/cdb-test.php [deleted file]
maintenance/tests/CdbTest.php [new file with mode: 0644]

diff --git a/maintenance/cdb-test.php b/maintenance/cdb-test.php
deleted file mode 100644 (file)
index b6f23c4..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-<?php
-
-/**
- * Test the CDB reader/writer
- */
-
-require_once( dirname(__FILE__) . '/Maintenance.php' );
-
-class CdbTest extends Maintenance {
-       public function __construct() {
-               parent::__construct();
-               $this->mDescription = "CDB read/write test";
-       }
-
-       public function execute() {
-               $this->output( "Write test...\n" );
-
-               $w1 = new CdbWriter_PHP( 'php.cdb' );
-               $w2 = new CdbWriter_DBA( 'dba.cdb' );
-
-               $data = array();
-               for ( $i = 0; $i < 100000; $i++ ) {
-                       $key = $this->randomString();
-                       $value = $this->randomString();
-                       $w1->set( $key, $value );
-                       $w2->set( $key, $value );
-
-                       if ( !isset( $data[$key] ) ) {
-                               $data[$key] = $value;
-                       }
-               }
-
-               $w1->close();
-               $w2->close();
-
-               passthru( 'md5sum php.cdb dba.cdb' );
-
-               $this->output( "Read test...\n" );
-
-               $r1 = new CdbReader_PHP( 'php.cdb' );
-               $r2 = new CdbReader_DBA( 'dba.cdb' );
-
-               foreach ( $data as $key => $value ) {
-                       if ( $key === '' ) {
-                               // Known bug
-                               continue;
-                       }
-                       $v1 = $r1->get( $key );
-                       $v2 = $r2->get( $key );
-
-                       $v1 = $v1 === false ? '(not found)' : $v1;
-                       $v2 = $v2 === false ? '(not found)' : $v2;
-
-                       #cdbAssert( 'Mismatch', $key, $v1, $v2 );
-                       $this->cdbAssert( "PHP error", $key, $v1, $value );
-                       $this->cdbAssert( "DBA error", $key, $v2, $value );
-               }
-               $this->output( "Done.\n" );
-       }
-
-       private function randomString() {
-               $len = mt_rand( 0, 10 );
-               $s = '';
-               for ( $j = 0; $j < $len; $j++ ) {
-                       $s .= chr( mt_rand( 0, 255 ) );
-               }
-               return $s;
-       }
-
-       private function cdbAssert( $msg, $key, $v1, $v2 ) {
-               if ( $v1 !== $v2 ) {
-                       $this->output( $msg . ', k=' . bin2hex( $key ) . 
-                               ', v1=' . bin2hex( $v1 ) . 
-                               ', v2=' . bin2hex( $v2 ) . "\n" );
-                       return false;
-               } else {
-                       return true;
-               }
-       }
-}
-
-$maintClass = "CdbTest";
-require_once( DO_MAINTENANCE );
diff --git a/maintenance/tests/CdbTest.php b/maintenance/tests/CdbTest.php
new file mode 100644 (file)
index 0000000..3549c24
--- /dev/null
@@ -0,0 +1,73 @@
+<?php
+
+/**
+ * Test the CDB reader/writer
+ */
+
+class CdbTest extends PHPUnit_Framework_TestCase {
+
+       public function testCdb() {
+               $w1 = new CdbWriter_PHP( 'php.cdb' );
+               $w2 = new CdbWriter_DBA( 'dba.cdb' );
+
+               $data = array();
+               for ( $i = 0; $i < 1000; $i++ ) {
+                       $key = $this->randomString();
+                       $value = $this->randomString();
+                       $w1->set( $key, $value );
+                       $w2->set( $key, $value );
+
+                       if ( !isset( $data[$key] ) ) {
+                               $data[$key] = $value;
+                       }
+               }
+
+               $w1->close();
+               $w2->close();
+
+               $this->assertEquals(
+                       md5_file( 'dba.cdb' ),
+                       md5_file( 'php.cdb' ),
+                       'same hash'
+               );
+
+               $r1 = new CdbReader_PHP( 'php.cdb' );
+               $r2 = new CdbReader_DBA( 'dba.cdb' );
+
+               foreach ( $data as $key => $value ) {
+                       if ( $key === '' ) {
+                               // Known bug
+                               continue;
+                       }
+                       $v1 = $r1->get( $key );
+                       $v2 = $r2->get( $key );
+
+                       $v1 = $v1 === false ? '(not found)' : $v1;
+                       $v2 = $v2 === false ? '(not found)' : $v2;
+
+                       #cdbAssert( 'Mismatch', $key, $v1, $v2 );
+                       $this->cdbAssert( "PHP error", $key, $v1, $value );
+                       $this->cdbAssert( "DBA error", $key, $v2, $value );
+               }
+
+               unlink( 'dba.cdb' );
+               unlink( 'php.cdb' );
+       }
+
+       private function randomString() {
+               $len = mt_rand( 0, 10 );
+               $s = '';
+               for ( $j = 0; $j < $len; $j++ ) {
+                       $s .= chr( mt_rand( 0, 255 ) );
+               }
+               return $s;
+       }
+
+       private function cdbAssert( $msg, $key, $v1, $v2 ) {
+               $this->assertEquals(
+                       $v2,
+                       $v1,
+                       $msg . ', k=' . bin2hex( $key )
+               );
+       }
+}