NormalizerBaseTest.php

Same filename and directory in other branches
  1. 8.9.x core/modules/serialization/tests/src/Unit/Normalizer/NormalizerBaseTest.php
  2. 10 core/modules/serialization/tests/src/Unit/Normalizer/NormalizerBaseTest.php
  3. 11.x core/modules/serialization/tests/src/Unit/Normalizer/NormalizerBaseTest.php

Contains \Drupal\Tests\serialization\Unit\Normalizer\NormalizerBaseTest.

Namespace

Drupal\Tests\serialization\Unit\Normalizer

File

core/modules/serialization/tests/src/Unit/Normalizer/NormalizerBaseTest.php

View source
<?php


/**
 * @file
 * Contains \Drupal\Tests\serialization\Unit\Normalizer\NormalizerBaseTest.
 */
namespace Drupal\Tests\serialization\Unit\Normalizer;

use Drupal\Tests\UnitTestCase;
use Drupal\serialization\Normalizer\NormalizerBase;

/**
 * @coversDefaultClass \Drupal\serialization\Normalizer\NormalizerBase
 * @group serialization
 */
class NormalizerBaseTest extends UnitTestCase {
    
    /**
     * Tests the supportsNormalization method.
     *
     * @dataProvider providerTestSupportsNormalization
     *
     * @param bool $expected_return
     *   The expected boolean return value from supportNormalization.
     * @param mixed $data
     *   The data passed to supportsNormalization.
     * @param string $supported_interface_or_class
     *   (optional) The supported interface or class to set on the normalizer.
     */
    public function testSupportsNormalization($expected_return, $data, $supported_interface_or_class = NULL) {
        $normalizer_base = $this->getMockForAbstractClass('Drupal\\Tests\\serialization\\Unit\\Normalizer\\TestNormalizerBase');
        if (isset($supported_interface_or_class)) {
            $normalizer_base->setSupportedInterfaceOrClass($supported_interface_or_class);
        }
        $this->assertSame($expected_return, $normalizer_base->supportsNormalization($data));
    }
    
    /**
     * Data provider for testSupportsNormalization.
     *
     * @return array
     *   An array of provider data for testSupportsNormalization.
     */
    public function providerTestSupportsNormalization() {
        return [
            // Something that is not an object should return FALSE immediately.
[
                FALSE,
                [],
            ],
            // An object with no class set should return FALSE.
[
                FALSE,
                new \stdClass(),
            ],
            // Set a supported Class.
[
                TRUE,
                new \stdClass(),
                'stdClass',
            ],
            // Set a supported interface.
[
                TRUE,
                new \RecursiveArrayIterator(),
                'RecursiveIterator',
            ],
            // Set a different class.
[
                FALSE,
                new \stdClass(),
                'ArrayIterator',
            ],
            // Set a different interface.
[
                FALSE,
                new \stdClass(),
                'RecursiveIterator',
            ],
        ];
    }

}

/**
 * Test class for NormalizerBase.
 */
abstract class TestNormalizerBase extends NormalizerBase {
    
    /**
     * Sets the protected supportedInterfaceOrClass property.
     *
     * @param string $supported_interface_or_class
     *   The class name to set.
     */
    public function setSupportedInterfaceOrClass($supported_interface_or_class) {
        $this->supportedInterfaceOrClass = $supported_interface_or_class;
    }

}

Classes

Title Deprecated Summary
NormalizerBaseTest @coversDefaultClass \Drupal\serialization\Normalizer\NormalizerBase @group serialization
TestNormalizerBase Test class for NormalizerBase.

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