DatabaseSqlite::sourceStream(): convert CHAR types, allow more spaces
authorMax Semenik <maxsem@users.mediawiki.org>
Thu, 12 Aug 2010 16:28:11 +0000 (16:28 +0000)
committerMax Semenik <maxsem@users.mediawiki.org>
Thu, 12 Aug 2010 16:28:11 +0000 (16:28 +0000)
includes/db/DatabaseSqlite.php
maintenance/tests/DatabaseSqliteTest.php

index 74aea6f..cee84d6 100644 (file)
@@ -572,9 +572,9 @@ class DatabaseSqlite extends DatabaseBase {
                        // no such thing as unsigned
                        $s = preg_replace( '/\b(un)?signed\b/i', '', $s );
                        // INT -> INTEGER
-                       $s = preg_replace( '/\b(tiny|small|medium|big|)int(\([\s\d]*\)|\b)/i', 'INTEGER', $s );
+                       $s = preg_replace( '/\b(tiny|small|medium|big|)int(\s*\([\s\d]*\)|\b)/i', 'INTEGER', $s );
                        // varchar -> TEXT
-                       $s = preg_replace( '/\bvarchar\(\d+\)/i', 'TEXT', $s );
+                       $s = preg_replace( '/\b(var)?char\s*\(.*?\)/i', 'TEXT', $s );
                        // TEXT normalization
                        $s = preg_replace( '/\b(tiny|medium|long)text\b/i', 'TEXT', $s );
                        // BLOB normalization
index e70c3ac..29ce638 100644 (file)
@@ -36,9 +36,9 @@ class DatabaseSqliteTest extends PHPUnit_Framework_TestCase {
                $this->assertEquals( 'foo', $this->replaceVars( 'foo' ), "Don't break anything accidentally" );
 
                $this->assertEquals( "CREATE TABLE /**/foo (foo_key INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, "
-                       . "foo_name TEXT NOT NULL DEFAULT '', foo_int INTEGER, foo_int2 INTEGER );",
+                       . "foo_bar TEXT, foo_name TEXT NOT NULL DEFAULT '', foo_int INTEGER, foo_int2 INTEGER );",
                        $this->replaceVars( "CREATE TABLE /**/foo (foo_key int unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,
-                       foo_name varchar(255) binary NOT NULL DEFAULT '', foo_int tinyint( 8 ), foo_int2 int(16) ) ENGINE=MyISAM;" )
+                       foo_bar char(13), foo_name varchar(255) binary NOT NULL DEFAULT '', foo_int tinyint ( 8 ), foo_int2 int(16) ) ENGINE=MyISAM;" )
                        );
 
                $this->assertEquals( "CREATE TABLE foo ( foo_binary1 BLOB, foo_binary2 BLOB );",