You are here

class FindReplaceTest in Tamper 8

Tests the find and replace plugin.

@coversDefaultClass \Drupal\tamper\Plugin\Tamper\FindReplace @group tamper

Hierarchy

Expanded class hierarchy of FindReplaceTest

File

tests/src/Unit/Plugin/Tamper/FindReplaceTest.php, line 14

Namespace

Drupal\Tests\tamper\Unit\Plugin\Tamper
View source
class FindReplaceTest extends TamperPluginTestBase {

  /**
   * {@inheritdoc}
   */
  protected function instantiatePlugin() {
    $config = [
      FindReplace::SETTING_FIND => '',
      FindReplace::SETTING_REPLACE => '',
      FindReplace::SETTING_CASE_SENSITIVE => FALSE,
      FindReplace::SETTING_WORD_BOUNDARIES => FALSE,
      FindReplace::SETTING_WHOLE => FALSE,
    ];
    return new FindReplace($config, 'find_replace', [], $this
      ->getMockSourceDefinition());
  }

  /**
   * Test the plugin with a single value.
   */
  public function testSingleValue() {
    $config = [
      FindReplace::SETTING_FIND => 'cat',
      FindReplace::SETTING_REPLACE => 'dog',
      FindReplace::SETTING_CASE_SENSITIVE => FALSE,
      FindReplace::SETTING_WORD_BOUNDARIES => FALSE,
      FindReplace::SETTING_WHOLE => FALSE,
    ];
    $plugin = new FindReplace($config, 'find_replace', [], $this
      ->getMockSourceDefinition());
    $this
      ->assertEquals('The dog went to the park.', $plugin
      ->tamper('The cat went to the park.'));
    $this
      ->assertEquals('The dog went to the park.', $plugin
      ->tamper('The Cat went to the park.'));
    $this
      ->assertEquals('The dogwent to the park.', $plugin
      ->tamper('The Catwent to the park.'));
  }

  /**
   * Test the plugin as case sensitve.
   */
  public function testSingleValueCaseSensitive() {
    $config = [
      FindReplace::SETTING_FIND => 'cat',
      FindReplace::SETTING_REPLACE => 'dog',
      FindReplace::SETTING_CASE_SENSITIVE => TRUE,
      FindReplace::SETTING_WORD_BOUNDARIES => FALSE,
      FindReplace::SETTING_WHOLE => FALSE,
    ];
    $plugin = new FindReplace($config, 'find_replace', [], $this
      ->getMockSourceDefinition());
    $this
      ->assertEquals('The dog went to the park.', $plugin
      ->tamper('The cat went to the park.'));
    $this
      ->assertEquals('The Cat went to the park.', $plugin
      ->tamper('The Cat went to the park.'));
    $this
      ->assertEquals('The dogwent to the park.', $plugin
      ->tamper('The catwent to the park.'));
  }

  /**
   * Test the plugin as respecting word boundaries.
   */
  public function testSingleValueWordBoundaries() {
    $config = [
      FindReplace::SETTING_FIND => 'cat',
      FindReplace::SETTING_REPLACE => 'dog',
      FindReplace::SETTING_CASE_SENSITIVE => FALSE,
      FindReplace::SETTING_WORD_BOUNDARIES => TRUE,
      FindReplace::SETTING_WHOLE => FALSE,
    ];
    $plugin = new FindReplace($config, 'find_replace', [], $this
      ->getMockSourceDefinition());
    $this
      ->assertEquals('The dog went to the park.', $plugin
      ->tamper('The cat went to the park.'));
    $this
      ->assertEquals('The dog went to the park.', $plugin
      ->tamper('The Cat went to the park.'));
    $this
      ->assertEquals('The catwent to the park.', $plugin
      ->tamper('The catwent to the park.'));
  }

  /**
   * Test the plugin as replace whole words only.
   */
  public function testSingleValueWhole() {
    $config = [
      FindReplace::SETTING_FIND => 'cat',
      FindReplace::SETTING_REPLACE => 'dog',
      FindReplace::SETTING_CASE_SENSITIVE => FALSE,
      FindReplace::SETTING_WORD_BOUNDARIES => FALSE,
      FindReplace::SETTING_WHOLE => TRUE,
    ];
    $plugin = new FindReplace($config, 'find_replace', [], $this
      ->getMockSourceDefinition());
    $this
      ->assertEquals('The cat went to the park.', $plugin
      ->tamper('The cat went to the park.'));
    $this
      ->assertEquals('dog', $plugin
      ->tamper('cat'));
    $this
      ->assertEquals('dog', $plugin
      ->tamper('Cat'));
  }

  /**
   * Test the plugin with a multiple values.
   */
  public function testMultipleValues() {
    $plugin = new FindReplace([], 'find_replace', [], $this
      ->getMockSourceDefinition());
    $this
      ->expectException(TamperException::class);
    $this
      ->expectExceptionMessage('Input should be a string.');
    $plugin
      ->tamper([
      'foo',
      'bar',
      'baz',
    ]);
  }

}

Members

Namesort descending Modifiers Type Description Overrides
FindReplaceTest::instantiatePlugin protected function Instantiates a plugin. Overrides TamperPluginTestBase::instantiatePlugin
FindReplaceTest::testMultipleValues public function Test the plugin with a multiple values.
FindReplaceTest::testSingleValue public function Test the plugin with a single value.
FindReplaceTest::testSingleValueCaseSensitive public function Test the plugin as case sensitve.
FindReplaceTest::testSingleValueWhole public function Test the plugin as replace whole words only.
FindReplaceTest::testSingleValueWordBoundaries public function Test the plugin as respecting word boundaries.
PhpunitCompatibilityTrait::getMock Deprecated public function Returns a mock object for the specified class using the available method.
PhpunitCompatibilityTrait::setExpectedException Deprecated public function Compatibility layer for PHPUnit 6 to support PHPUnit 4 code.
TamperPluginTestBase::$plugin protected property The tamper plugin under test.
TamperPluginTestBase::getMockSourceDefinition protected function Returns a mocked source definition.
TamperPluginTestBase::setUp protected function Overrides UnitTestCase::setUp 3
TamperPluginTestBase::testBuildConfigurationForm public function @covers ::buildConfigurationForm
TamperPluginTestBase::testDefaultConfiguration public function @covers ::defaultConfiguration
TamperPluginTestBase::testGetConfiguration public function @covers ::getConfiguration
TamperPluginTestBase::testGetPluginDefinition public function @covers ::getPluginDefinition
TamperPluginTestBase::testGetPluginId public function @covers ::getPluginId
TamperPluginTestBase::testMultiple public function @covers ::multiple
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
UnitTestCase::assertArrayEquals protected function Asserts if two arrays are equal by sorting them first.
UnitTestCase::getBlockMockWithMachineName Deprecated protected function Mocks a block with a block plugin. 1
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.