StatisticsAdminTest.php

Same filename in other branches
  1. 9 core/modules/statistics/tests/src/Functional/StatisticsAdminTest.php
  2. 8.9.x core/modules/statistics/tests/src/Functional/StatisticsAdminTest.php
  3. 11.x core/modules/statistics/tests/src/Functional/StatisticsAdminTest.php

Namespace

Drupal\Tests\statistics\Functional

File

core/modules/statistics/tests/src/Functional/StatisticsAdminTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\Tests\statistics\Functional;

use Drupal\Core\Database\Database;
use Drupal\Tests\BrowserTestBase;
use Drupal\Tests\Traits\Core\CronRunTrait;
// cspell:ignore accesslog daycount

/**
 * Tests the statistics admin.
 *
 * @group statistics
 * @group legacy
 */
class StatisticsAdminTest extends BrowserTestBase {
    use CronRunTrait;
    
    /**
     * Modules to enable.
     *
     * @var array
     */
    protected static $modules = [
        'node',
        'statistics',
    ];
    
    /**
     * {@inheritdoc}
     */
    protected $defaultTheme = 'stark';
    
    /**
     * A user that has permission to administer statistics.
     *
     * @var \Drupal\user\UserInterface
     */
    protected $privilegedUser;
    
    /**
     * A page node for which to check content statistics.
     *
     * @var \Drupal\node\NodeInterface
     */
    protected $testNode;
    
    /**
     * The Guzzle HTTP client.
     *
     * @var \GuzzleHttp\Client
     */
    protected $client;
    
    /**
     * {@inheritdoc}
     */
    protected function setUp() : void {
        parent::setUp();
        // Set the max age to 0 to simplify testing.
        $this->config('statistics.settings')
            ->set('display_max_age', 0)
            ->save();
        // Create Basic page node type.
        if ($this->profile != 'standard') {
            $this->drupalCreateContentType([
                'type' => 'page',
                'name' => 'Basic page',
            ]);
        }
        $this->privilegedUser = $this->drupalCreateUser([
            'administer statistics',
            'view post access counter',
            'create page content',
        ]);
        $this->drupalLogin($this->privilegedUser);
        $this->testNode = $this->drupalCreateNode([
            'type' => 'page',
            'uid' => $this->privilegedUser
                ->id(),
        ]);
        $this->client = \Drupal::httpClient();
    }
    
    /**
     * Verifies that the statistics settings page works.
     */
    public function testStatisticsSettings() : void {
        $config = $this->config('statistics.settings');
        $this->assertEmpty($config->get('count_content_views'), 'Count content view log is disabled by default.');
        // Enable counter on content view.
        $edit['statistics_count_content_views'] = 1;
        $this->drupalGet('admin/config/system/statistics');
        $this->submitForm($edit, 'Save configuration');
        $config = $this->config('statistics.settings');
        $this->assertNotEmpty($config->get('count_content_views'), 'Count content view log is enabled.');
        // Hit the node.
        $this->drupalGet('node/' . $this->testNode
            ->id());
        // Manually calling statistics.php, simulating ajax behavior.
        $nid = $this->testNode
            ->id();
        $post = [
            'nid' => $nid,
        ];
        global $base_url;
        $stats_path = $base_url . '/' . $this->getModulePath('statistics') . '/statistics.php';
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        // Hit the node again (the counter is incremented after the hit, so
        // "1 view" will actually be shown when the node is hit the second time).
        $this->drupalGet('node/' . $this->testNode
            ->id());
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        $this->assertSession()
            ->pageTextContains('1 view');
        $this->drupalGet('node/' . $this->testNode
            ->id());
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        $this->assertSession()
            ->pageTextContains('2 views');
        // Increase the max age to test that nodes are no longer immediately
        // updated, visit the node once more to populate the cache.
        $this->config('statistics.settings')
            ->set('display_max_age', 3600)
            ->save();
        $this->drupalGet('node/' . $this->testNode
            ->id());
        $this->assertSession()
            ->pageTextContains('3 views');
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        $this->drupalGet('node/' . $this->testNode
            ->id());
        // Verify that views counter was not updated.
        $this->assertSession()
            ->pageTextContains('3 views');
    }
    
    /**
     * Tests that when a node is deleted, the node counter is deleted too.
     */
    public function testDeleteNode() : void {
        $this->config('statistics.settings')
            ->set('count_content_views', 1)
            ->save();
        $this->drupalGet('node/' . $this->testNode
            ->id());
        // Manually calling statistics.php, simulating ajax behavior.
        $nid = $this->testNode
            ->id();
        $post = [
            'nid' => $nid,
        ];
        global $base_url;
        $stats_path = $base_url . '/' . $this->getModulePath('statistics') . '/statistics.php';
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        $connection = Database::getConnection();
        $result = $connection->select('node_counter', 'n')
            ->fields('n', [
            'nid',
        ])
            ->condition('n.nid', $this->testNode
            ->id())
            ->execute()
            ->fetchAssoc();
        $this->assertEquals($result['nid'], $this->testNode
            ->id(), 'Verifying that the node counter is incremented.');
        $this->testNode
            ->delete();
        $result = $connection->select('node_counter', 'n')
            ->fields('n', [
            'nid',
        ])
            ->condition('n.nid', $this->testNode
            ->id())
            ->execute()
            ->fetchAssoc();
        $this->assertFalse($result, 'Verifying that the node counter is deleted.');
    }
    
    /**
     * Tests that cron clears day counts and expired access logs.
     */
    public function testExpiredLogs() : void {
        $this->config('statistics.settings')
            ->set('count_content_views', 1)
            ->save();
        \Drupal::state()->set('statistics.day_timestamp', 8640000);
        $this->drupalGet('node/' . $this->testNode
            ->id());
        // Manually calling statistics.php, simulating ajax behavior.
        $nid = $this->testNode
            ->id();
        $post = [
            'nid' => $nid,
        ];
        global $base_url;
        $stats_path = $base_url . '/' . $this->getModulePath('statistics') . '/statistics.php';
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        $this->drupalGet('node/' . $this->testNode
            ->id());
        $this->client
            ->post($stats_path, [
            'form_params' => $post,
        ]);
        $this->assertSession()
            ->pageTextContains('1 view');
        // statistics_cron() will subtract
        // statistics.settings:accesslog.max_lifetime config from
        // \Drupal::time()->getRequestTime() in the delete query, so wait two secs here to make
        // sure the access log will be flushed for the node just hit.
        sleep(2);
        $this->cronRun();
        // Verify that no hit URL is found.
        $this->drupalGet('admin/reports/pages');
        $this->assertSession()
            ->pageTextNotContains('node/' . $this->testNode
            ->id());
        $result = Database::getConnection()->select('node_counter', 'nc')
            ->fields('nc', [
            'daycount',
        ])
            ->condition('nid', $this->testNode
            ->id(), '=')
            ->execute()
            ->fetchField();
        $this->assertEmpty($result, 'Daycount is zero.');
    }

}

Classes

Title Deprecated Summary
StatisticsAdminTest Tests the statistics admin.

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