1 update.test | UpdateTestContribCase::testHookUpdateStatusAlter() |
Check that hook_update_status_alter() works to change a status.
We provide the same external data as if aaa_update_test 1.x-1.0 were installed and that was the latest release. Then we use hook_update_status_alter() to try to mark this as missing a security update, then assert if we see the appropriate warnings on the right pages.
File
- core/
modules/ update/ tests/ update.test, line 611 - This file contains tests for the Update Manager module.
Class
Code
function testHookUpdateStatusAlter() {
$GLOBALS['settings']['allow_authorize_operations'] = TRUE;
$config = config('update.settings');
$update_admin_user = $this->backdropCreateUser(array(
'administer site configuration',
'administer software updates',
'access site reports',
));
$this->backdropLogin($update_admin_user);
$system_info = array(
'#all' => array(
'version' => '1.0',
),
'aaa_update_test' => array(
'project' => 'aaa_update_test',
'version' => '1.x-1.0',
'hidden' => FALSE,
),
);
state_set('update_test_system_info', $system_info);
$update_status = array(
'aaa_update_test' => array(
'status' => UPDATE_NOT_SECURE,
),
);
$config->set('update_status', $update_status)->save();
$this->refreshUpdateStatus(
array(
'backdrop' => '0',
'aaa_update_test' => '1_0',
)
);
$this->backdropGet('admin/reports/updates');
$this->assertRaw('<h3>' . t('Modules') . '</h3>');
$this->assertText(t('Security update required!'));
$this->assertRaw(l(t('AAA Update test'), 'http://example.com/project/aaa_update_test'), 'Link to aaa_update_test project appears.');
// Visit the reports page again without the altering and make sure the
// status is back to normal.
$config->set('update_status', array())->save();
$this->backdropGet('admin/reports/updates');
$this->assertRaw('<h3>' . t('Modules') . '</h3>');
$this->assertNoText(t('Security update required!'));
$this->assertRaw(l(t('AAA Update test'), 'http://example.com/project/aaa_update_test'), 'Link to aaa_update_test project appears.');
}