public function PiwikStatusMessagesTest::testPiwikStatusMessages in Piwik Web Analytics 8
Tests if status messages tracking is properly added to the page.
File
- src/
Tests/ PiwikStatusMessagesTest.php, line 39
Class
- PiwikStatusMessagesTest
- Test status messages functionality of Piwik module.
Namespace
Drupal\piwik\TestsCode
public function testPiwikStatusMessages() {
$site_id = '1';
$this
->config('piwik.settings')
->set('site_id', $site_id)
->save();
$this
->config('piwik.settings')
->set('url_http', 'http://www.example.com/piwik/')
->save();
$this
->config('piwik.settings')
->set('url_https', 'https://www.example.com/piwik/')
->save();
// Enable logging of errors only.
$this
->config('piwik.settings')
->set('track.messages', [
'error' => 'error',
])
->save();
$this
->drupalPostForm('user/login', [], t('Log in'));
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Error message", "Username field is required."]);', '[testPiwikStatusMessages]: trackEvent "Username field is required." is shown.');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Error message", "Password field is required."]);', '[testPiwikStatusMessages]: trackEvent "Password field is required." is shown.');
// Testing this drupal_set_message() requires an extra test module.
$this
->drupalGet('piwik-test/drupal-set-message');
$this
->assertNoRaw('_paq.push(["trackEvent", "Messages", "Status message", "Example status message."]);', '[testPiwikStatusMessages]: Example status message is not enabled for tracking.');
$this
->assertNoRaw('_paq.push(["trackEvent", "Messages", "Warning message", "Example warning message."]);', '[testPiwikStatusMessages]: Example warning message is not enabled for tracking.');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Error message", "Example error message."]);', '[testPiwikStatusMessages]: Example error message is shown.');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Error message", "Example error message with html tags and link."]);', '[testPiwikStatusMessages]: HTML has been stripped successful from Example error message with html tags and link.');
// Enable logging of status, warnings and errors.
$this
->config('piwik.settings')
->set('track.messages', [
'status' => 'status',
'warning' => 'warning',
'error' => 'error',
])
->save();
$this
->drupalGet('piwik-test/drupal-set-message');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Status message", "Example status message."]);', '[testPiwikStatusMessages]: Example status message is enabled for tracking.');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Warning message", "Example warning message."]);', '[testPiwikStatusMessages]: Example warning message is enabled for tracking.');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Error message", "Example error message."]);', '[testPiwikStatusMessages]: Example error message is shown.');
$this
->assertRaw('_paq.push(["trackEvent", "Messages", "Error message", "Example error message with html tags and link."]);', '[testPiwikStatusMessages]: HTML has been stripped successful from Example error message with html tags and link.');
}