Merge pull request #2526 from Nicofuma/ticket/12639

[ticket/12639] Delete entry in admin-log leads to mysql-error

* Nicofuma/ticket/12639:
  [ticket/12639] Add a space in the code generated by generate_sql_keyword()
  [ticket/12639] Handle $conditions['keywords'] outside of the loop
  [ticket/12639] Don't make a copy of $marked when deleting logs in acp_logs
  [ticket/12639] Send a correct IN entry when deleting marked logs
  [ticket/12639] Use assertSame
  [ticket/12639] Remove old commented tests
  [ticket/12639] Order the results correctly in the test
  [ticket/12639] Fix tests on postgres
  [ticket/12639] Update tests to use a dataProvider
  [ticket/12639] Add a test case with an empty keywords list
  [ticket/12639] Delete entry in admin-log leads to mysql-error
This commit is contained in:
Andreas Fischer 2014-06-04 23:59:20 +02:00
commit f9c0a6b96e
4 changed files with 143 additions and 55 deletions

View file

@ -58,13 +58,7 @@ class acp_logs
if ($deletemark && sizeof($marked)) if ($deletemark && sizeof($marked))
{ {
$sql_in = array(); $conditions['log_id'] = array('IN' => $marked);
foreach ($marked as $mark)
{
$sql_in[] = $mark;
}
$conditions['log_id'] = $sql_in;
unset($sql_in);
} }
if ($deleteall) if ($deleteall)
@ -78,8 +72,6 @@ class acp_logs
$conditions['keywords'] = $keywords; $conditions['keywords'] = $keywords;
} }
$conditions['log_type'] = $this->log_type;
$phpbb_log = $phpbb_container->get('log'); $phpbb_log = $phpbb_container->get('log');
$phpbb_log->delete($mode, $conditions); $phpbb_log->delete($mode, $conditions);
} }

View file

