aboutsummaryrefslogtreecommitdiffstats
path: root/tests/functional/memberlist_test.php
blob: 1da5c39401f4e05cde4c2060a3eaa3ded7c7937a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?php
/**
*
* This file is part of the phpBB Forum Software package.
*
* @copyright (c) phpBB Limited <https://www.phpbb.com>
* @license GNU General Public License, version 2 (GPL-2.0)
*
* For full copyright and license information, please see
* the docs/CREDITS.txt file.
*
*/

/**
* @group functional
*/
class phpbb_functional_memberlist_test extends phpbb_functional_test_case
{
	public function test_memberlist()
	{
		$this->create_user('memberlist-test-user');
		// logs in as admin
		$this->login();
		$crawler = self::request('GET', 'memberlist.php?sid=' . $this->sid);
		$this->assertContains('memberlist-test-user', $crawler->text());

		// restrict by first character
		$crawler = self::request('GET', 'memberlist.php?first_char=m&sid=' . $this->sid);
		$this->assertContains('memberlist-test-user', $crawler->text());

		// make sure results for wrong character are not returned
		$crawler = self::request('GET', 'memberlist.php?first_char=a&sid=' . $this->sid);
		$this->assertNotContains('memberlist-test-user', $crawler->text());
	}

	public function test_viewprofile()
	{
		$this->login();
		// XXX hardcoded user id
		$crawler = self::request('GET', 'memberlist.php?mode=viewprofile&u=2&sid=' . $this->sid);
		$this->assertContains('admin', $crawler->filter('h2')->text());
	}

	protected function get_memberlist_leaders_table_crawler()
	{
		$crawler = self::request('GET', 'memberlist.php?mode=team&sid=' . $this->sid);
		return $crawler->filter('.forumbg-table');
	}

	public function test_leaders()
	{
		$this->login();
		$this->create_user('memberlist-test-moderator');

		$crawler = $this->get_memberlist_leaders_table_crawler();

		// Admin in admin group, but not in moderators
		$this->assertContains('admin', $crawler->eq(0)->text());
		$this->assertNotContains('admin', $crawler->eq(1)->text());

		// memberlist-test-user in neither group
		$this->assertNotContains('memberlist-test-user', $crawler->eq(0)->text());
		$this->assertNotContains('memberlist-test-user', $crawler->eq(1)->text());

		// memberlist-test-moderator in neither group
		$this->assertNotContains('memberlist-test-moderator', $crawler->eq(0)->text());
		$this->assertNotContains('memberlist-test-moderator', $crawler->eq(1)->text());
	}

	public function test_leaders_remove_users()
	{
		$this->login();

		// Remove admin from admins, but is now in moderators
		$this->remove_user_group('ADMINISTRATORS', array('admin'));
		$crawler = $this->get_memberlist_leaders_table_crawler();
		$this->assertNotContains('admin', $crawler->eq(0)->text());
		$this->assertContains('admin', $crawler->eq(1)->text());

		// Remove admin from moderators, should not be visible anymore
		$this->remove_user_group('GLOBAL_MODERATORS', array('admin'));
		$crawler = $this->get_memberlist_leaders_table_crawler();
		$this->assertNotContains('admin', $crawler->eq(0)->text());
		$this->assertNotContains('admin', $crawler->eq(1)->text());
	}

	public function test_leaders_add_users()
	{
		$this->login();

		// Add memberlist-test-moderator to moderators
		$this->add_user_group('GLOBAL_MODERATORS', array('memberlist-test-moderator'));
		$crawler = $this->get_memberlist_leaders_table_crawler();
		$this->assertNotContains('memberlist-test-moderator', $crawler->eq(0)->text());
		$this->assertContains('memberlist-test-moderator', $crawler->eq(1)->text());

		// Add admin to moderators, should be visible as moderator
		$this->add_user_group('GLOBAL_MODERATORS', array('admin'), true);
		$crawler = $this->get_memberlist_leaders_table_crawler();
		$this->assertNotContains('admin', $crawler->eq(0)->text());
		$this->assertContains('admin', $crawler->eq(1)->text());

		// Add admin to admins as leader, should be visible as admin, not moderator
		$this->add_user_group('ADMINISTRATORS', array('admin'), true, true);
		$crawler = $this->get_memberlist_leaders_table_crawler();
		$this->assertContains('admin', $crawler->eq(0)->text());
		$this->assertNotContains('admin', $crawler->eq(1)->text());
	}

	public function test_group_rank()
	{
		copy(__DIR__ . '/fixtures/files/valid.jpg', __DIR__ . '/../../phpBB/images/ranks/valid.jpg');

		$this->login();
		$this->admin_login();
		$this->add_lang(array('acp/groups', 'acp/posting'));

		// Set a group rank to the registered users
		$crawler = self::request('GET', "adm/index.php?sid={$this->sid}&i=acp_groups&mode=manage&action=edit&g=2");
		$form = $crawler->selectButton('Submit')->form();
		$form['group_rank']->select('1');
		$crawler = self::submit($form);
		$this->assertContainsLang('GROUP_UPDATED', $crawler->filter('.successbox')->text());

		// Set a rank image for site_admin
		$crawler = self::request('GET', "adm/index.php?sid={$this->sid}&i=acp_ranks&mode=ranks&action=edit&id=1");
		$form = $crawler->selectButton('Submit')->form();
		$form['rank_image']->select('valid.jpg');
		$crawler = self::submit($form);
		$this->assertContainsLang('RANK_UPDATED', $crawler->filter('.successbox')->text());

		$crawler = self::request('GET', 'memberlist.php?mode=group&g=2');
		$this->assertContains('memberlist-test-user', $crawler->text());

		unlink(__DIR__ . '/../../phpBB/images/ranks/valid.jpg');
	}
}