mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-08 12:28:52 +00:00
[ticket/12370] Add unit tests for topic notifications
PHPBB3-12370
This commit is contained in:
parent
708db0f05c
commit
c99584ec7b
3 changed files with 284 additions and 1 deletions
134
tests/notification/fixtures/submit_post_topic.xml
Normal file
134
tests/notification/fixtures/submit_post_topic.xml
Normal file
|
@ -0,0 +1,134 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<dataset>
|
||||||
|
<table name="phpbb_forums_watch">
|
||||||
|
<column>forum_id</column>
|
||||||
|
<column>user_id</column>
|
||||||
|
<column>notify_status</column>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>6</value>
|
||||||
|
<value>0</value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>7</value>
|
||||||
|
<value>0</value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>8</value>
|
||||||
|
<value>0</value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
<table name="phpbb_notifications">
|
||||||
|
<column>notification_type_id</column>
|
||||||
|
<column>user_id</column>
|
||||||
|
<column>item_id</column>
|
||||||
|
<column>item_parent_id</column>
|
||||||
|
<column>notification_read</column>
|
||||||
|
<column>notification_data</column>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>8</value>
|
||||||
|
<value>1</value>
|
||||||
|
<value>1</value>
|
||||||
|
<value>0</value>
|
||||||
|
<value></value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
<table name="phpbb_notification_types">
|
||||||
|
<column>notification_type_id</column>
|
||||||
|
<column>notification_type_name</column>
|
||||||
|
<column>notification_type_enabled</column>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>topic</value>
|
||||||
|
<value>1</value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
<table name="phpbb_posts">
|
||||||
|
<column>post_id</column>
|
||||||
|
<column>topic_id</column>
|
||||||
|
<column>forum_id</column>
|
||||||
|
<column>post_text</column>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>1</value>
|
||||||
|
<value>1</value>
|
||||||
|
<value></value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
<table name="phpbb_topics">
|
||||||
|
<column>topic_id</column>
|
||||||
|
<column>forum_id</column>
|
||||||
|
<row>
|
||||||
|
<value>1</value>
|
||||||
|
<value>1</value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
<table name="phpbb_users">
|
||||||
|
<column>user_id</column>
|
||||||
|
<column>username_clean</column>
|
||||||
|
<column>user_permissions</column>
|
||||||
|
<column>user_sig</column>
|
||||||
|
<row>
|
||||||
|
<value>2</value>
|
||||||
|
<value>poster</value>
|
||||||
|
<value></value>
|
||||||
|
<value></value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>6</value>
|
||||||
|
<value>noauth</value>
|
||||||
|
<value></value>
|
||||||
|
<value></value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>7</value>
|
||||||
|
<value>default</value>
|
||||||
|
<value></value>
|
||||||
|
<value></value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>8</value>
|
||||||
|
<value>notified</value>
|
||||||
|
<value></value>
|
||||||
|
<value></value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
<table name="phpbb_user_notifications">
|
||||||
|
<column>item_type</column>
|
||||||
|
<column>item_id</column>
|
||||||
|
<column>user_id</column>
|
||||||
|
<column>method</column>
|
||||||
|
<column>notify</column>
|
||||||
|
<row>
|
||||||
|
<value>topic</value>
|
||||||
|
<value>0</value>
|
||||||
|
<value>2</value>
|
||||||
|
<value></value>
|
||||||
|
<value>1</value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>topic</value>
|
||||||
|
<value>0</value>
|
||||||
|
<value>6</value>
|
||||||
|
<value></value>
|
||||||
|
<value>1</value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>topic</value>
|
||||||
|
<value>0</value>
|
||||||
|
<value>7</value>
|
||||||
|
<value></value>
|
||||||
|
<value>1</value>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<value>topic</value>
|
||||||
|
<value>0</value>
|
||||||
|
<value>8</value>
|
||||||
|
<value></value>
|
||||||
|
<value>1</value>
|
||||||
|
</row>
|
||||||
|
</table>
|
||||||
|
</dataset>
|
|
@ -101,7 +101,7 @@ abstract class phpbb_notification_submit_post_base extends phpbb_database_test_c
|
||||||
$user_loader = new \phpbb\user_loader($db, $phpbb_root_path, $phpEx, USERS_TABLE);
|
$user_loader = new \phpbb\user_loader($db, $phpbb_root_path, $phpEx, USERS_TABLE);
|
||||||
|
|
||||||
// Notification Types
|
// Notification Types
|
||||||
$notification_types = array('quote', 'bookmark', 'post', 'post_in_queue', 'topic', 'approve_topic', 'approve_post');
|
$notification_types = array('quote', 'bookmark', 'post', 'post_in_queue', 'topic', 'topic_in_queue', 'approve_topic', 'approve_post');
|
||||||
$notification_types_array = array();
|
$notification_types_array = array();
|
||||||
foreach ($notification_types as $type)
|
foreach ($notification_types as $type)
|
||||||
{
|
{
|
||||||
|
|
149
tests/notification/submit_post_type_topic_test.php
Normal file
149
tests/notification/submit_post_type_topic_test.php
Normal file
|
@ -0,0 +1,149 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2014 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/submit_post_base.php';
|
||||||
|
|
||||||
|
class phpbb_notification_submit_post_type_topic_test extends phpbb_notification_submit_post_base
|
||||||
|
{
|
||||||
|
protected $item_type = 'topic';
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
global $auth, $phpbb_log;
|
||||||
|
|
||||||
|
// Add additional permissions
|
||||||
|
$auth->expects($this->any())
|
||||||
|
->method('acl_get_list')
|
||||||
|
->with($this->anything(),
|
||||||
|
$this->stringContains('_'),
|
||||||
|
$this->greaterThan(0))
|
||||||
|
->will($this->returnValueMap(array(
|
||||||
|
array(
|
||||||
|
array(6, 7, 8),
|
||||||
|
'f_read',
|
||||||
|
1,
|
||||||
|
array(
|
||||||
|
1 => array(
|
||||||
|
'f_read' => array(7, 8),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)));
|
||||||
|
|
||||||
|
$phpbb_log = $this->getMock('\phpbb\log\null');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* submit_post() Notifications test
|
||||||
|
*
|
||||||
|
* submit_post() $mode = 'post'
|
||||||
|
* Notification item_type = 'topic'
|
||||||
|
*/
|
||||||
|
public function submit_post_data()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
/**
|
||||||
|
* Normal post
|
||||||
|
*
|
||||||
|
* User => State description
|
||||||
|
* 2 => Poster, should NOT receive a notification
|
||||||
|
* 6 => Forum subscribed, but no-auth reading, should NOT receive a notification
|
||||||
|
* 7 => Forum subscribed, should receive a notification
|
||||||
|
* 8 => Forum subscribed, but already notified, should NOT receive a new notification
|
||||||
|
*/
|
||||||
|
array(
|
||||||
|
array(),
|
||||||
|
array(
|
||||||
|
array('user_id' => 8, 'item_id' => 1, 'item_parent_id' => 1),
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
array('user_id' => 7, 'item_id' => 2, 'item_parent_id' => 1),
|
||||||
|
array('user_id' => 8, 'item_id' => 1, 'item_parent_id' => 1),
|
||||||
|
array('user_id' => 8, 'item_id' => 2, 'item_parent_id' => 1),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unapproved post
|
||||||
|
*
|
||||||
|
* No new notifications
|
||||||
|
*/
|
||||||
|
array(
|
||||||
|
array('force_approved_state' => false),
|
||||||
|
array(
|
||||||
|
array('user_id' => 8, 'item_id' => 1, 'item_parent_id' => 1),
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
array('user_id' => 8, 'item_id' => 1, 'item_parent_id' => 1),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider submit_post_data
|
||||||
|
*/
|
||||||
|
public function test_submit_post($additional_post_data, $expected_before, $expected_after)
|
||||||
|
{
|
||||||
|
$sql = 'SELECT user_id, item_id, item_parent_id
|
||||||
|
FROM ' . NOTIFICATIONS_TABLE . ' n, ' . NOTIFICATION_TYPES_TABLE . " nt
|
||||||
|
WHERE nt.notification_type_name = '" . $this->item_type . "'
|
||||||
|
AND n.notification_type_id = nt.notification_type_id
|
||||||
|
ORDER BY user_id ASC, item_id ASC";
|
||||||
|
$result = $this->db->sql_query($sql);
|
||||||
|
$this->assertEquals($expected_before, $this->db->sql_fetchrowset($result));
|
||||||
|
$this->db->sql_freeresult($result);
|
||||||
|
|
||||||
|
$poll_data = array();
|
||||||
|
$post_data = array_merge($this->post_data, $additional_post_data);
|
||||||
|
submit_post('post', '', 'poster-name', POST_NORMAL, $poll_data, $post_data, false, false);
|
||||||
|
|
||||||
|
// Check whether the notifications got added successfully
|
||||||
|
$result = $this->db->sql_query($sql);
|
||||||
|
$this->assertEquals($expected_after, $this->db->sql_fetchrowset($result),
|
||||||
|
'Check whether the notifications got added successfully');
|
||||||
|
$this->db->sql_freeresult($result);
|
||||||
|
|
||||||
|
if (isset($additional_post_data['force_approved_state']) && $additional_post_data['force_approved_state'] === false)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$reply_data = array_merge($this->post_data, array(
|
||||||
|
'topic_id' => 2,
|
||||||
|
));
|
||||||
|
$url = submit_post('reply', '', 'poster-name', POST_NORMAL, $poll_data, $reply_data, false, false);
|
||||||
|
$reply_id = 3;
|
||||||
|
$this->assertStringEndsWith('p' . $reply_id, $url, 'Post ID of reply is not ' . $reply_id);
|
||||||
|
|
||||||
|
// Check whether the notifications are still correct after a reply has been added
|
||||||
|
$result = $this->db->sql_query($sql);
|
||||||
|
$this->assertEquals($expected_after, $this->db->sql_fetchrowset($result),
|
||||||
|
'Check whether the notifications are still correct after a reply has been added');
|
||||||
|
$this->db->sql_freeresult($result);
|
||||||
|
|
||||||
|
$result = $this->db->sql_query(
|
||||||
|
'SELECT *
|
||||||
|
FROM ' . POSTS_TABLE . '
|
||||||
|
WHERE post_id = ' . $reply_id);
|
||||||
|
$reply_edit_data = array_merge($this->post_data, $this->db->sql_fetchrow($result), array(
|
||||||
|
'force_approved_state' => false,
|
||||||
|
'post_edit_reason' => 'PHPBB3-12370',
|
||||||
|
));
|
||||||
|
submit_post('edit', '', 'poster-name', POST_NORMAL, $poll_data, $reply_edit_data, false, false);
|
||||||
|
|
||||||
|
// Check whether the notifications are still correct after the reply has been edit
|
||||||
|
$result = $this->db->sql_query($sql);
|
||||||
|
$this->assertEquals($expected_after, $this->db->sql_fetchrowset($result),
|
||||||
|
'Check whether the notifications are still correct after the reply has been edit');
|
||||||
|
$this->db->sql_freeresult($result);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue