diff options
author | Dries Buytaert <dries@buytaert.net> | 2008-05-07 19:17:50 +0000 |
---|---|---|
committer | Dries Buytaert <dries@buytaert.net> | 2008-05-07 19:17:50 +0000 |
commit | 48e293a6b3d647d79b7b3ce58ab467f9c3fd6de7 (patch) | |
tree | 27f65e9b32c8b9a81dd894a9c2f73fb34cb645db /modules/statistics | |
parent | e9b40575b2c67d958321a5cc01664a505f5d8cba (diff) | |
download | drupal-48e293a6b3d647d79b7b3ce58ab467f9c3fd6de7.tar.gz drupal-48e293a6b3d647d79b7b3ce58ab467f9c3fd6de7.zip |
- Patch #248436 by catch: fixed some bugs in the statistics module, wrote some tests, and made some minor usability improvments along the way. That is _exactly_ how we like it.
Diffstat (limited to 'modules/statistics')
-rw-r--r-- | modules/statistics/statistics.admin.inc | 8 | ||||
-rw-r--r-- | modules/statistics/statistics.test | 67 |
2 files changed, 71 insertions, 4 deletions
diff --git a/modules/statistics/statistics.admin.inc b/modules/statistics/statistics.admin.inc index 9aad6f668af..bc2e539e5f5 100644 --- a/modules/statistics/statistics.admin.inc +++ b/modules/statistics/statistics.admin.inc @@ -79,18 +79,18 @@ function statistics_top_visitors() { array('data' => t('Hits'), 'field' => 'hits', 'sort' => 'desc'), array('data' => t('Visitor'), 'field' => 'u.name'), array('data' => t('Total page generation time'), 'field' => 'total'), - array('data' => t('Operations')) + array('data' => user_access('block IP addresses') ? t('Operations') : '', 'colspan' => 2), ); - $sql = "SELECT COUNT(a.uid) AS hits, a.uid, u.name, a.hostname, SUM(a.timer) AS total, ac.aid FROM {accesslog} a LEFT JOIN {access} ac ON ac.type = 'host' AND LOWER(a.hostname) LIKE (ac.mask) LEFT JOIN {users} u ON a.uid = u.uid GROUP BY a.hostname, a.uid, u.name, ac.aid" . tablesort_sql($header); + $sql = "SELECT COUNT(a.uid) AS hits, a.uid, u.name, a.hostname, SUM(a.timer) AS total, bl.iid FROM {accesslog} a LEFT JOIN {blocked_ips} bl ON a.hostname = bl.ip LEFT JOIN {users} u ON a.uid = u.uid GROUP BY a.hostname, a.uid, u.name, bl.iid" . tablesort_sql($header); $sql_cnt = "SELECT COUNT(DISTINCT(CONCAT(uid, hostname))) FROM {accesslog}"; $result = pager_query($sql, 30, 0, $sql_cnt); $rows = array(); while ($account = db_fetch_object($result)) { $qs = drupal_get_destination(); - $ban_link = $account->aid ? l(t('unban'), "admin/user/rules/delete/$account->aid", array('query' => $qs)) : l(t('ban'), "admin/user/rules/add/$account->hostname/host", array('query' => $qs)); - $rows[] = array($account->hits, ($account->uid ? theme('username', $account) : $account->hostname), format_interval(round($account->total / 1000)), $ban_link); + $ban_link = $account->iid ? l(t('unblock IP address'), "admin/settings/ip-blocking/delete/$account->iid", array('query' => $qs)) : l(t('block IP address'), "admin/settings/ip-blocking/$account->hostname", array('query' => $qs)); + $rows[] = array($account->hits, ($account->uid ? theme('username', $account) : $account->hostname), format_interval(round($account->total / 1000)), (user_access('block IP addresses') && !$account->uid) ? $ban_link : ''); } if (empty($rows)) { diff --git a/modules/statistics/statistics.test b/modules/statistics/statistics.test new file mode 100644 index 00000000000..955f30b9902 --- /dev/null +++ b/modules/statistics/statistics.test @@ -0,0 +1,67 @@ +<?php +// $Id$ + +class StatisticsBlockVisitorsTestCase extends DrupalWebTestCase { + /** + * Implementation of getInfo(). + */ + function getInfo() { + return array( + 'name' => t('Top visitor blocking'), + 'description' => t('Tests blocking of IP addresses via the top visitors report.'), + 'group' => t('Statistics') + ); + } + + /** + * Implementation of setUp(). + */ + function setUp() { + parent::setUp('statistics'); + + // Create user. + $this->blocking_user = $this->drupalCreateUser(array('block IP addresses', 'access statistics')); + + // Insert dummy access by anonymous user into accessi log. + db_query("INSERT INTO {accesslog} (title, path, url, hostname, uid, sid, timer, timestamp) values('%s', '%s', '%s', '%s', %d, '%s', %d, %d)", 'test', 'node/1', 'http://example.com', '192.168.1.1', '0', '10', '10', time()); + } + + /** + * Blocks an IP address via the top visitors report then uses the same page to unblock it. + */ + function testIPAddressBlocking() { + // IP address for testing. + $test_ip_address = '192.168.1.1'; + + // Enable access logging (redundant since we insert the data manually). + variable_set('statistics_enable_access_log', 1); + + // Verify the IP address from accesslog appears on the top visitors page + // and that a 'block IP adddress' link is displayed. + $this->drupalLogin($this->blocking_user); + $this->drupalGet('admin/reports/visitors'); + $this->assertText($test_ip_address, t('IP address found.')); + $this->assertText(t('block IP address'), t('Block IP link displayed')); + + // Block the IP address. + $this->clickLink('block IP address'); + $this->assertText(t('IP address blocking'), t('IP blocking page displayed.')); + $edit = array(); + $edit['ip'] = $test_ip_address; + $this->drupalPost('admin/settings/ip-blocking', $edit, t('Save')); + $ip = db_result(db_query("SELECT iid from {blocked_ips} WHERE ip = '%s'", $edit['ip'])); + $this->assertNotNull($ip, t('IP address found in database')); + $this->assertRaw(t('The IP address %ip has been blocked.', array('%ip' => $edit['ip'])), t('IP address was blocked.')); + + // Verify that the block/unblock link on the top visitors page has been altered. + $this->drupalGet('admin/reports/visitors'); + $this->assertText(t('unblock IP address'), t('Unblock IP address link displayed')); + + // Unblock the IP address. + $this->clickLink('unblock IP address'); + $this->assertRaw(t('Are you sure you want to delete %ip?', array('%ip' => $test_ip_address)), t('IP address deletion confirmation found.')); + $edit = array(); + $this->drupalPost('admin/settings/ip-blocking/delete/1', NULL, t('Delete')); + $this->assertRaw(t('The IP address %ip was deleted.', array('%ip' => $test_ip_address)), t('IP address deleted.')); + } +} |