Skip to content
Snippets Groups Projects
Verified Commit 2a98f613 authored by Alex Pott's avatar Alex Pott
Browse files

Issue #3119761 by dww, aleevas, Hardik_Patel_12, quietone, tedbow,...

Issue #3119761 by dww, aleevas, Hardik_Patel_12, quietone, tedbow, _utsavsharma, smustgrave, xjm, longwave: Replace multiple test methods in InfoParserUnitTest with 1 testInfoException and a dataprovider

(cherry picked from commit 9f6b172c)
parent 5f2e43b3
Branches
Tags
27 merge requests!11769Issue #3517987: Add option to contextual filters to encode slashes in query parameter.,!11185Issue #3477324 by andypost, alexpott: Fix usage of str_getcsv() and fgetcsv() for PHP 8.4,!10602Issue #3438769 by vinmayiswamy, antonnavi, michelle, amateescu: Sub workspace does not clear,!10301Issue #3469309 by mstrelan, smustgrave, moshe weitzman: Use one-time login...,!10187Issue #3487488 by dakwamine: ExtensionMimeTypeGuesser::guessMimeType must support file names with "0" (zero) like foo.0.zip,!9944Issue #3483353: Consider making the createCopy config action optionally fail...,!9929Issue #3445469 by pooja_sharma, smustgrave: Add additional test coverage for...,!9787Resolve issue 3479427 - bootstrap barrio issue under Windows,!9742Issue #3463908 by catch, quietone: Split OptionsFieldUiTest into two,!9526Issue #3458177 by mondrake, catch, quietone, godotislate, longwave, larowlan,...,!8738Issue #3424162 by camilledavis, dineshkumarbollu, smustgrave: Claro...,!8704Make greek characters available in ckeditor5,!8597Draft: Issue #3442259 by catch, quietone, dww: Reduce time of Migrate Upgrade tests...,!8533Issue #3446962 by kim.pepper: Remove incorrectly added...,!8517Issue #3443748 by NexusNovaz, smustgrave: Testcase creates false positive,!8325Update file Sort.php,!8095Expose document root on install,!7930Resolve #3427374 "Taxonomytid viewsargumentdefault plugin",!7627Issue #3439440 by nicxvan, Binoli Lalani, longwave: Remove country support from DateFormatter,!7445Issue #3440169: When using drupalGet(), provide an associative array for $headers,!7401#3271894 Fix documented StreamWrapperInterface return types for realpath() and dirname(),!7384Add constraints to system.advisories,!7078Issue #3320569 by Spokje, mondrake, smustgrave, longwave, quietone, Lendude,...,!6622Issue #2559833 by piggito, mohit_aghera, larowlan, guptahemant, vakulrai,...,!6502Draft: Resolve #2938524 "Plach testing issue",!38582585169-10.1.x,!3226Issue #2987537: Custom menu link entity type should not declare "bundle" entity key
Pipeline #111417 passed
Pipeline: drupal

