protected function MongoDBLogTestCase::ZtestFilter in MongoDB 8
Same name and namespace in other branches
- 7 mongodb_watchdog/mongodb_watchdog.test \MongoDBLogTestCase::ztestFilter()
Test the dblog filter on admin/reports/dblog.
File
- mongodb_watchdog/
mongodb_watchdog.test, line 553 - Test class for MongoDB_watchdog.
Class
- MongoDBLogTestCase
- Test the behaviour of watchdog() mongodb_watchdog, not dblog
Code
protected function ZtestFilter() {
$this
->drupalLogin($this->big_user);
// Clear log to ensure that only generated entries are found.
db_delete('watchdog')
->execute();
// Generate watchdog entries.
$type_names = array();
$types = array();
for ($i = 0; $i < 3; $i++) {
$type_names[] = $type_name = $this
->randomName();
$severity = WATCHDOG_EMERGENCY;
for ($j = 0; $j < 3; $j++) {
$types[] = $type = array(
'count' => mt_rand(1, 5),
'type' => $type_name,
'severity' => $severity++,
);
$this
->generateLogEntries($type['count'], $type['type'], $type['severity']);
}
}
// View the dblog.
$this
->drupalGet('admin/reports/dblog');
// Confirm all the entries are displayed.
$count = $this
->getTypeCount($types);
foreach ($types as $key => $type) {
$this
->assertEqual($count[$key], $type['count'], 'Count matched');
}
// Filter by each type and confirm that entries with various severities are
// displayed.
foreach ($type_names as $type_name) {
$edit = array(
'type[]' => array(
$type_name,
),
);
$this
->drupalPost(NULL, $edit, t('Filter'));
// Count the number of entries of this type.
$type_count = 0;
foreach ($types as $type) {
if ($type['type'] == $type_name) {
$type_count += $type['count'];
}
}
$count = $this
->getTypeCount($types);
$this
->assertEqual(array_sum($count), $type_count, 'Count matched');
}
// Set filter to match each of the three type attributes and confirm the
// number of entries displayed.
foreach ($types as $key => $type) {
$edit = array(
'type[]' => array(
$type['type'],
),
'severity[]' => array(
$type['severity'],
),
);
$this
->drupalPost(NULL, $edit, t('Filter'));
$count = $this
->getTypeCount($types);
$this
->assertEqual(array_sum($count), $type['count'], 'Count matched');
}
}