Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 43
0.00% covered (danger)
0.00%
0 / 2
CRAP
0.00% covered (danger)
0.00%
0 / 1
functional_permission_roles_test
0.00% covered (danger)
0.00%
0 / 43
0.00% covered (danger)
0.00%
0 / 2
12
0.00% covered (danger)
0.00%
0 / 1
 data_permission_roles
0.00% covered (danger)
0.00%
0 / 20
0.00% covered (danger)
0.00%
0 / 1
2
 test_permission_roles
0.00% covered (danger)
0.00%
0 / 23
0.00% covered (danger)
0.00%
0 / 1
6
1<?php
2/**
3*
4* This file is part of the phpBB Forum Software package.
5*
6* @copyright (c) phpBB Limited <https://www.phpbb.com>
7* @license GNU General Public License, version 2 (GPL-2.0)
8*
9* For full copyright and license information, please see
10* the docs/CREDITS.txt file.
11*
12*/
13
14/**
15* @group functional
16*/
17class functional_permission_roles_test extends phpbb_functional_test_case
18{
19    public static function data_permission_roles()
20    {
21        return array(
22            array(
23                array(0, 14),
24                array(17, 17),
25                array(
26                    'role[5][1]'    => 14,
27                )
28            ),
29            array(
30                array(14, 14),
31                array(17, 17),
32                array(
33                    'role[5][1]'    => 0,
34                )
35            ),
36            array(
37                array(0, 14),
38                array(17, 17)
39            ),
40        );
41    }
42    /**
43     * @dataProvider data_permission_roles
44     */
45    public function test_permission_roles($admin_roles, $guest_roles, $set_values = array())
46    {
47        $this->login();
48        $this->admin_login();
49        $this->add_lang('acp/permissions');
50        $crawler = self::request('GET', 'adm/index.php?i=acp_permissions&mode=setting_forum_local&sid=' . $this->sid);
51
52        // Select forums
53        $form = $crawler->filter('form[id=select_victim]')->form();
54        $form['forum_id']->setValue(array(1,2));
55        $crawler = self::$client->submit($form);
56
57        // Select administrators and guests
58        $groups_form = $crawler->filter('form[id=groups]')->form();
59        $groups_form['group_id']->setValue(array(1,5));
60
61        $crawler = self::submit($groups_form);
62        $form = $crawler->filter('form')->form();
63        $values = $form->getValues();
64
65        // Check default settings
66        $this->assertEquals($admin_roles[0], $values['role[5][1]']);
67        $this->assertEquals($admin_roles[1], $values['role[5][2]']);
68        $this->assertEquals($guest_roles[0], $values['role[1][1]']);
69        $this->assertEquals($guest_roles[1], $values['role[1][2]']);
70
71        // Set admin to full access on category
72        foreach ($set_values as $key => $value)
73        {
74            $form[$key]->setValue($value);
75        }
76
77        $form_values = $form->getValues();
78        $form_values['action[apply_all_permissions]'] = true;
79        $crawler = self::request('POST', 'adm/index.php?i=acp_permissions&mode=setting_forum_local&sid=' . $this->sid, $form_values);
80        $this->assertContainsLang('AUTH_UPDATED', $crawler->text());
81
82        $this->logout();
83    }
84}