Skip to content
GitLab
Menu
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
moodle
moodle
Commits
0dd508d6
Commit
0dd508d6
authored
Nov 22, 2021
by
Eloy Lafuente
Committed by
jun
Nov 23, 2021
Browse files
Merge branch 'MDL-73095_master_v3' of
https://github.com/TomoTsuyuki/moodle
Added one extra TEXT column so we have it covered too.
parents
89ab2b1c
cb4e37c4
Changes
2
Hide whitespace changes
Inline
Side-by-side
lib/ddl/database_manager.php
View file @
0dd508d6
...
...
@@ -1039,52 +1039,60 @@ class database_manager {
$errors
[
$tablename
][]
=
"column '
$fieldname
' should allow NULL (
$dbfield->meta_type
)"
;
}
}
if
(
$dbtype
==
XMLDB_TYPE_TEXT
)
{
// No length check necessary - there is one size only now.
}
else
if
(
$dbtype
==
XMLDB_TYPE_NUMBER
)
{
if
(
$field
->
getType
()
==
XMLDB_TYPE_FLOAT
)
{
switch
(
$dbtype
)
{
case
XMLDB_TYPE_TEXT
:
case
XMLDB_TYPE_BINARY
:
// No length check necessary - there is one size only now.
break
;
case
XMLDB_TYPE_NUMBER
:
$lengthmismatch
=
$field
->
getLength
()
!=
$dbfield
->
max_length
;
$decimalmismatch
=
$field
->
getDecimals
()
!=
$dbfield
->
scale
;
// Do not use floats in any new code, they are deprecated in XMLDB editor!
if
(
$field
->
getType
()
!=
XMLDB_TYPE_FLOAT
&&
(
$lengthmismatch
||
$decimalmismatch
))
{
$size
=
"(
{
$field
->
getLength
()
}
,
{
$field
->
getDecimals
()
}
)"
;
$dbsize
=
"(
$dbfield->max_length
,
$dbfield->scale
)"
;
$errors
[
$tablename
][]
=
"column '
$fieldname
' size is
$dbsize
,"
.
" expected
$size
(
$dbfield->meta_type
)"
;
}
break
;
case
XMLDB_TYPE_CHAR
:
// This is not critical, but they should ideally match.
if
(
$field
->
getLength
()
!=
$dbfield
->
max_length
)
{
$errors
[
$tablename
][]
=
"column '
$fieldname
' length is
$dbfield->max_length
,"
.
" expected
{
$field
->
getLength
()
}
(
$dbfield->meta_type
)"
;
}
break
;
case
XMLDB_TYPE_INTEGER
:
// Integers may be bigger in some DBs.
$length
=
$field
->
getLength
();
if
(
$length
>
18
)
{
// Integers are not supposed to be bigger than 18.
$length
=
18
;
}
if
(
$length
>
$dbfield
->
max_length
)
{
$errors
[
$tablename
][]
=
"column '
$fieldname
' length is
$dbfield->max_length
,"
.
" expected at least
{
$field
->
getLength
()
}
(
$dbfield->meta_type
)"
;
}
break
;
case
XMLDB_TYPE_TIMESTAMP
:
$errors
[
$tablename
][]
=
"column '
$fieldname
' is a timestamp,"
.
" this type is not supported (
$dbfield->meta_type
)"
;
continue
2
;
case
XMLDB_TYPE_DATETIME
:
$errors
[
$tablename
][]
=
"column '
$fieldname
' is a datetime,"
.
"this type is not supported (
$dbfield->meta_type
)"
;
continue
2
;
default
:
// Report all other unsupported types as problems.
$errors
[
$tablename
][]
=
"column '
$fieldname
' has unknown type (
$dbfield->meta_type
)"
;
continue
2
;
}
else
if
(
$field
->
getLength
()
!=
$dbfield
->
max_length
or
$field
->
getDecimals
()
!=
$dbfield
->
scale
)
{
$size
=
"(
{
$field
->
getLength
()
}
,
{
$field
->
getDecimals
()
}
)"
;
$dbsize
=
"(
$dbfield->max_length
,
$dbfield->scale
)"
;
$errors
[
$tablename
][]
=
"column '
$fieldname
' size is
$dbsize
, expected
$size
(
$dbfield->meta_type
)"
;
}
}
else
if
(
$dbtype
==
XMLDB_TYPE_CHAR
)
{
// This is not critical, but they should ideally match.
if
(
$field
->
getLength
()
!=
$dbfield
->
max_length
)
{
$errors
[
$tablename
][]
=
"column '
$fieldname
' length is
$dbfield->max_length
, expected
{
$field
->
getLength
()
}
(
$dbfield->meta_type
)"
;
}
}
else
if
(
$dbtype
==
XMLDB_TYPE_INTEGER
)
{
// Integers may be bigger in some DBs.
$length
=
$field
->
getLength
();
if
(
$length
>
18
)
{
// Integers are not supposed to be bigger than 18.
$length
=
18
;
}
if
(
$length
>
$dbfield
->
max_length
)
{
$errors
[
$tablename
][]
=
"column '
$fieldname
' length is
$dbfield->max_length
, expected at least
{
$field
->
getLength
()
}
(
$dbfield->meta_type
)"
;
}
}
else
if
(
$dbtype
==
XMLDB_TYPE_BINARY
)
{
// Ignore binary types.
continue
;
}
else
if
(
$dbtype
==
XMLDB_TYPE_TIMESTAMP
)
{
$errors
[
$tablename
][]
=
"column '
$fieldname
' is a timestamp, this type is not supported (
$dbfield->meta_type
)"
;
continue
;
}
else
if
(
$dbtype
==
XMLDB_TYPE_DATETIME
)
{
$errors
[
$tablename
][]
=
"column '
$fieldname
' is a datetime, this type is not supported (
$dbfield->meta_type
)"
;
continue
;
}
else
{
// Report all other unsupported types as problems.
$errors
[
$tablename
][]
=
"column '
$fieldname
' has unknown type (
$dbfield->meta_type
)"
;
continue
;
}
// Note: The empty string defaults are a bit messy...
...
...
lib/ddl/tests/ddl_test.php
View file @
0dd508d6
...
...
@@ -2454,6 +2454,7 @@ class core_ddl_testcase extends database_driver_testcase {
$table
->
add_field
(
'id'
,
XMLDB_TYPE_INTEGER
,
'10'
,
null
,
XMLDB_NOTNULL
,
XMLDB_SEQUENCE
,
null
);
$table
->
add_field
(
'extracolumn'
,
XMLDB_TYPE_INTEGER
,
'10'
,
null
,
XMLDB_NOTNULL
,
null
,
null
);
$table
->
add_field
(
'courseid'
,
XMLDB_TYPE_INTEGER
,
'10'
,
null
,
XMLDB_NOTNULL
,
null
,
null
);
$table
->
add_field
(
'binaryfield'
,
XMLDB_TYPE_BINARY
,
null
,
null
,
XMLDB_NOTNULL
,
null
,
null
);
$table
->
add_key
(
'primary'
,
XMLDB_KEY_PRIMARY
,
array
(
'id'
));
$table
->
add_key
(
'extraindex'
,
XMLDB_KEY_UNIQUE
,
array
(
'extracolumn'
));
$table
->
setComment
(
"This is a test table, you can drop it safely."
);
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment