diff options
author | Nathan Guse <nathaniel.guse@gmail.com> | 2012-11-20 18:14:48 -0600 |
---|---|---|
committer | Nathan Guse <nathaniel.guse@gmail.com> | 2012-11-20 22:54:16 -0600 |
commit | 2afb8b9df873c3f9572a32ab7a62ea8ba8d8a45b (patch) | |
tree | ab584092e7e54f50a15dd9a22ed5b31200ea03f1 /tests/notification | |
parent | d2187424da6ff2e0d4a69a6e21bac7e92f68335a (diff) | |
download | forums-2afb8b9df873c3f9572a32ab7a62ea8ba8d8a45b.tar forums-2afb8b9df873c3f9572a32ab7a62ea8ba8d8a45b.tar.gz forums-2afb8b9df873c3f9572a32ab7a62ea8ba8d8a45b.tar.bz2 forums-2afb8b9df873c3f9572a32ab7a62ea8ba8d8a45b.tar.xz forums-2afb8b9df873c3f9572a32ab7a62ea8ba8d8a45b.zip |
[ticket/11103] Create user loader class, update for DIC
Create a very basic user loader class to handle querying/storing
user data in a centralized location.
Use DIC collection service for notification types/methods.
Cleanup unused dependencies.
Fix some other issues.
PHPBB3-11103
Diffstat (limited to 'tests/notification')
-rw-r--r-- | tests/notification/ext/test/notification/type/test.php | 7 | ||||
-rw-r--r-- | tests/notification/notification.php | 139 |
2 files changed, 93 insertions, 53 deletions
diff --git a/tests/notification/ext/test/notification/type/test.php b/tests/notification/ext/test/notification/type/test.php index 34149484df..45670e1c2d 100644 --- a/tests/notification/ext/test/notification/type/test.php +++ b/tests/notification/ext/test/notification/type/test.php @@ -15,8 +15,13 @@ if (!defined('IN_PHPBB')) exit; } -class phpbb_ext_test_notification_type_test extends phpbb_notification_type_base +class phpbb_notification_type_test extends phpbb_notification_type_base { + public function get_type() + { + return 'test'; + } + public static function get_item_id($post) { return (int) $post['post_id']; diff --git a/tests/notification/notification.php b/tests/notification/notification.php index 9c88ad892e..8fa77ff651 100644 --- a/tests/notification/notification.php +++ b/tests/notification/notification.php @@ -6,10 +6,10 @@ * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 * */ - +//calls: [ [set_notification_manager, [@notification_manager]] ] class phpbb_notification_test extends phpbb_database_test_case { - protected $notifications; + protected $notifications, $db, $container, $user, $config, $auth, $cache; public function getDataSet() { @@ -30,34 +30,69 @@ class phpbb_notification_test extends phpbb_database_test_case include_once(__DIR__ . '/ext/test/notification/type/test.' . $phpEx); - $db = $this->new_dbal(); - $config = new phpbb_config(array( + $db = $this->db = $this->new_dbal(); + $this->config = new phpbb_config(array( 'allow_privmsg' => true, 'allow_bookmarks' => true, 'allow_topic_notify' => true, 'allow_forum_notify' => true, )); - $user = new phpbb_mock_user(); - - $this->notifications = new phpbb_notification_manager( - $db, - new phpbb_mock_cache(), - new phpbb_template($phpbb_root_path, $phpEx, $config, $user, new phpbb_style_resource_locator()), - new phpbb_mock_extension_manager($phpbb_root_path, - array( - 'test' => array( - 'ext_name' => 'test', - 'ext_active' => '1', - 'ext_path' => 'ext/test/', - ), - ) - ), - $user, - new phpbb_mock_notifications_auth(), - $config, + $this->user = new phpbb_mock_user(); + $this->user_loader = new phpbb_user_loader($this->db, 'phpbb_users'); + $this->auth = new phpbb_mock_notifications_auth(); + $this->cache = new phpbb_mock_cache(); + + $this->container = new phpbb_mock_container_builder(); + + $this->notifications = new phpbb_mock_notifications_notification_manager( + array(), + array(), + $this->container, + $this->user_loader, + $this->db, + $this->user, $phpbb_root_path, - $phpEx + $phpEx, + 'phpbb_notifications', + 'phpbb_user_notifications' ); + + $this->notifications->setDependencies($this->auth, $this->cache, $this->config); + + $types = array(); + foreach (array( + 'test', + 'approve_post', + 'approve_topic', + 'bookmark', + 'disapprove_post', + 'disapprove_topic', + 'pm', + 'post', + 'post_in_queue', + 'quote', + 'report_pm', + 'report_pm_closed', + 'report_post', + 'report_post_closed', + 'topic', + 'topic_in_queue', + ) as $type) + { + $class = $this->build_type('phpbb_notification_type_' . $type); + + $types[$type] = $class; + $this->container->set('notification.type.' . $type, $class); + } + + $this->notifications->set_var('notification_types', $types); + } + + protected function build_type($type) + { + global $phpbb_root_path, $phpEx; + + return new $type($this->user_loader, $this->db, $this->cache, $this->user, $this->auth, $this->config, $phpbb_root_path, $phpEx, 'phpbb_notifications', 'phpbb_user_notifications'); } public function test_get_subscription_types() @@ -67,12 +102,12 @@ class phpbb_notification_test extends phpbb_database_test_case $this->assertArrayHasKey('NOTIFICATION_GROUP_MISCELLANEOUS', $subscription_types); $this->assertArrayHasKey('NOTIFICATION_GROUP_POSTING', $subscription_types); - $this->assertArrayHasKey('phpbb_notification_type_bookmark', $subscription_types['NOTIFICATION_GROUP_POSTING']); - $this->assertArrayHasKey('phpbb_notification_type_post', $subscription_types['NOTIFICATION_GROUP_POSTING']); - $this->assertArrayHasKey('phpbb_notification_type_quote', $subscription_types['NOTIFICATION_GROUP_POSTING']); - $this->assertArrayHasKey('phpbb_notification_type_topic', $subscription_types['NOTIFICATION_GROUP_POSTING']); + $this->assertArrayHasKey('bookmark', $subscription_types['NOTIFICATION_GROUP_POSTING']); + $this->assertArrayHasKey('post', $subscription_types['NOTIFICATION_GROUP_POSTING']); + $this->assertArrayHasKey('quote', $subscription_types['NOTIFICATION_GROUP_POSTING']); + $this->assertArrayHasKey('topic', $subscription_types['NOTIFICATION_GROUP_POSTING']); - $this->assertArrayHasKey('phpbb_notification_type_pm', $subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS']); + $this->assertArrayHasKey('pm', $subscription_types['NOTIFICATION_GROUP_MISCELLANEOUS']); //get_subscription_types //get_subscription_methods @@ -80,13 +115,13 @@ class phpbb_notification_test extends phpbb_database_test_case public function test_subscriptions() { - $this->notifications->delete_subscription('phpbb_notification_type_post', 0, '', 2); + $this->notifications->delete_subscription('post', 0, '', 2); - $this->assertArrayNotHasKey('phpbb_notification_type_post', $this->notifications->get_global_subscriptions(2)); + $this->assertArrayNotHasKey('post', $this->notifications->get_global_subscriptions(2)); - $this->notifications->add_subscription('phpbb_notification_type_post', 0, '', 2); + $this->notifications->add_subscription('post', 0, '', 2); - $this->assertArrayHasKey('phpbb_notification_type_post', $this->notifications->get_global_subscriptions(2)); + $this->assertArrayHasKey('post', $this->notifications->get_global_subscriptions(2)); } public function test_notifications() @@ -108,25 +143,25 @@ class phpbb_notification_test extends phpbb_database_test_case 'count_unread' => true, ))); - $this->notifications->add_notifications('phpbb_ext_test_notification_type_test', array( + $this->notifications->add_notifications('test', array( 'post_id' => '1', 'topic_id' => '1', 'post_time' => 1349413321, )); - $this->notifications->add_notifications('phpbb_ext_test_notification_type_test', array( + $this->notifications->add_notifications('test', array( 'post_id' => '2', 'topic_id' => '2', 'post_time' => 1349413322, )); - $this->notifications->add_notifications('phpbb_ext_test_notification_type_test', array( + $this->notifications->add_notifications('test', array( 'post_id' => '3', 'topic_id' => '2', 'post_time' => 1349413323, )); - $this->notifications->add_notifications(array('phpbb_notification_type_quote', 'phpbb_notification_type_bookmark', 'phpbb_notification_type_post', 'phpbb_ext_test_notification_type_test'), array( + $this->notifications->add_notifications(array('quote', 'bookmark', 'post', 'test'), array( 'post_id' => '4', 'topic_id' => '2', 'post_time' => 1349413324, @@ -142,7 +177,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'user_id' => 0, ))); - $this->notifications->add_notifications(array('phpbb_notification_type_quote', 'phpbb_notification_type_bookmark', 'phpbb_notification_type_post', 'phpbb_ext_test_notification_type_test'), array( + $this->notifications->add_notifications(array('quote', 'bookmark', 'post', 'test'), array( 'post_id' => '5', 'topic_id' => '2', 'post_time' => 1349413325, @@ -153,9 +188,9 @@ class phpbb_notification_test extends phpbb_database_test_case 'forum_name' => 'Your first forum', )); - $this->notifications->delete_subscription('phpbb_ext_test_notification_type_test'); + $this->notifications->delete_subscription('test'); - $this->notifications->add_notifications('phpbb_ext_test_notification_type_test', array( + $this->notifications->add_notifications('test', array( 'post_id' => '6', 'topic_id' => '2', 'post_time' => 1349413326, @@ -167,7 +202,7 @@ class phpbb_notification_test extends phpbb_database_test_case $expected = array( 1 => array( - 'item_type' => 'phpbb_ext_test_notification_type_test', + 'item_type' => 'test', 'item_id' => 1, 'item_parent_id' => 1, 'user_id' => 0, @@ -176,7 +211,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'data' => array(), ), 2 => array( - 'item_type' => 'phpbb_ext_test_notification_type_test', + 'item_type' => 'test', 'item_id' => 2, 'item_parent_id' => 2, 'user_id' => 0, @@ -185,7 +220,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'data' => array(), ), 3 => array( - 'item_type' => 'phpbb_ext_test_notification_type_test', + 'item_type' => 'test', 'item_id' => 3, 'item_parent_id' => 2, 'user_id' => 0, @@ -194,7 +229,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'data' => array(), ), 4 => array( - 'item_type' => 'phpbb_notification_type_post', + 'item_type' => 'post', 'item_id' => 4, 'item_parent_id' => 2, 'user_id' => 0, @@ -210,7 +245,7 @@ class phpbb_notification_test extends phpbb_database_test_case ), ), 5 => array( - 'item_type' => 'phpbb_notification_type_bookmark', + 'item_type' => 'bookmark', 'item_id' => 5, 'item_parent_id' => 2, 'user_id' => 0, @@ -245,19 +280,19 @@ class phpbb_notification_test extends phpbb_database_test_case // Now test updating ------------------------------- - $this->notifications->update_notifications('phpbb_ext_test_notification_type_test', array( + $this->notifications->update_notifications('test', array( 'post_id' => '1', 'topic_id' => '2', // change parent_id 'post_time' => 1349413321, )); - $this->notifications->update_notifications('phpbb_ext_test_notification_type_test', array( + $this->notifications->update_notifications('test', array( 'post_id' => '3', 'topic_id' => '2', 'post_time' => 1234, // change time )); - $this->notifications->update_notifications(array('phpbb_notification_type_quote', 'phpbb_notification_type_bookmark', 'phpbb_notification_type_post', 'phpbb_ext_test_notification_type_test'), array( + $this->notifications->update_notifications(array('quote', 'bookmark', 'post', 'test'), array( 'post_id' => '5', 'topic_id' => '2', 'poster_id' => 2, @@ -273,7 +308,7 @@ class phpbb_notification_test extends phpbb_database_test_case $expected = array( 1 => array( - 'item_type' => 'phpbb_ext_test_notification_type_test', + 'item_type' => 'test', 'item_id' => 1, 'item_parent_id' => 2, 'user_id' => 0, @@ -282,7 +317,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'data' => array(), ), 2 => array( - 'item_type' => 'phpbb_ext_test_notification_type_test', + 'item_type' => 'test', 'item_id' => 2, 'item_parent_id' => 2, 'user_id' => 0, @@ -291,7 +326,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'data' => array(), ), 3 => array( - 'item_type' => 'phpbb_ext_test_notification_type_test', + 'item_type' => 'test', 'item_id' => 3, 'item_parent_id' => 2, 'user_id' => 0, @@ -300,7 +335,7 @@ class phpbb_notification_test extends phpbb_database_test_case 'data' => array(), ), 4 => array( - 'item_type' => 'phpbb_notification_type_post', + 'item_type' => 'post', 'item_id' => 4, 'item_parent_id' => 2, 'user_id' => 0, @@ -316,7 +351,7 @@ class phpbb_notification_test extends phpbb_database_test_case ), ), 5 => array( - 'item_type' => 'phpbb_notification_type_bookmark', + 'item_type' => 'bookmark', 'item_id' => 5, 'item_parent_id' => 2, 'user_id' => 0, |