mirror of
https://github.com/moodle/moodle.git
synced 2025-08-06 09:26:35 +02:00
MDL-66935 core_lock: Fix resource key clashes in db and postgres locks
This commit is contained in:
parent
9f997f9bd7
commit
7e086935e3
5 changed files with 86 additions and 32 deletions
|
@ -46,31 +46,57 @@ class lock_config_testcase extends advanced_testcase {
|
|||
if (isset($CFG->lock_factory)) {
|
||||
$original = $CFG->lock_factory;
|
||||
}
|
||||
$originalfilelocking = null;
|
||||
if (isset($CFG->preventfilelocking)) {
|
||||
$originalfilelocking = $CFG->preventfilelocking;
|
||||
}
|
||||
|
||||
// Test no configuration.
|
||||
unset($CFG->lock_factory);
|
||||
|
||||
$CFG->preventfilelocking = 0;
|
||||
$factory = \core\lock\lock_config::get_lock_factory('cache');
|
||||
|
||||
$this->assertNotEmpty($factory, 'Get a default factory with no configuration');
|
||||
|
||||
$CFG->lock_factory = '\core\lock\file_lock_factory';
|
||||
// Test explicit broken lock.
|
||||
$CFG->lock_factory = '\core\lock\not_a_lock_factory';
|
||||
try {
|
||||
$factory = \core\lock\lock_config::get_lock_factory('cache');
|
||||
$this->fail('Exception expected');
|
||||
} catch (moodle_exception $ex) {
|
||||
$this->assertInstanceOf('coding_exception', $ex);
|
||||
}
|
||||
|
||||
// Test explicit file locks.
|
||||
$CFG->lock_factory = '\core\lock\file_lock_factory';
|
||||
$factory = \core\lock\lock_config::get_lock_factory('cache');
|
||||
$this->assertTrue($factory instanceof \core\lock\file_lock_factory,
|
||||
'Get a default factory with a set configuration');
|
||||
'Get an explicit file lock factory');
|
||||
|
||||
// Test explicit file locks but with file locks prevented.
|
||||
$CFG->preventfilelocking = 1;
|
||||
try {
|
||||
$factory = \core\lock\lock_config::get_lock_factory('cache');
|
||||
$this->fail('Exception expected');
|
||||
} catch (moodle_exception $ex) {
|
||||
$this->assertInstanceOf('coding_exception', $ex);
|
||||
}
|
||||
|
||||
// Test explicit db locks.
|
||||
$CFG->lock_factory = '\core\lock\db_record_lock_factory';
|
||||
|
||||
$factory = \core\lock\lock_config::get_lock_factory('cache');
|
||||
$this->assertTrue($factory instanceof \core\lock\db_record_lock_factory,
|
||||
'Get a default factory with a changed configuration');
|
||||
'Get an explicit db record lock factory');
|
||||
|
||||
if ($original) {
|
||||
$CFG->lock_factory = $original;
|
||||
} else {
|
||||
unset($CFG->lock_factory);
|
||||
}
|
||||
if ($originalfilelocking) {
|
||||
$CFG->preventfilelocking = $originalfilelocking;
|
||||
} else {
|
||||
unset($CFG->preventfilelocking);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue