Merge pull request #7620 from open-sausages/pulls/4.0/its-too-big-to-fit

BUG Added warning for auto-generated table_name
This commit is contained in:
Damian Mooyman 2017-11-28 09:42:12 +13:00 committed by GitHub
commit 2fe59680e3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 4 deletions

View File

@ -6,6 +6,7 @@ use Exception;
use SilverStripe\Core\Injector\Injectable; use SilverStripe\Core\Injector\Injectable;
use SilverStripe\Core\Config\Configurable; use SilverStripe\Core\Config\Configurable;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
use SilverStripe\Dev\TestOnly;
use SilverStripe\ORM\FieldType\DBComposite; use SilverStripe\ORM\FieldType\DBComposite;
use SilverStripe\Core\ClassInfo; use SilverStripe\Core\ClassInfo;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
@ -126,6 +127,7 @@ class DataObjectSchema
} }
return null; return null;
} }
/** /**
* Returns the root class (the first to extend from DataObject) for the * Returns the root class (the first to extend from DataObject) for the
* passed class. * passed class.
@ -301,10 +303,25 @@ class DataObjectSchema
$table = Config::inst()->get($class, 'table_name', Config::UNINHERITED); $table = Config::inst()->get($class, 'table_name', Config::UNINHERITED);
// Generate default table name // Generate default table name
if (!$table) { if ($table) {
return $table;
}
if (strpos($class, '\\') === false) {
return $class;
}
if (!ClassInfo::classImplements($class, TestOnly::class)) {
trigger_error(
"It is recommended to define a table_name for your '$class'." .
' Not defining a table_name may cause subsequent table names to be too long and may not be supported' .
' by your current database engine, the generated naming scheme will also change when upgrading to' .
' SilverStripe 5.0 and potentially break.',
E_USER_WARNING
);
}
$separator = DataObjectSchema::config()->uninherited('table_namespace_separator'); $separator = DataObjectSchema::config()->uninherited('table_namespace_separator');
$table = str_replace('\\', $separator, trim($class, '\\')); $table = str_replace('\\', $separator, trim($class, '\\'));
}
return $table; return $table;
} }

View File

@ -2,7 +2,9 @@
namespace SilverStripe\Core\Tests\ClassInfoTest; namespace SilverStripe\Core\Tests\ClassInfoTest;
class ChildClass extends BaseClass use SilverStripe\Dev\TestOnly;
class ChildClass extends BaseClass implements TestOnly
{ {
} }