You are here

public function UpdateSemverTestBase::securityUpdateAvailabilityProvider in Drupal 9

Data provider method for testSecurityUpdateAvailability().

These test cases rely on the following fixtures containing the following releases:

  • [::$updateProject].sec.0.1_0.2.xml

    • 8.0.2 Security update
    • 8.0.1 Security update, Insecure
    • 8.0.0 Insecure
  • [::$updateProject].sec.0.2.xml
    • 8.0.2 Security update
    • 8.0.1 Insecure
    • 8.0.0 Insecure
  • [::$updateProject].sec.0.2-rc2.xml
    • 8.2.0-rc2 Security update
    • 8.2.0-rc1 Insecure
    • 8.2.0-beta2 Insecure
    • 8.2.0-beta1 Insecure
    • 8.2.0-alpha2 Insecure
    • 8.2.0-alpha1 Insecure
    • 8.1.2 Security update
    • 8.1.1 Insecure
    • 8.1.0 Insecure
    • 8.0.2 Security update
    • 8.0.1 Insecure
    • 8.0.0 Insecure
  • [::$updateProject].sec.1.2.xml
    • 8.1.2 Security update
    • 8.1.1 Insecure
    • 8.1.0 Insecure
    • 8.0.2
    • 8.0.1
    • 8.0.0
  • [::$updateProject].sec.1.2_insecure.xml
    • 8.1.2 Security update
    • 8.1.1 Insecure
    • 8.1.0 Insecure
    • 8.0.2 Insecure
    • 8.0.1 Insecure
    • 8.0.0 Insecure
  • [::$updateProject].sec.1.2_insecure-unsupported This file has the exact releases as [::$updateProject].sec.1.2_insecure.xml. It has a different value for 'supported_branches' that does not contain '8.0.'. It is used to ensure that the "Security update required!" is displayed even if the currently installed version is in an unsupported branch.
  • [::$updateProject].sec.0.2-rc2-b.xml
    • 8.2.0-rc2
    • 8.2.0-rc1
    • 8.2.0-beta2
    • 8.2.0-beta1
    • 8.2.0-alpha2
    • 8.2.0-alpha1
    • 8.1.2 Security update
    • 8.1.1 Insecure
    • 8.1.0 Insecure
    • 8.0.2 Security update
    • 8.0.1 Insecure
    • 8.0.0 Insecure

File

core/modules/update/tests/src/Functional/UpdateSemverTestBase.php, line 258

Class

UpdateSemverTestBase
Common test methods for projects that use semver version releases.

Namespace

Drupal\Tests\update\Functional

Code

public function securityUpdateAvailabilityProvider() {
  $test_cases = [
    // Security release available for site minor release 0.
    // No releases for next minor.
    '0.0, 0.2' => [
      'site_patch_version' => '0.0',
      'expected_security_releases' => [
        '0.2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.0.2',
    ],
    // Site on latest security release available for site minor release 0.
    // Minor release 1 also has a security release, and the current release
    // is marked as insecure.
    '0.2, 0.2' => [
      'site_patch_version' => '0.2',
      'expected_security_release' => [
        '1.2',
        '2.0-rc2',
      ],
      'expected_update_message_type' => static::UPDATE_AVAILABLE,
      'fixture' => 'sec.0.2-rc2',
    ],
    // Two security releases available for site minor release 0.
    // 0.1 security release marked as insecure.
    // No releases for next minor.
    '0.0, 0.1 0.2' => [
      'site_patch_version' => '0.0',
      'expected_security_releases' => [
        '0.2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.0.1_0.2',
    ],
    // Security release available for site minor release 1.
    // No releases for next minor.
    '1.0, 1.2' => [
      'site_patch_version' => '1.0',
      'expected_security_releases' => [
        '1.2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.1.2',
    ],
    // Security release available for site minor release 0.
    // Security release also available for next minor.
    '0.0, 0.2 1.2' => [
      'site_patch_version' => '0.0',
      'expected_security_releases' => [
        '0.2',
        '1.2',
        '2.0-rc2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.0.2-rc2',
    ],
    // No newer security release for site minor 1.
    // Previous minor has security release.
    '1.2, 0.2 1.2' => [
      'site_patch_version' => '1.2',
      'expected_security_releases' => [],
      'expected_update_message_type' => static::UPDATE_NONE,
      'fixture' => 'sec.0.2-rc2',
    ],
    // No security release available for site minor release 0.
    // Security release available for next minor.
    '0.0, 1.2, insecure' => [
      'site_patch_version' => '0.0',
      'expected_security_releases' => [
        '1.2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.1.2_insecure',
    ],
    // No security release available for site minor release 0.
    // Site minor is not a supported branch.
    // Security release available for next minor.
    '0.0, 1.2, insecure-unsupported' => [
      'site_patch_version' => '0.0',
      'expected_security_releases' => [
        '1.2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.1.2_insecure-unsupported',
    ],
    // All releases for minor 0 are secure.
    // Security release available for next minor.
    '0.0, 1.2, secure' => [
      'site_patch_version' => '0.0',
      'expected_security_release' => [
        '1.2',
      ],
      'expected_update_message_type' => static::UPDATE_AVAILABLE,
      'fixture' => 'sec.1.2',
    ],
    '0.2, 1.2, secure' => [
      'site_patch_version' => '0.2',
      'expected_security_release' => [
        '1.2',
      ],
      'expected_update_message_type' => static::UPDATE_AVAILABLE,
      'fixture' => 'sec.1.2',
    ],
    // Site on 2.0-rc2 which is a security release.
    '2.0-rc2, 0.2 1.2' => [
      'site_patch_version' => '2.0-rc2',
      'expected_security_releases' => [],
      'expected_update_message_type' => static::UPDATE_NONE,
      'fixture' => 'sec.0.2-rc2',
    ],
    // Ensure that 8.0.2 security release is not shown because it is earlier
    // version than 1.0.
    '1.0, 0.2 1.2' => [
      'site_patch_version' => '1.0',
      'expected_security_releases' => [
        '1.2',
        '2.0-rc2',
      ],
      'expected_update_message_type' => static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.0.2-rc2',
    ],
  ];
  $pre_releases = [
    '2.0-alpha1',
    '2.0-alpha2',
    '2.0-beta1',
    '2.0-beta2',
    '2.0-rc1',
    '2.0-rc2',
  ];
  foreach ($pre_releases as $pre_release) {

    // If the site is on an alpha/beta/RC of an upcoming minor and none of the
    // alpha/beta/RC versions are marked insecure, no security update should
    // be required.
    $test_cases["Pre-release:{$pre_release}, no security update"] = [
      'site_patch_version' => $pre_release,
      'expected_security_releases' => [],
      'expected_update_message_type' => $pre_release === '2.0-rc2' ? static::UPDATE_NONE : static::UPDATE_AVAILABLE,
      'fixture' => 'sec.0.2-rc2-b',
    ];

    // If the site is on an alpha/beta/RC of an upcoming minor and there is
    // an RC version with a security update, it should be recommended.
    $test_cases["Pre-release:{$pre_release}, security update"] = [
      'site_patch_version' => $pre_release,
      'expected_security_releases' => $pre_release === '2.0-rc2' ? [] : [
        '2.0-rc2',
      ],
      'expected_update_message_type' => $pre_release === '2.0-rc2' ? static::UPDATE_NONE : static::SECURITY_UPDATE_REQUIRED,
      'fixture' => 'sec.0.2-rc2',
    ];
  }
  return $test_cases;
}