diff --git a/src/ORM/Connect/TableBuilder.php b/src/ORM/Connect/TableBuilder.php new file mode 100644 index 00000000000..7b2e3cc41ef --- /dev/null +++ b/src/ORM/Connect/TableBuilder.php @@ -0,0 +1,69 @@ +schemaUpdate(function () use ($dataClasses, $extraDataObjects, $testMode, $quiet, $showRecordCounts) { + $dataObjectSchema = DataObject::getSchema(); + + foreach ($dataClasses as $dataClass) { + // Check if class exists before trying to instantiate - this sidesteps any manifest weirdness + if (!class_exists($dataClass)) { + continue; + } + + // Check if this class should be excluded as per testing conventions + /** @var DataObject $SNG */ + $SNG = new $dataClass([], DataObject::CREATE_SINGLETON); + if (!$testMode && $SNG instanceof TestOnly) { + continue; + } + + // Log data + if (!$quiet) { + $tableName = $dataObjectSchema->tableName($dataClass); + if ($showRecordCounts && DB::get_schema()->hasTable($tableName)) { + try { + $count = DB::query("SELECT COUNT(*) FROM \"$tableName\"")->value(); + $countSuffix = " ($count records)"; + } catch (\Exception $e) { + $countSuffix = " (error getting record count)"; + } + } else { + $countSuffix = ""; + } + + if (Director::is_cli()) { + echo " * $tableName$countSuffix\n"; + } else { + echo "
  • $tableName$countSuffix
  • \n"; + } + } + + // Instruct the class to apply its schema to the database + $SNG->requireTable(); + } + + // If we have additional dataobjects which need schema (i.e. for tests), do so here: + if ($extraDataObjects) { + foreach ($extraDataObjects as $dataClass) { + $SNG = new $dataClass([], DataObject::CREATE_SINGLETON); + if ($SNG instanceof DataObject) { + $SNG->requireTable(); + } + } + } + }); + } +} diff --git a/src/ORM/Connect/TempDatabase.php b/src/ORM/Connect/TempDatabase.php index a268adf8943..ced43d8469d 100644 --- a/src/ORM/Connect/TempDatabase.php +++ b/src/ORM/Connect/TempDatabase.php @@ -244,29 +244,9 @@ protected function rebuildTables($extraDataObjects = []) $schema = $this->getConn()->getSchemaManager(); $schema->quiet(); - $schema->schemaUpdate( - function () use ($dataClasses, $extraDataObjects) { - foreach ($dataClasses as $dataClass) { - // Check if class exists before trying to instantiate - this sidesteps any manifest weirdness - if (class_exists($dataClass ?? '')) { - $SNG = singleton($dataClass); - if (!($SNG instanceof TestOnly)) { - $SNG->requireTable(); - } - } - } - // If we have additional dataobjects which need schema, do so here: - if ($extraDataObjects) { - foreach ($extraDataObjects as $dataClass) { - $SNG = singleton($dataClass); - if (singleton($dataClass) instanceof DataObject) { - $SNG->requireTable(); - } - } - } - } - ); + $tableBuilder = TableBuilder::singleton(); + $tableBuilder->buildTables($schema, $dataClasses, $extraDataObjects, true); Config::modify()->set(DBSchemaManager::class, 'check_and_repair_on_build', $oldCheckAndRepairOnBuild); diff --git a/src/ORM/DatabaseAdmin.php b/src/ORM/DatabaseAdmin.php index 30ca53b2520..c10ef679b45 100644 --- a/src/ORM/DatabaseAdmin.php +++ b/src/ORM/DatabaseAdmin.php @@ -14,6 +14,7 @@ use SilverStripe\Dev\DevelopmentAdmin; use SilverStripe\Dev\TestOnly; use SilverStripe\ORM\Connect\DatabaseException; +use SilverStripe\ORM\Connect\TableBuilder; use SilverStripe\ORM\FieldType\DBClassName; use SilverStripe\Security\Permission; use SilverStripe\Security\Security; @@ -304,46 +305,8 @@ public function doBuild($quiet = false, $populate = true, $testMode = false) // Initiate schema update $dbSchema = DB::get_schema(); - $dbSchema->schemaUpdate(function () use ($dataClasses, $testMode, $quiet, $showRecordCounts) { - $dataObjectSchema = DataObject::getSchema(); - - foreach ($dataClasses as $dataClass) { - // Check if class exists before trying to instantiate - this sidesteps any manifest weirdness - if (!class_exists($dataClass ?? '')) { - continue; - } - - // Check if this class should be excluded as per testing conventions - $SNG = new $dataClass([], DataObject::CREATE_SINGLETON); - if (!$testMode && $SNG instanceof TestOnly) { - continue; - } - $tableName = $dataObjectSchema->tableName($dataClass); - - // Log data - if (!$quiet) { - if ($showRecordCounts && DB::get_schema()->hasTable($tableName)) { - try { - $count = DB::query("SELECT COUNT(*) FROM \"$tableName\"")->value(); - $countSuffix = " ($count records)"; - } catch (Exception $e) { - $countSuffix = " (error getting record count)"; - } - } else { - $countSuffix = ""; - } - - if (Director::is_cli()) { - echo " * $tableName$countSuffix\n"; - } else { - echo "
  • $tableName$countSuffix
  • \n"; - } - } - - // Instruct the class to apply its schema to the database - $SNG->requireTable(); - } - }); + $tableBuilder = TableBuilder::singleton(); + $tableBuilder->buildTables($dbSchema, $dataClasses, [], $quiet, $testMode, $showRecordCounts); ClassInfo::reset_db_cache(); if (!$quiet && !Director::is_cli()) {