function ArgumentStringTest::testGlossary

Same name in other branches
  1. 9 core/modules/views/tests/src/Kernel/Handler/ArgumentStringTest.php \Drupal\Tests\views\Kernel\Handler\ArgumentStringTest::testGlossary()
  2. 10 core/modules/views/tests/src/Kernel/Handler/ArgumentStringTest.php \Drupal\Tests\views\Kernel\Handler\ArgumentStringTest::testGlossary()
  3. 11.x core/modules/views/tests/src/Kernel/Handler/ArgumentStringTest.php \Drupal\Tests\views\Kernel\Handler\ArgumentStringTest::testGlossary()

Tests the glossary feature.

File

core/modules/views/tests/src/Kernel/Handler/ArgumentStringTest.php, line 32

Class

ArgumentStringTest
Tests the core Drupal\views\Plugin\views\argument\StringArgument handler.

Namespace

Drupal\Tests\views\Kernel\Handler

Code

public function testGlossary() {
    $this->installEntitySchema('user');
    $this->installEntitySchema('node');
    NodeType::create([
        'type' => 'page',
    ])->save();
    // Setup some nodes, one with a, two with b and three with c.
    $counter = 1;
    foreach ([
        'a',
        'b',
        'c',
    ] as $char) {
        for ($i = 0; $i < $counter; $i++) {
            Node::create([
                'type' => 'page',
                'title' => $char . $this->randomMachineName(),
            ])
                ->save();
        }
    }
    $view = Views::getView('test_glossary');
    $this->executeView($view);
    $count_field = 'nid';
    foreach ($view->result as &$row) {
        if (strpos($view->field['title']
            ->getValue($row), 'a') === 0) {
            $this->assertEquals(1, $row->{$count_field});
        }
        if (strpos($view->field['title']
            ->getValue($row), 'b') === 0) {
            $this->assertEquals(2, $row->{$count_field});
        }
        if (strpos($view->field['title']
            ->getValue($row), 'c') === 0) {
            $this->assertEquals(3, $row->{$count_field});
        }
    }
}

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