function ArgumentUidRevisionTest::testArgument

Same name and namespace in other branches
  1. 9 core/modules/node/tests/src/Kernel/Views/ArgumentUidRevisionTest.php \Drupal\Tests\node\Kernel\Views\ArgumentUidRevisionTest::testArgument()
  2. 8.9.x core/modules/node/tests/src/Kernel/Views/ArgumentUidRevisionTest.php \Drupal\Tests\node\Kernel\Views\ArgumentUidRevisionTest::testArgument()
  3. 10 core/modules/node/tests/src/Kernel/Views/ArgumentUidRevisionTest.php \Drupal\Tests\node\Kernel\Views\ArgumentUidRevisionTest::testArgument()

Tests the node_uid_revision argument.

File

core/modules/node/tests/src/Kernel/Views/ArgumentUidRevisionTest.php, line 54

Class

ArgumentUidRevisionTest
Tests the argument_node_uid_revision handler.

Namespace

Drupal\Tests\node\Kernel\Views

Code

public function testArgument() : void {
    $expected_result = [];
    $author = $this->createUser();
    $no_author = $this->createUser();
    // Create one node, with the author as the node author.
    $node1 = Node::create([
        'type' => 'default',
        'title' => $this->randomMachineName(),
    ]);
    $node1->setOwner($author);
    $node1->save();
    $expected_result[] = [
        'nid' => $node1->id(),
    ];
    // Create one node of which an additional revision author will be the
    // author.
    $node2 = Node::create([
        'type' => 'default',
        'title' => $this->randomMachineName(),
    ]);
    $node2->setRevisionUserId($no_author->id());
    $node2->save();
    $expected_result[] = [
        'nid' => $node2->id(),
    ];
    // Force to add a new revision.
    $node2->setNewRevision(TRUE);
    $node2->setRevisionUserId($author->id());
    $node2->save();
    // Create one  node on which the author has neither authorship of revisions
    // or the main node.
    $node3 = Node::create([
        'type' => 'default',
        'title' => $this->randomMachineName(),
    ]);
    $node3->setOwner($no_author);
    $node3->save();
    $view = Views::getView('test_argument_node_uid_revision');
    $view->initHandlers();
    $view->setArguments([
        'uid_revision' => $author->id(),
    ]);
    $this->executeView($view);
    $this->assertIdenticalResultset($view, $expected_result, [
        'nid' => 'nid',
    ]);
}

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