Refs #29548 -- Mentioned MariaDB in database system checks.

This commit is contained in:
Mariusz Felisiak 2020-03-19 09:42:04 +01:00 committed by GitHub
parent fc0fa72ff4
commit 6e026aec5f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 23 additions and 13 deletions

View File

@ -12,12 +12,20 @@ class DatabaseValidation(BaseDatabaseValidation):
def _check_sql_mode(self, **kwargs): def _check_sql_mode(self, **kwargs):
if not (self.connection.sql_mode & {'STRICT_TRANS_TABLES', 'STRICT_ALL_TABLES'}): if not (self.connection.sql_mode & {'STRICT_TRANS_TABLES', 'STRICT_ALL_TABLES'}):
return [checks.Warning( return [checks.Warning(
"MySQL Strict Mode is not set for database connection '%s'" % self.connection.alias, "%s Strict Mode is not set for database connection '%s'"
hint="MySQL's Strict Mode fixes many data integrity problems in MySQL, " % (self.connection.display_name, self.connection.alias),
"such as data truncation upon insertion, by escalating warnings into " hint=(
"errors. It is strongly recommended you activate it. See: " "%s's Strict Mode fixes many data integrity problems in "
"%s, such as data truncation upon insertion, by "
"escalating warnings into errors. It is strongly "
"recommended you activate it. See: "
"https://docs.djangoproject.com/en/%s/ref/databases/#mysql-sql-mode" "https://docs.djangoproject.com/en/%s/ref/databases/#mysql-sql-mode"
% (get_docs_version(),), % (
self.connection.display_name,
self.connection.display_name,
get_docs_version(),
),
),
id='mysql.W002', id='mysql.W002',
)] )]
return [] return []
@ -34,7 +42,8 @@ class DatabaseValidation(BaseDatabaseValidation):
(field.max_length is None or int(field.max_length) > 255)): (field.max_length is None or int(field.max_length) > 255)):
errors.append( errors.append(
checks.Error( checks.Error(
'MySQL does not allow unique CharFields to have a max_length > 255.', '%s does not allow unique CharFields to have a max_length '
'> 255.' % self.connection.display_name,
obj=field, obj=field,
id='mysql.E001', id='mysql.E001',
) )

View File

@ -121,14 +121,14 @@ configured:
Database Database
-------- --------
MySQL MySQL and MariaDB
~~~~~ ~~~~~~~~~~~~~~~~~
If you're using MySQL, the following checks will be performed: If you're using MySQL or MariaDB, the following checks will be performed:
* **mysql.E001**: MySQL does not allow unique ``CharField``\s to have a * **mysql.E001**: MySQL/MariaDB does not allow unique ``CharField``\s to have a
``max_length`` > 255. ``max_length`` > 255.
* **mysql.W002**: MySQL Strict Mode is not set for database connection * **mysql.W002**: MySQL/MariaDB Strict Mode is not set for database connection
'<alias>'. See also :ref:`mysql-sql-mode`. '<alias>'. See also :ref:`mysql-sql-mode`.
Model fields Model fields

View File

@ -373,7 +373,8 @@ class CharFieldTests(SimpleTestCase):
validator = DatabaseValidation(connection=connection) validator = DatabaseValidation(connection=connection)
self.assertEqual(validator.check_field(field), [ self.assertEqual(validator.check_field(field), [
Error( Error(
'MySQL does not allow unique CharFields to have a max_length > 255.', '%s does not allow unique CharFields to have a max_length > '
'255.' % connection.display_name,
obj=field, obj=field,
id='mysql.E001', id='mysql.E001',
) )