1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-10-24 05:06:09 +02:00

[ticket/11744] Helper function to assert notifications in base test

This also fixes tests

PHPBB3-11744
This commit is contained in:
Nathan Guse
2013-07-27 19:31:31 -05:00
parent b213be84a7
commit 359aedf664
3 changed files with 145 additions and 168 deletions

View File

@@ -106,4 +106,26 @@ abstract class phpbb_tests_notification_base extends phpbb_database_test_case
return new $type($this->user_loader, $this->db, $this->cache->get_driver(), $this->user, $this->auth, $this->config, $phpbb_root_path, $phpEx, 'phpbb_notification_types', 'phpbb_notifications', 'phpbb_user_notifications'); return new $type($this->user_loader, $this->db, $this->cache->get_driver(), $this->user, $this->auth, $this->config, $phpbb_root_path, $phpEx, 'phpbb_notification_types', 'phpbb_notifications', 'phpbb_user_notifications');
} }
protected function assert_notifications($expected, $options = array())
{
$notifications = $this->notifications->load_notifications(array_merge(array(
'count_unread' => true,
'order_by' => 'notification_time',
'order_dir' => 'ASC',
), $options));
$this->assertEquals(sizeof($expected), $notifications['unread_count']);
$i = 0;
foreach ($notifications['notifications'] as $notification)
{
foreach ($expected[$i] as $key => $value)
{
$this->assertEquals($value, $notification->$key, $i . ' ' . $key);
}
$i++;
}
}
} }

View File

@@ -53,18 +53,15 @@ class phpbb_notification_group_request_test extends phpbb_tests_notification_bas
$group_id = false; $group_id = false;
group_create($group_id, GROUP_OPEN, 'test', 'test group', array()); group_create($group_id, GROUP_OPEN, 'test', 'test group', array());
// Add user 1 as group leader // Add user 2 as group leader
group_user_add($group_id, 2, false, false, false, true, false); group_user_add($group_id, 2, false, false, false, true, false);
// Add user 2 as pending // Add user 3 as pending
group_user_add($group_id, 3, false, false, false, false, true); group_user_add($group_id, 3, false, false, false, false, true);
$notifications = $this->notifications->load_notifications(array( $this->assert_notifications(
'count_unread' => true, array(
'user_id' => 2, // user 3 pending notification
));
$expected = array(
array( array(
'item_id' => 3, // user_id of requesting join 'item_id' => 3, // user_id of requesting join
'item_parent_id' => $group_id, 'item_parent_id' => $group_id,
@@ -74,20 +71,10 @@ class phpbb_notification_group_request_test extends phpbb_tests_notification_bas
'group_name' => 'test', 'group_name' => 'test',
), ),
), ),
),
array(
'user_id' => 2,
)
); );
$this->assertEquals(sizeof($expected), $notifications['unread_count']);
$i = 0;
foreach ($notifications['notifications'] as $notification)
{
foreach ($expected[$i] as $notification_data)
{
$this->assertEquals($value, $notification->$key, $key . ' ' . $i);
}
$i++;
}
} }
} }

View File

@@ -160,11 +160,8 @@ class phpbb_notification_test extends phpbb_tests_notification_base
'post_time' => 1349413326, 'post_time' => 1349413326,
)); ));
$notifications = $this->notifications->load_notifications(array( $this->assert_notifications(
'count_unread' => true, array(
));
$expected = array(
array( array(
'item_id' => 1, 'item_id' => 1,
'item_parent_id' => 1, 'item_parent_id' => 1,
@@ -219,21 +216,9 @@ class phpbb_notification_test extends phpbb_tests_notification_base
'forum_name' => 'Your first forum', 'forum_name' => 'Your first forum',
), ),
), ),
)
); );
$this->assertEquals(sizeof($expected), $notifications['unread_count']);
$i = 0;
foreach ($notifications['notifications'] as $notification)
{
foreach ($expected[$i] as $notification_data)
{
$this->assertEquals($value, $notification->$key, $key . ' ' . $i);
}
$i++;
}
// Now test updating ------------------------------- // Now test updating -------------------------------
$this->notifications->update_notifications('test', array( $this->notifications->update_notifications('test', array(
@@ -258,11 +243,16 @@ class phpbb_notification_test extends phpbb_tests_notification_base
'forum_name' => 'Your second forum', // change forum_name 'forum_name' => 'Your second forum', // change forum_name
)); ));
$notifications = $this->notifications->load_notifications(array( $this->assert_notifications(
'count_unread' => true, array(
)); array(
'item_id' => 3,
$expected = array( 'item_parent_id' => 2,
'user_id' => 0,
'notification_read' => 0,
'notification_time' => 1234,
'notification_data' => array(),
),
array( array(
'item_id' => 1, 'item_id' => 1,
'item_parent_id' => 2, 'item_parent_id' => 2,
@@ -279,15 +269,6 @@ class phpbb_notification_test extends phpbb_tests_notification_base
'notification_time' => 1349413322, 'notification_time' => 1349413322,
'notification_data' => array(), 'notification_data' => array(),
), ),
array(
'notification_type_id' => 4,
'item_id' => 3,
'item_parent_id' => 2,
'user_id' => 0,
'notification_read' => 0,
'notification_time' => 1234,
'notification_data' => array(),
),
array( array(
'item_id' => 4, 'item_id' => 4,
'item_parent_id' => 2, 'item_parent_id' => 2,
@@ -318,20 +299,7 @@ class phpbb_notification_test extends phpbb_tests_notification_base
'forum_name' => 'Your second forum', 'forum_name' => 'Your second forum',
), ),
), ),
)
); );
$this->assertEquals(sizeof($expected), $notifications['unread_count']);
$i = 0;
foreach ($notifications['notifications'] as $notification)
{
foreach ($expected[$i] as $notification_data)
{
$this->assertEquals($value, $notification->$key, $key . ' ' . $i);
}
$i++;
}
} }
} }