diff options
author | Joas Schilling <nickvergessen@gmx.de> | 2013-11-19 01:03:12 +0100 |
---|---|---|
committer | Joas Schilling <nickvergessen@gmx.de> | 2013-11-19 01:03:12 +0100 |
commit | d213e23ab6cdb0405fd68308ebb5758abd58e7f6 (patch) | |
tree | b2158c2c749c0ff234a67232aae381f67f87f193 /tests/functional | |
parent | c31787436e246b8c28d07dd55142f52188d7bb72 (diff) | |
parent | 0d3396487e58091053778c9eb40ebcb6fa86536f (diff) | |
download | forums-d213e23ab6cdb0405fd68308ebb5758abd58e7f6.tar forums-d213e23ab6cdb0405fd68308ebb5758abd58e7f6.tar.gz forums-d213e23ab6cdb0405fd68308ebb5758abd58e7f6.tar.bz2 forums-d213e23ab6cdb0405fd68308ebb5758abd58e7f6.tar.xz forums-d213e23ab6cdb0405fd68308ebb5758abd58e7f6.zip |
Merge remote-tracking branch 'Marc/ticket/11896' into develop
* Marc/ticket/11896:
[ticket/11896] Use $form_time and fix out of bounds $form_time
[ticket/11896] Correctly document return of null in docblocks
[ticket/11896] Minor code improvements in phpbb_functional_test_case
[ticket/11896] Add functional tests for marking all notifications read
[ticket/11896] Add ability to define expected message after posting
[ŧicket/11896] Set form_time with time() when marking all notifications read
Diffstat (limited to 'tests/functional')
-rw-r--r-- | tests/functional/notification_test.php | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/tests/functional/notification_test.php b/tests/functional/notification_test.php index 7f33ad1859..dd1b8ec981 100644 --- a/tests/functional/notification_test.php +++ b/tests/functional/notification_test.php @@ -52,4 +52,37 @@ class phpbb_functional_notification_test extends phpbb_functional_test_case $this->assert_checkbox_is_unchecked($cplist, $checkbox_name); } } + + public function test_mark_notifications_read() + { + // Create a new standard user + $this->create_user('notificationtestuser'); + $this->add_user_group('NEWLY_REGISTERED', array('notificationtestuser')); + $this->login('notificationtestuser'); + $crawler = self::request('GET', 'index.php'); + $this->assertContains('notificationtestuser', $crawler->filter('.icon-logout')->text()); + + // Post a new post that needs approval + $this->create_post(2, 1, 'Re: Welcome to phpBB3', 'This is a test [b]post[/b] posted by notificationtestuser.', array(), 'POST_STORED_MOD'); + $crawler = self::request('GET', "viewtopic.php?t=1&sid={$this->sid}"); + $this->assertNotContains('This is a test post posted by notificationtestuser.', $crawler->filter('html')->text()); + + // logout + $crawler = self::request('GET', 'ucp.php?sid=' . $this->sid . '&mode=logout'); + + // admin login + $this->login(); + $this->add_lang('ucp'); + $crawler = self::request('GET', 'ucp.php?i=ucp_notifications'); + + // At least one notification should exist + $this->assertGreaterThan(0, $crawler->filter('#notification_list_button strong')->text()); + + // Get form token + $link = $crawler->selectLink($this->lang('NOTIFICATIONS_MARK_ALL_READ'))->link()->getUri(); + $crawler = self::request('GET', substr($link, strpos($link, 'ucp.'))); + $form = $crawler->selectButton($this->lang('YES'))->form(); + $crawler = self::submit($form); + $this->assertEquals(0, $crawler->filter('#notification_list_button strong')->text()); + } } |