You are here

class FormCallbackToMethodTest in Drupal 7 to 8/9 Module Upgrader 8

@group DMU.Fixer

Hierarchy

Expanded class hierarchy of FormCallbackToMethodTest

File

tests/src/Unit/Plugin/DMU/Fixer/FormCallbackToMethodTest.php, line 14

Namespace

Drupal\Tests\drupalmoduleupgrader\Unit\Plugin\DMU\Fixer
View source
class FormCallbackToMethodTest extends TestBase {
  public function test() {
    $callback = Parser::parseSnippet('function foo_submit(&$form, &$form_state) {}');
    $function_indexer = $this
      ->createMock('\\Drupal\\drupalmoduleupgrader\\IndexerInterface');
    $function_indexer
      ->method('get')
      ->with('foo_submit')
      ->willReturn($callback);
    $class = ClassNode::create('FooForm');
    $class_indexer = $this
      ->createMock('\\Drupal\\drupalmoduleupgrader\\IndexerInterface');
    $class_indexer
      ->method('get')
      ->with('FooForm')
      ->willReturn($class);
    $this->container
      ->get('plugin.manager.drupalmoduleupgrader.indexer')
      ->method('createInstance')
      ->willReturnCallback(function ($which) use ($class_indexer, $function_indexer) {
      switch ($which) {
        case 'class':
          return $class_indexer;
        case 'function':
          return $function_indexer;
        default:
          break;
      }
    });
    $config = [
      'callback' => 'foo_submit',
      'destination' => 'FooForm::submitForm',
    ];
    $plugin = new FormCallbackToMethod($config, uniqid(), []);
    $plugin
      ->setTarget($this->target);
    try {

      // We expect a CodeManagerIOException because we're implementing the
      // method on a class that is not officially part of the target's code.
      // That's OK, though.
      $plugin
        ->execute();
    } catch (IOException $e) {
    }
    $this
      ->assertTrue($class
      ->hasMethod('submitForm'));
    $parameters = $class
      ->getMethod('submitForm')
      ->getParameters();
    $this
      ->assertCount(2, $parameters);
    $this
      ->assertEquals('form', $parameters[0]
      ->getName());
    $this
      ->assertInstanceOf('\\Pharborist\\TokenNode', $parameters[0]
      ->getTypeHint());
    $this
      ->assertSame(T_ARRAY, $parameters[0]
      ->getTypeHint()
      ->getType());
    $this
      ->assertInstanceOf('\\Pharborist\\TokenNode', $parameters[0]
      ->getReference());
    $this
      ->assertEquals('form_state', $parameters[1]
      ->getName());
    $this
      ->assertInstanceOf('\\Pharborist\\Namespaces\\NameNode', $parameters[1]
      ->getTypeHint());
    $this
      ->assertEquals('Drupal\\Core\\Form\\FormStateInterface', $parameters[1]
      ->getTypeHint()
      ->getText());
    $this
      ->assertNull($parameters[1]
      ->getReference());
  }

}

Members

Namesort descending Modifiers Type Description Overrides
ContainerMockTrait::$container protected property
ContainerMockTrait::mockContainer protected function
ContainerMockTrait::mockLogger protected function
ContainerMockTrait::mockTranslator protected function
FormCallbackToMethodTest::test public function
ModuleMockerTrait::mockModule protected function
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.
SQLiteDatabaseTrait::$db protected property
SQLiteDatabaseTrait::initDB protected function
TestBase::$dir protected property
TestBase::$info protected property The parsed annotations for the test class and method being executed.
TestBase::$target protected property
TestBase::getPlugin protected function Instantiates the plugin class covered by this test (as indicated by the @covers annotation). The plugin instance is given a randomly generated ID and description. Dependencies will be pulled from $this->container, so this should only be called once… 1
TestBase::setUp public function Mocks an entire module, called foo, in a virtual file system. Overrides UnitTestCase::setUp 17
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.