Merge branch 'develop-ascraeus' into develop

* develop-ascraeus:
  [ticket/13137] Create schema.json in build script
  [ticket/13137] Improve output of create_schema_files.php
  [ticket/13137] Add schema.json file to .gitignore
  [ticket/13137] Generate the schema when the schema.json file is not available
  [ticket/13137] Remove schema.json file
This commit is contained in:
Andreas Fischer 2014-10-07 20:30:40 +02:00
commit 10e99b018a
7 changed files with 69 additions and 3384 deletions

1
.gitignore vendored
View file

@ -11,6 +11,7 @@
/phpBB/images/avatars/gallery/* /phpBB/images/avatars/gallery/*
/phpBB/images/avatars/upload/* /phpBB/images/avatars/upload/*
/phpBB/images/ranks/* /phpBB/images/ranks/*
/phpBB/install/schemas/schema.json
/phpBB/language/* /phpBB/language/*
!/phpBB/language/en !/phpBB/language/en
/phpBB/store/* /phpBB/store/*

View file

@ -270,6 +270,9 @@
</else> </else>
</if> </if>
<!-- Create schema.json -->
<exec dir="${dir}" command="php develop/create_schema_files.php" />
<delete file="${dir}/config.php" /> <delete file="${dir}/config.php" />
<delete dir="${dir}/develop" /> <delete dir="${dir}/develop" />
<delete dir="${dir}/install/data" /> <delete dir="${dir}/install/data" />

View file

@ -57,4 +57,4 @@ $fp = fopen($schema_path . 'schema.json', 'wb');
fwrite($fp, json_encode($schema_data, JSON_PRETTY_PRINT)); fwrite($fp, json_encode($schema_data, JSON_PRETTY_PRINT));
fclose($fp); fclose($fp);
echo 'done'; echo 'Successfully created schema file';

View file

@ -1175,8 +1175,31 @@ class install_install extends module
} }
// Ok we have the db info go ahead and work on building the table // Ok we have the db info go ahead and work on building the table
$db_table_schema = @file_get_contents('schemas/schema.json'); if (file_exists('schemas/schema.json'))
$db_table_schema = json_decode($db_table_schema, true); {
$db_table_schema = @file_get_contents('schemas/schema.json');
$db_table_schema = json_decode($db_table_schema, true);
}
else
{
global $phpbb_root_path, $phpEx, $table_prefix;
$table_prefix = 'phpbb_';
if (!defined('CONFIG_TABLE'))
{
// We need to include the constants file for the table constants
// when we generate the schema from the migration files.
include($phpbb_root_path . 'includes/constants.' . $phpEx);
}
$finder = new \phpbb\finder(new \phpbb\filesystem(), $phpbb_root_path, null, $phpEx);
$classes = $finder->core_path('phpbb/db/migration/data/')
->get_classes();
$sqlite_db = new \phpbb\db\driver\sqlite();
$schema_generator = new \phpbb\db\migration\schema_generator($classes, new \phpbb\config\config(array()), $sqlite_db, new \phpbb\db\tools($sqlite_db, true), $phpbb_root_path, $phpEx, $table_prefix);
$db_table_schema = $schema_generator->get_schema();
}
if (!defined('CONFIG_TABLE')) if (!defined('CONFIG_TABLE'))
{ {

File diff suppressed because it is too large Load diff

View file

@ -55,47 +55,46 @@ abstract class phpbb_database_test_case extends PHPUnit_Extensions_Database_Test
static public function setUpBeforeClass() static public function setUpBeforeClass()
{ {
$setup_extensions = static::setup_extensions(); $setup_extensions = static::setup_extensions();
self::$schema_file = '';
if (!empty($setup_extensions)) $schema_md5 = md5(serialize($setup_extensions));
self::$schema_file = __DIR__ . '/../tmp/' . $schema_md5 . '.json';
self::$install_schema_file = __DIR__ . '/../../phpBB/install/schemas/schema.json';
if (!file_exists(self::$schema_file))
{ {
$schema_md5 = md5(serialize($setup_extensions)); global $phpbb_root_path, $phpEx, $table_prefix;
$finder = new \phpbb\finder(new \phpbb\filesystem(), $phpbb_root_path, null, $phpEx);
self::$schema_file = __DIR__ . '/../tmp/' . $schema_md5 . '.json'; if (!empty($setup_extensions))
self::$phpbb_schema_copy = __DIR__ . '/../tmp/schema_phpbb_copy.json';
self::$install_schema_file = __DIR__ . '/../../phpBB/install/schemas/schema.json';
if (!file_exists(self::$schema_file))
{ {
global $phpbb_root_path, $phpEx, $table_prefix;
$finder = new \phpbb\finder(new \phpbb\filesystem(), $phpbb_root_path, null, $phpEx);
$classes = $finder->core_path('phpbb/db/migration/data/') $classes = $finder->core_path('phpbb/db/migration/data/')
->set_extensions($setup_extensions) ->set_extensions($setup_extensions)
->extension_directory('/migrations') ->extension_directory('/migrations')
->get_classes(); ->get_classes();
$db = new \phpbb\db\driver\sqlite(); }
$schema_generator = new \phpbb\db\migration\schema_generator($classes, new \phpbb\config\config(array()), $db, new \phpbb\db\tools($db, true), $phpbb_root_path, $phpEx, $table_prefix); else
$schema_data = $schema_generator->get_schema(); {
file_put_contents(self::$schema_file, json_encode($schema_data)); $classes = $finder->core_path('phpbb/db/migration/data/')
->get_classes();
} }
copy(self::$install_schema_file, self::$phpbb_schema_copy); $db = new \phpbb\db\driver\sqlite();
copy(self::$schema_file, self::$install_schema_file); $schema_generator = new \phpbb\db\migration\schema_generator($classes, new \phpbb\config\config(array()), $db, new \phpbb\db\tools($db, true), $phpbb_root_path, $phpEx, $table_prefix);
$schema_data = $schema_generator->get_schema();
file_put_contents(self::$schema_file, json_encode($schema_data));
} }
copy(self::$schema_file, self::$install_schema_file);
parent::setUpBeforeClass(); parent::setUpBeforeClass();
} }
static public function tearDownAfterClass() static public function tearDownAfterClass()
{ {
if (self::$schema_file !== '') unlink(self::$install_schema_file);
{
copy(self::$phpbb_schema_copy, self::$install_schema_file);
unlink(self::$schema_file);
}
parent::tearDownAfterClass(); parent::tearDownAfterClass();
} }

View file

@ -356,8 +356,23 @@ class phpbb_database_test_connection_manager
} }
// Ok we have the db info go ahead and work on building the table // Ok we have the db info go ahead and work on building the table
$db_table_schema = file_get_contents($directory . 'schema.json'); if (file_exists($directory . 'schema.json'))
$db_table_schema = json_decode($db_table_schema, true); {
$db_table_schema = file_get_contents($directory . 'schema.json');
$db_table_schema = json_decode($db_table_schema, true);
}
else
{
global $phpbb_root_path, $phpEx, $table_prefix;
$finder = new \phpbb\finder(new \phpbb\filesystem(), $phpbb_root_path, null, $phpEx);
$classes = $finder->core_path('phpbb/db/migration/data/')
->get_classes();
$db = new \phpbb\db\driver\sqlite();
$schema_generator = new \phpbb\db\migration\schema_generator($classes, new \phpbb\config\config(array()), $db, new \phpbb\db\tools($db, true), $phpbb_root_path, $phpEx, $table_prefix);
$db_table_schema = $schema_generator->get_schema();
}
$db_tools = new \phpbb\db\tools($db, true); $db_tools = new \phpbb\db\tools($db, true);
foreach ($db_table_schema as $table_name => $table_data) foreach ($db_table_schema as $table_name => $table_data)