mirror of
https://github.com/moodle/moodle.git
synced 2025-08-10 11:26:41 +02:00
MDL-58593 database: More efficiently track issued key names
This commit is contained in:
parent
0714bcb2a2
commit
cd729dc905
2 changed files with 51 additions and 7 deletions
|
@ -2080,6 +2080,38 @@ class core_ddl_testcase extends database_driver_testcase {
|
|||
strlen($gen->getNameForObject($table, $fields, $suffix)),
|
||||
'Generated object name is too long. $i = '.$i);
|
||||
}
|
||||
|
||||
// Now test to confirm that a duplicate name isn't issued, even if they come from different root names.
|
||||
// Move to a new field.
|
||||
$fields = "fl";
|
||||
|
||||
// Insert twice, moving is to a key with fl2.
|
||||
$this->assertEquals($gen->names_max_length - 1, strlen($gen->getNameForObject($table, $fields, $suffix)));
|
||||
$result1 = $gen->getNameForObject($table, $fields, $suffix);
|
||||
|
||||
// Make sure we end up with _fl2_ in the result.
|
||||
$this->assertRegExp('/_fl2_/', $result1);
|
||||
|
||||
// Now, use a field that would result in the same key if it wasn't already taken.
|
||||
$fields = "fl2";
|
||||
// Because we are now at the max key length, it will try:
|
||||
// - _fl2_ (the natural name)
|
||||
// - _fl2_ (removing the original 2, and adding a counter 2)
|
||||
// - then settle on _fl3_.
|
||||
$result2 = $gen->getNameForObject($table, $fields, $suffix);
|
||||
$this->assertRegExp('/_fl3_/', $result2);
|
||||
|
||||
// Make sure they don't match.
|
||||
$this->assertNotEquals($result1, $result2);
|
||||
// But are only different in the way we expect. This confirms the test is working properly.
|
||||
$this->assertEquals(str_replace('_fl2_', '', $result1), str_replace('_fl3_', '', $result2));
|
||||
|
||||
// Now go back. We would expect the next result to be fl3 again, but it is taken, so it should move to fl4.
|
||||
$fields = "fl";
|
||||
$result3 = $gen->getNameForObject($table, $fields, $suffix);
|
||||
|
||||
$this->assertNotEquals($result2, $result3);
|
||||
$this->assertRegExp('/_fl4_/', $result3);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue