summaryrefslogtreecommitdiffstatshomepage
path: root/modules/statistics
diff options
context:
space:
mode:
authorDries Buytaert <dries@buytaert.net>2008-05-07 19:17:50 +0000
committerDries Buytaert <dries@buytaert.net>2008-05-07 19:17:50 +0000
commit48e293a6b3d647d79b7b3ce58ab467f9c3fd6de7 (patch)
tree27f65e9b32c8b9a81dd894a9c2f73fb34cb645db /modules/statistics
parente9b40575b2c67d958321a5cc01664a505f5d8cba (diff)
downloaddrupal-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.inc8
-rw-r--r--modules/statistics/statistics.test67
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.'));
+ }
+}