function UpdateContribTest::testHookUpdateStatusAlter

Same name and namespace in other branches
  1. 9 core/modules/update/tests/src/Functional/UpdateContribTest.php \Drupal\Tests\update\Functional\UpdateContribTest::testHookUpdateStatusAlter()
  2. 8.9.x 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 497

Class

UpdateContribTest
Tests how the Update Manager handles contributed modules and themes.

Namespace

Drupal\Tests\update\Functional

Code

public function testHookUpdateStatusAlter() : void {
  $update_admin_user = $this->drupalCreateUser([
    'administer site configuration',
    'administer software updates',
  ]);
  $this->drupalLogin($update_admin_user);
  $this->mockInstalledExtensionsInfo([
    'aaa_update_test' => [
      'project' => 'aaa_update_test',
      'version' => '8.x-1.0',
      'hidden' => FALSE,
    ],
  ]);
  $this->mockDefaultExtensionsInfo([
    'version' => '8.0.0',
  ]);
  $update_test_config = $this->config('update_test.settings');
  $update_status = [
    'aaa_update_test' => [
      'status' => UpdateManagerInterface::NOT_SECURE,
    ],
  ];
  $update_test_config->set('update_status', $update_status)
    ->save();
  $this->refreshUpdateStatus([
    'drupal' => '8.0.0',
    'aaa_update_test' => '1_0',
  ]);
  $this->assertSession()
    ->responseContains('<h3>Modules</h3>');
  $this->assertSession()
    ->pageTextContains('Security update required!');
  $this->assertSession()
    ->linkExists('AAA Update test');
  $this->assertSession()
    ->linkByHrefExists('http://example.com/project/aaa_update_test');
  // 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->assertSession()
    ->responseContains('<h3>Modules</h3>');
  $this->assertSession()
    ->pageTextNotContains('Security update required!');
  $this->assertSession()
    ->linkExists('AAA Update test');
  $this->assertSession()
    ->linkByHrefExists('http://example.com/project/aaa_update_test');
  // 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->assertSession()
    ->pageTextContains('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->assertSession()
    ->pageTextNotContains('Security update');
}

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