@ -115,9 +115,8 @@ class mcp_logs
if ($deletemark && sizeof($marked)) if ($deletemark && sizeof($marked))
{ {
$conditions = array( $conditions = array(
'log_type' => LOG_MOD,
'forum_id' => $forum_list, 'forum_id' => $forum_list,
'log_id' => $marked, 'log_id' => array('IN' => $marked),
); );
$phpbb_log->delete('mod', $conditions); $phpbb_log->delete('mod', $conditions);
@ -127,7 +126,6 @@ class mcp_logs
$keywords = utf8_normalize_nfc(request_var('keywords', '', true)); $keywords = utf8_normalize_nfc(request_var('keywords', '', true));
$conditions = array( $conditions = array(
'log_type' => LOG_MOD,
'forum_id' => $forum_list, 'forum_id' => $forum_list,
'keywords' => $keywords, 'keywords' => $keywords,
); );

View file

@ -391,28 +391,29 @@ class log implements \phpbb\log\log_interface
} }
$sql_where = 'WHERE log_type = ' . $log_type; $sql_where = 'WHERE log_type = ' . $log_type;
if (isset($conditions['keywords']))
{
$sql_where .= $this->generate_sql_keyword($conditions['keywords'], '');
unset($conditions['keywords']);
}
foreach ($conditions as $field => $field_value) foreach ($conditions as $field => $field_value)
{ {
$sql_where .= ' AND '; $sql_where .= ' AND ';
if ($field == 'keywords') if (is_array($field_value) && sizeof($field_value) == 2 && !is_array($field_value[1]))
{ {
$sql_where .= $this->generate_sql_keyword($field_value, '', ''); $sql_where .= $field . ' ' . $field_value[0] . ' ' . $field_value[1];
}
else if (is_array($field_value) && isset($field_value['IN']) && is_array($field_value['IN']))
{
$sql_where .= $this->db->sql_in_set($field, $field_value['IN']);
} }
else else
{ {
if (is_array($field_value) && sizeof($field_value) == 2 && !is_array($field_value[1])) $sql_where .= $field . ' = ' . $field_value;
{
$sql_where .= $field . ' ' . $field_value[0] . ' ' . $field_value[1];
}
else if (is_array($field_value) && isset($field_value['IN']) && is_array($field_value['IN']))
{
$sql_where .= $this->db->sql_in_set($field, $field_value['IN']);
}
else
{
$sql_where .= $field . ' = ' . $field_value;
}
} }
} }
@ -781,7 +782,7 @@ class log implements \phpbb\log\log_interface
} }
} }
$sql_keywords = $statement_operator . ' ('; $sql_keywords = ' ' . $statement_operator . ' (';
if (!empty($operations)) if (!empty($operations))
{ {
$sql_keywords .= $this->db->sql_in_set($table_alias . 'log_operation', $operations) . ' OR '; $sql_keywords .= $this->db->sql_in_set($table_alias . 'log_operation', $operations) . ' OR ';

View file

@ -1,9 +1,13 @@
<?php <?php
/** /**
* *
* @package testing * This file is part of the phpBB Forum Software package.
* @copyright (c) 2012 phpBB Group *
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 * @copyright (c) phpBB Limited <https://www.phpbb.com>
* @license GNU General Public License, version 2 (GPL-2.0)
*
* For full copyright and license information, please see
* the docs/CREDITS.txt file.
* *
*/ */
@ -13,48 +17,141 @@ require_once dirname(__FILE__) . '/../../phpBB/includes/utf/utf_tools.php';
class phpbb_log_delete_test extends phpbb_database_test_case class phpbb_log_delete_test extends phpbb_database_test_case
{ {
protected $log;
public function getDataSet() public function getDataSet()
{ {
return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/delete_log.xml'); return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/delete_log.xml');
} }
public function test_log_delete() protected function setUp()
{ {
global $phpbb_root_path, $phpEx, $db, $phpbb_dispatcher, $auth; global $phpbb_root_path, $phpEx, $db, $phpbb_dispatcher, $auth;
$db = $this->new_dbal(); $db = $this->new_dbal();
$cache = new phpbb_mock_cache;
$phpbb_dispatcher = new phpbb_mock_event_dispatcher(); $phpbb_dispatcher = new phpbb_mock_event_dispatcher();
$user = $this->getMock('\phpbb\user'); $user = $this->getMock('\phpbb\user');
$user->data['user_id'] = 1; $user->data['user_id'] = 1;
$auth = $this->getMock('\phpbb\auth\auth'); $auth = $this->getMock('\phpbb\auth\auth');
$log = new \phpbb\log\log($db, $user, $auth, $phpbb_dispatcher, $phpbb_root_path, 'adm/', $phpEx, LOG_TABLE); $this->log = new \phpbb\log\log($db, $user, $auth, $phpbb_dispatcher, $phpbb_root_path, 'adm/', $phpEx, LOG_TABLE);
// Delete all admin logs parent::setUp();
$this->assertCount(2, $log->get_logs('admin')); }
$log->delete('admin');
// One entry is added to the admin log when the logs are purged
$this->assertCount(1, $log->get_logs('admin'));
// Delete with keyword public function log_delete_data()
$this->assertCount(1, $log->get_logs('mod', false, 0, 0, 0, 0, 0, 0, 'l.log_time DESC', 'guest')); {
$log->delete('mod', array('keywords' => 'guest')); return array(
$this->assertEmpty($log->get_logs('mod', false, 0, 0, 0, 0, 0, 0, 'l.log_time DESC', 'guest')); array(
array(1, 2),
array(16),
array(),
'admin',
false,
0,
0,
0,
0,
0,
0,
'l.log_id ASC',
'',
),
array(
array(11),
array(),
array('keywords' => 'guest'),
'mod',
false,
0,
0,
0,
0,
0,
0,
'l.log_id ASC',
'guest',
),
array(
array(4, 5, 7),
array(),
array('forum_id' => 12, 'user_id' => 1),
'mod',
false,
0,
0,
12,
0,
1,
0,
'l.log_id ASC',
'',
),
array(
array(12, 13),
array(),
array('forum_id' => array('IN' => array(14, 13))),
'mod',
false,
0,
0,
array(13, 14),
0,
0,
0,
'l.log_id ASC',
'',
),
array(
array(3, 14, 15),
array(3),
array('user_id' => array('>', 1)),
'critical',
false,
0,
0,
0,
0,
0,
0,
'l.log_id ASC',
'',
),
array(
array(3, 14, 15),
array(),
array('keywords' => ''),
'critical',
false,
0,
0,
0,
0,
0,
0,
'l.log_id ASC',
'',
),
);
}
// Delete with simples conditions /**
$this->assertCount(3, $log->get_logs('mod', false, 0, 0, 12, 0, 1, 0, 'l.log_time DESC')); * @dataProvider log_delete_data
$log->delete('mod', array('forum_id' => 12, 'user_id' => 1)); */
$this->assertEmpty($log->get_logs('mod', false, 0, 0, 12, 0, 1, 0, 'l.log_time DESC')); public function test_log_delete($expected_before, $expected_after, $delete_conditions, $mode, $count_logs, $limit, $offset, $forum_id, $topic_id, $user_id, $log_time, $sort_by, $keywords)
{
$this->assertSame($expected_before, $this->get_ids($this->log->get_logs($mode, $count_logs, $limit, $offset, $forum_id, $topic_id, $user_id, $log_time, $sort_by, $keywords)), 'before');
$this->log->delete($mode, $delete_conditions);
$this->assertSame($expected_after, $this->get_ids($this->log->get_logs($mode, $count_logs, $limit, $offset, $forum_id, $topic_id, $user_id, $log_time, $sort_by, $keywords)), 'after');
}
// Delete with IN condition public function get_ids($logs)
$this->assertCount(2, $log->get_logs('mod', false, 0, 0, array(13, 14), 0, 0, 0, 'l.log_time DESC')); {
$log->delete('mod', array('forum_id' => array('IN' => array(14, 13)))); $ids = array();
$this->assertEmpty($log->get_logs('mod', false, 0, 0, array(13, 14), 0, 0, 0, 'l.log_time DESC')); foreach ($logs as $log_entry)
{
// Delete with a custom condition (ie: WHERE x >= 10) $ids[] = (int) $log_entry['id'];
$this->assertCount(3, $log->get_logs('critical', false, 0, 0, 0, 0, 0, 0, 'l.log_time DESC')); }
$log->delete('critical', array('user_id' => array('>', 1))); return $ids;
$this->assertCount(1, $log->get_logs('critical', false, 0, 0, 0, 0, 0, 0, 'l.log_time DESC'));
} }
} }