createXMLDataSet(dirname(__FILE__) . '/fixtures/submit_post_notification.xml'); } public function setUp() { parent::setUp(); global $auth, $cache, $config, $db, $phpbb_container, $phpbb_dispatcher, $user, $request, $phpEx, $phpbb_root_path; // Database $this->db = $this->new_dbal(); $db = $this->db; // Cache $cache = new phpbb_mock_cache(); // Auth $auth = $this->getMock('phpbb_auth'); $auth->expects($this->any()) ->method('acl_get') ->with($this->stringContains('_'), $this->anything()) ->will($this->returnValueMap(array( array('f_noapprove', 1, true), array('f_postcount', 1, true), array('m_edit', 1, false), ))); $auth->expects($this->any()) ->method('acl_get_list') ->with($this->anything(), $this->stringContains('_'), $this->greaterThan(0)) ->will($this->returnValueMap(array( array( array('3', '4', '5', '6', '7', '8'), 'f_read', 1, array( 1 => array( 'f_read' => array(3, 5, 6, 7, 8), ), ), ), ))); // Config $config = new phpbb_config(array('num_topics' => 1,'num_posts' => 1,)); set_config(null, null, null, $config); set_config_count(null, null, null, $config); // Event dispatcher $phpbb_dispatcher = new phpbb_mock_event_dispatcher(); // User $user = $this->getMock('phpbb_user'); $user->ip = ''; $user->data = array( 'user_id' => 2, 'username' => 'user-name', 'is_registered' => true, 'user_colour' => '', ); // Request $type_cast_helper = $this->getMock('phpbb_request_type_cast_helper_interface'); $request = $this->getMock('phpbb_request'); // Container $phpbb_container = new phpbb_mock_container_builder(); $user_loader = new phpbb_user_loader($db, $phpbb_root_path, '.' . $phpEx, USERS_TABLE); // Notification Manager $phpbb_notifications = new phpbb_notification_manager(array(), array(), $phpbb_container, $user_loader, $db, $user, $phpbb_root_path, '.' . $phpEx, NOTIFICATION_TYPES_TABLE, NOTIFICATIONS_TABLE, USER_NOTIFICATIONS_TABLE); $phpbb_container->set('notification_manager', $phpbb_notifications); // Notification Types $notification_types = array('quote', 'bookmark', 'post'); foreach ($notification_types as $type) { $class_name = 'phpbb_notification_type_' . $type; $phpbb_container->set('notification.type.' . $type, new $class_name( $user_loader, $db, $cache, $user, $auth, $config, $phpbb_root_path, '.' . $phpEx, NOTIFICATION_TYPES_TABLE, NOTIFICATIONS_TABLE, USER_NOTIFICATIONS_TABLE)); } } /** * submit_post() Notifications test * * submit_post() $mode = 'reply' * Notification item_type = 'post' * * User => State description * 2 => Poster, should NOT receive a notification * 3 => Topic subscribed, should receive a notification * 4 => Topic subscribed, but unauthed to read, should NOT receive a notification * 5 => Topic subscribed, but already notified, should NOT receive a new notification * 6 => Topic and forum subscribed, should receive ONE notification * 7 => Forum subscribed, should receive a notification * 8 => Forum subscribed, but already notified, should NOT receive a new notification */ public function test_type_post() { $sql = 'SELECT user_id, item_id, item_parent_id FROM ' . NOTIFICATIONS_TABLE . " WHERE item_type = 'post' ORDER BY user_id, item_id ASC"; $result = $this->db->sql_query($sql); $this->assertEquals(array( array('user_id' => 5, 'item_id' => 1, 'item_parent_id' => 1), array('user_id' => 8, 'item_id' => 1, 'item_parent_id' => 1), ), $this->db->sql_fetchrowset($result)); $this->db->sql_freeresult($result); $poll = array(); $data = array( 'forum_id' => 1, 'topic_id' => 1, 'topic_title' => 'topic_title', 'icon_id' => 0, 'enable_bbcode' => 0, 'enable_smilies' => 0, 'enable_urls' => 0, 'enable_sig' => 0, 'message' => '', 'message_md5' => '', 'attachment_data' => array(), 'bbcode_bitfield' => '', 'bbcode_uid' => '', 'post_edit_locked' => false, //'force_approved_state' => 1, ); submit_post('reply', '', 'poster-name', POST_NORMAL, $poll, $data, false, false); $sql = 'SELECT user_id, item_id, item_parent_id FROM ' . NOTIFICATIONS_TABLE . " WHERE item_type = 'post' ORDER BY user_id ASC, item_id ASC"; $result = $this->db->sql_query($sql); $this->assertEquals(array( array('user_id' => 3, 'item_id' => 1, 'item_parent_id' => 1), array('user_id' => 5, 'item_id' => 1, 'item_parent_id' => 1), array('user_id' => 6, 'item_id' => 1, 'item_parent_id' => 1), array('user_id' => 7, 'item_id' => 1, 'item_parent_id' => 1), array('user_id' => 8, 'item_id' => 1, 'item_parent_id' => 1), ), $this->db->sql_fetchrowset($result)); $this->db->sql_freeresult($result); } }