function UpdateContribTest::testHookUpdateStatusAlter

Same name in other branches
  1. 9 core/modules/update/tests/src/Functional/UpdateContribTest.php \Drupal\Tests\update\Functional\UpdateContribTest::testHookUpdateStatusAlter()
  2. 10 core/modules/update/tests/src/Functional/UpdateContribTest.php \Drupal\Tests\update\Functional\UpdateContribTest::testHookUpdateStatusAlter()
  3. 11.x core/modules/update/tests/src/Functional/UpdateContribTest.php \Drupal\Tests\update\Functional\UpdateContribTest::testHookUpdateStatusAlter()

Checks that hook_update_status_alter() works to change a status.

We provide the same external data as if aaa_update_test 8.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/src/Functional/UpdateContribTest.php, line 508

Class

UpdateContribTest
Tests how the Update Manager module handles contributed modules and themes in a series of functional tests using mock XML data.

Namespace

Drupal\Tests\update\Functional

Code

public function testHookUpdateStatusAlter() {
    $update_test_config = $this->config('update_test.settings');
    $update_admin_user = $this->drupalCreateUser([
        'administer site configuration',
        'administer software updates',
    ]);
    $this->drupalLogin($update_admin_user);
    $system_info = [
        '#all' => [
            'version' => '8.0.0',
        ],
        'aaa_update_test' => [
            'project' => 'aaa_update_test',
            'version' => '8.x-1.0',
            'hidden' => FALSE,
        ],
    ];
    $update_test_config->set('system_info', $system_info)
        ->save();
    $update_status = [
        'aaa_update_test' => [
            'status' => UpdateManagerInterface::NOT_SECURE,
        ],
    ];
    $update_test_config->set('update_status', $update_status)
        ->save();
    $this->refreshUpdateStatus([
        'drupal' => '0.0',
        'aaa_update_test' => '1_0',
    ]);
    $this->drupalGet('admin/reports/updates');
    $this->assertRaw('<h3>' . t('Modules') . '</h3>');
    $this->assertText(t('Security update required!'));
    $this->assertRaw(Link::fromTextAndUrl(t('AAA Update test'), Url::fromUri('http://example.com/project/aaa_update_test'))->toString(), 'Link to aaa_update_test project appears.');
    // Visit the reports page again without the altering and make sure the
    // status is back to normal.
    $update_test_config->set('update_status', [])
        ->save();
    $this->drupalGet('admin/reports/updates');
    $this->assertRaw('<h3>' . t('Modules') . '</h3>');
    $this->assertNoText(t('Security update required!'));
    $this->assertRaw(Link::fromTextAndUrl(t('AAA Update test'), Url::fromUri('http://example.com/project/aaa_update_test'))->toString(), 'Link to aaa_update_test project appears.');
    // Turn the altering back on and visit the Update manager UI.
    $update_test_config->set('update_status', $update_status)
        ->save();
    $this->drupalGet('admin/modules/update');
    $this->assertText(t('Security update'));
    // Turn the altering back off and visit the Update manager UI.
    $update_test_config->set('update_status', [])
        ->save();
    $this->drupalGet('admin/modules/update');
    $this->assertNoText(t('Security update'));
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.