#111419

    ......@@ -55,94 +55,101 @@ public function testInfoParserNonExisting() {
    /**
    * Tests if correct exception is thrown for a broken info file.
    *
    * @covers ::parse
    * @param string $yaml
    * The YAML to use to create the file to parse.
    * @param string $expected_exception_message
    * The expected exception message.
    *
    * @dataProvider providerInfoException
    */
    public function testInfoParserBroken() {
    $broken_info = <<<BROKEN_INFO
    # info.yml for testing broken YAML parsing exception handling.
    name: File
    type: module
    description: 'Defines a file field type.'
    package: Core
    version: VERSION
    core_version_requirement: '*'
    dependencies::;;
    - field
    BROKEN_INFO;
    public function testInfoException($yaml, $expected_exception_message): void {
    vfsStream::setup('modules');
    vfsStream::create([
    'fixtures' => [
    'broken.info.txt' => $broken_info,
    "broken.info.txt" => $yaml,
    "broken-duplicate.info.txt" => $yaml,
    ],
    ]);
    $filename = vfsStream::url('modules/fixtures/broken.info.txt');
    $this->expectException('\Drupal\Core\Extension\InfoParserException');
    $this->expectExceptionMessage('broken.info.txt');
    $this->infoParser->parse($filename);
    try {
    $this->infoParser->parse(vfsStream::url("modules/fixtures/broken.info.txt"));
    }
    catch (InfoParserException $exception) {
    $this->assertSame("$expected_exception_message vfs://modules/fixtures/broken.info.txt", $exception->getMessage());
    }
    $this->expectException(InfoParserException::class);
    $this->expectExceptionMessage("$expected_exception_message vfs://modules/fixtures/broken-duplicate.info.txt");
    $this->infoParser->parse(vfsStream::url("modules/fixtures/broken-duplicate.info.txt"));
    }
    /**
    * Tests that missing required keys are detected.
    *
    * @covers ::parse
    * Data provider for testInfoException().
    */
    public function testInfoParserMissingKeys() {
    $missing_keys = <<<MISSING_KEYS
    # info.yml for testing missing name, description, and type keys.
    public static function providerInfoException(): array {
    return [
    'missing required key, type' => [
    <<<YML
    name: File
    description: Missing key
    package: Core
    version: VERSION
    dependencies:
    - field
    MISSING_KEYS;
    vfsStream::setup('modules');
    vfsStream::create([
    'fixtures' => [
    'missing_keys.info.txt' => $missing_keys,
    YML,
    "Missing required keys (type) in",
    ],
    ]);
    $filename = vfsStream::url('modules/fixtures/missing_keys.info.txt');
    $this->expectException('\Drupal\Core\Extension\InfoParserException');
    $this->expectExceptionMessage('Missing required keys (type, name) in vfs://modules/fixtures/missing_keys.info.txt');
    $this->infoParser->parse($filename);
    'missing core_version_requirement' => [
    <<<YML
    version: VERSION
    type: module
    name: Skynet
    dependencies:
    - self_awareness
    YML,
    "The 'core_version_requirement' key must be present in",
    ],
    'missing two required keys' => [
    <<<YML
    package: Core
    version: VERSION
    dependencies:
    - field
    YML,
    'Missing required keys (type, name) in',
    ],
    ];
    }
    /**
    * Tests that a missing 'core_version_requirement' key is detected.
    * Tests that the correct exception is thrown for a broken info file.
    *
    * @covers ::parse
    */
    public function testMissingCoreVersionRequirement() {
    $missing_core_version_requirement = <<<MISSING_CORE_VERSION_REQUIREMENT
    # info.yml for testing core_version_requirement.
    version: VERSION
    public function testInfoParserBroken() {
    $broken_info = <<<BROKEN_INFO
    # info.yml for testing broken YAML parsing exception handling.
    name: File
    type: module
    name: Skynet
    dependencies:
    - self_awareness
    MISSING_CORE_VERSION_REQUIREMENT;
    description: 'Defines a file field type.'
    package: Core
    version: VERSION
    core_version_requirement: '*'
    dependencies::;;
    - field
    BROKEN_INFO;
    vfsStream::setup('modules');
    vfsStream::create([
    'fixtures' => [
    'missing_core_version_requirement.info.txt' => $missing_core_version_requirement,
    'missing_core_version_requirement-duplicate.info.txt' => $missing_core_version_requirement,
    'broken.info.txt' => $broken_info,
    ],
    ]);
    $exception_message = "The 'core_version_requirement' key must be present in vfs://modules/fixtures/missing_core_version_requirement";
    // Set the expected exception for the 2nd call to parse().
    $filename = vfsStream::url('modules/fixtures/broken.info.txt');
    $this->expectException('\Drupal\Core\Extension\InfoParserException');
    $this->expectExceptionMessage("$exception_message-duplicate.info.txt");
    try {
    $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_core_version_requirement.info.txt'));
    }
    catch (InfoParserException $exception) {
    $this->assertSame("$exception_message.info.txt", $exception->getMessage());
    $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_core_version_requirement-duplicate.info.txt'));
    }
    $this->expectExceptionMessage('Unable to parse vfs://modules/fixtures/broken.info.txt');
    $this->infoParser->parse($filename);
    }
    /**
    ......@@ -169,43 +176,6 @@ public function testTestingPackageMissingCoreVersionRequirement() {
    $this->assertSame($info_values['core_version_requirement'], \Drupal::VERSION);
    }
    /**
    * Tests that missing required key is detected.
    *
    * @covers ::parse
    */
    public function testInfoParserMissingKey() {
    $missing_key = <<<MISSING_KEY
    # info.yml for testing missing type key.
    name: File
    description: 'Defines a file field type.'
    package: Core
    version: VERSION
    dependencies:
    - field
    MISSING_KEY;
    vfsStream::setup('modules');
    vfsStream::create([
    'fixtures' => [
    'missing_key.info.txt' => $missing_key,
    'missing_key-duplicate.info.txt' => $missing_key,
    ],
    ]);
    // Set the expected exception for the 2nd call to parse().
    $this->expectException(InfoParserException::class);
    $this->expectExceptionMessage('Missing required keys (type) in vfs://modules/fixtures/missing_key-duplicate.info.txt');
    try {
    $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_key.info.txt'));
    }
    catch (InfoParserException $exception) {
    $this->assertSame('Missing required keys (type) in vfs://modules/fixtures/missing_key.info.txt', $exception->getMessage());
    $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_key-duplicate.info.txt'));
    }
    }
    /**
    * Tests common info file.
    *
    ......
    0% Loading or .
    You are about to add 0 people to the discussion. Proceed with caution.
    Please register or to comment