✅ unit tests for Zotlabs\Access classes.
This commit is contained in:
		
							
								
								
									
										78
									
								
								tests/unit/Access/PermissionLimitsTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								tests/unit/Access/PermissionLimitsTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | |||||||
|  | <?php | ||||||
|  | /* | ||||||
|  |  * Copyright (c) 2017 Hubzilla | ||||||
|  |  * | ||||||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |  * of this software and associated documentation files (the "Software"), to deal | ||||||
|  |  * in the Software without restriction, including without limitation the rights | ||||||
|  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |  * copies of the Software, and to permit persons to whom the Software is | ||||||
|  |  * furnished to do so, subject to the following conditions: | ||||||
|  |  * | ||||||
|  |  * The above copyright notice and this permission notice shall be included in | ||||||
|  |  * all copies or substantial portions of the Software. | ||||||
|  |  * | ||||||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |  * SOFTWARE. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Zotlabs\Tests\Unit\Access; | ||||||
|  |  | ||||||
|  | use phpmock\phpunit\PHPMock; | ||||||
|  | use Zotlabs\Tests\Unit\UnitTestCase; | ||||||
|  | use Zotlabs\Access\PermissionLimits; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @brief Unit Test case for PermissionLimits class. | ||||||
|  |  * | ||||||
|  |  * @covers Zotlabs\Access\PermissionLimits | ||||||
|  |  */ | ||||||
|  | class PermissionLimitsTest extends UnitTestCase { | ||||||
|  |  | ||||||
|  | 	use PHPMock; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @todo If we could replace static call to Permissions::Perms() in | ||||||
|  | 	 * Std_Limits() we could better unit test this method, now we test the | ||||||
|  | 	 * result of Permissions::Perms() mostly. | ||||||
|  | 	 * | ||||||
|  | 	 * @uses Zotlabs\Access\Permissions::Perms | ||||||
|  | 	 * @uses ::call_hooks | ||||||
|  | 	 */ | ||||||
|  | 	public function testStd_Limits() { | ||||||
|  | 		// There are 18 default perms | ||||||
|  | 		$permsCount = 18; | ||||||
|  |  | ||||||
|  | 		// Create a stub for global function t() with expectation | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
|  | 		$t->expects($this->exactly($permsCount)); | ||||||
|  |  | ||||||
|  | 		$stdlimits = PermissionLimits::Std_Limits(); | ||||||
|  | 		$this->assertCount($permsCount, $stdlimits, "There should be $permsCount permissions."); | ||||||
|  |  | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['view_stream']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['send_stream']); | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['view_profile']); | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['view_contacts']); | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['view_storage']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['write_storage']); | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['view_pages']); | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['view_wiki']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['write_pages']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['write_wiki']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['post_wall']); | ||||||
|  | 		$this->assertEquals(PERMS_PUBLIC,   $stdlimits['post_comments']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['post_mail']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['post_like']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['tag_deliver']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['chat']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['republish']); | ||||||
|  | 		$this->assertEquals(PERMS_SPECIFIC, $stdlimits['delegate']); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										100
									
								
								tests/unit/Access/PermissionRolesTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								tests/unit/Access/PermissionRolesTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | |||||||
|  | <?php | ||||||
|  | /* | ||||||
|  |  * Copyright (c) 2017 Hubzilla | ||||||
|  |  * | ||||||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |  * of this software and associated documentation files (the "Software"), to deal | ||||||
|  |  * in the Software without restriction, including without limitation the rights | ||||||
|  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |  * copies of the Software, and to permit persons to whom the Software is | ||||||
|  |  * furnished to do so, subject to the following conditions: | ||||||
|  |  * | ||||||
|  |  * The above copyright notice and this permission notice shall be included in | ||||||
|  |  * all copies or substantial portions of the Software. | ||||||
|  |  * | ||||||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |  * SOFTWARE. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Zotlabs\Tests\Unit\Access; | ||||||
|  |  | ||||||
|  | use Zotlabs\Tests\Unit\UnitTestCase; | ||||||
|  | use Zotlabs\Access\PermissionRoles; | ||||||
|  | use phpmock\phpunit\PHPMock; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @brief Unit Test case for PermissionRoles class. | ||||||
|  |  * | ||||||
|  |  * @TODO Work around dependencies to static PermissionLimits methods. | ||||||
|  |  * | ||||||
|  |  * @covers Zotlabs\Access\PermissionRoles | ||||||
|  |  */ | ||||||
|  | class PermissionRolesTest extends UnitTestCase { | ||||||
|  |  | ||||||
|  | 	use PHPMock; | ||||||
|  |  | ||||||
|  | 	public function testVersion() { | ||||||
|  | 		$expectedVersion = 2; | ||||||
|  |  | ||||||
|  | 		$this->assertEquals($expectedVersion, PermissionRoles::version()); | ||||||
|  |  | ||||||
|  | 		$pr = new PermissionRoles(); | ||||||
|  | 		$this->assertEquals($expectedVersion, $pr->version()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function testRoles() { | ||||||
|  | 		// Create a stub for global function t() with expectation | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
|  | 		$t->expects($this->atLeastOnce())->willReturnCallback( | ||||||
|  | 				function ($string) { | ||||||
|  | 					return $string; | ||||||
|  | 				} | ||||||
|  | 		); | ||||||
|  |  | ||||||
|  | 		$roles = PermissionRoles::roles(); | ||||||
|  | 		$r = new PermissionRoles(); | ||||||
|  | 		$this->assertEquals($roles, $r->roles()); | ||||||
|  |  | ||||||
|  | 		$socialNetworking = [ | ||||||
|  | 				'social' => 'Social - Mostly Public', | ||||||
|  | 				'social_restricted' => 'Social - Restricted', | ||||||
|  | 				'social_private' => 'Social - Private' | ||||||
|  | 		]; | ||||||
|  |  | ||||||
|  | 		$this->assertArraySubset(['Social Networking' => $socialNetworking], $roles); | ||||||
|  | 		$this->assertEquals($socialNetworking, $roles['Social Networking']); | ||||||
|  |  | ||||||
|  | 		$this->assertCount(5, $roles, 'There should be 5 permission groups.'); | ||||||
|  |  | ||||||
|  | 		$this->assertCount(1, $roles['Other'], "In the 'Other' group should be just one permission role"); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @uses ::call_hooks | ||||||
|  | 	 * @uses Zotlabs\Access\PermissionLimits::Std_Limits | ||||||
|  | 	 * @uses Zotlabs\Access\Permissions::Perms | ||||||
|  | 	 */ | ||||||
|  | 	public function testRole_perms() { | ||||||
|  | 		// Create a stub for global function t() | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 'get_config'); | ||||||
|  |  | ||||||
|  | 		$rp_social = PermissionRoles::role_perms('social'); | ||||||
|  | 		$this->assertEquals('social', $rp_social['role']); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 		$rp_custom = PermissionRoles::role_perms('custom'); | ||||||
|  | 		$this->assertEquals(['role' => 'custom'], $rp_custom); | ||||||
|  |  | ||||||
|  | 		$rp_nonexistent = PermissionRoles::role_perms('nonexistent'); | ||||||
|  | 		$this->assertEquals(['role' => 'nonexistent'], $rp_nonexistent); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -23,6 +23,7 @@ | |||||||
|  |  | ||||||
| namespace Zotlabs\Tests\Unit\Access; | namespace Zotlabs\Tests\Unit\Access; | ||||||
|  |  | ||||||
|  | use phpmock\phpunit\PHPMock; | ||||||
| use Zotlabs\Tests\Unit\UnitTestCase; | use Zotlabs\Tests\Unit\UnitTestCase; | ||||||
| use Zotlabs\Access\Permissions; | use Zotlabs\Access\Permissions; | ||||||
|  |  | ||||||
| @@ -33,54 +34,228 @@ use Zotlabs\Access\Permissions; | |||||||
|  */ |  */ | ||||||
| class PermissionsTest extends UnitTestCase { | class PermissionsTest extends UnitTestCase { | ||||||
|  |  | ||||||
|  | 	use PHPMock; | ||||||
|  |  | ||||||
|  | 	public function testVersion() { | ||||||
|  | 		$expectedVersion = 2; | ||||||
|  |  | ||||||
|  | 		// static call | ||||||
|  | 		$this->assertEquals($expectedVersion, Permissions::version()); | ||||||
|  |  | ||||||
|  | 		// instance call | ||||||
|  | 		$p = new Permissions(); | ||||||
|  | 		$this->assertEquals($expectedVersion, $p->version()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
|  | 	 * @coversNothing | ||||||
|  | 	 */ | ||||||
|  | 	public function testVersionEqualsPermissionRoles() { | ||||||
|  | 		$p = new Permissions(); | ||||||
|  | 		$pr = new \Zotlabs\Access\PermissionRoles(); | ||||||
|  | 		$this->assertEquals($p->version(), $pr->version()); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @uses ::call_hooks | ||||||
|  | 	 */ | ||||||
|  | 	public function testPerms() { | ||||||
|  | 		// There are 18 default perms | ||||||
|  | 		$permsCount = 18; | ||||||
|  |  | ||||||
|  | 		// Create a stub for global function t() with expectation | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
|  | 		$t->expects($this->exactly(2*$permsCount))->willReturnCallback( | ||||||
|  | 				function ($string) { | ||||||
|  | 					return $string; | ||||||
|  | 				} | ||||||
|  | 		); | ||||||
|  |  | ||||||
|  | 		// static method Perms() | ||||||
|  | 		$perms = Permissions::Perms(); | ||||||
|  |  | ||||||
|  | 		$p = new Permissions(); | ||||||
|  | 		$this->assertEquals($perms, $p->Perms()); | ||||||
|  |  | ||||||
|  | 		$this->assertEquals($permsCount, count($perms), "There should be $permsCount permissions."); | ||||||
|  |  | ||||||
|  | 		$this->assertEquals('Can view my channel stream and posts', $perms['view_stream']); | ||||||
|  |  | ||||||
|  | 		// non existent perm should not be set | ||||||
|  | 		$this->assertFalse(isset($perms['invalid_perm'])); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * filter parmeter is only used in hook \b permissions_list. So the result | ||||||
|  | 	 * in this test should be the same as if there was no filter parameter. | ||||||
|  | 	 * | ||||||
|  | 	 * @todo Stub call_hooks() function and also test filter | ||||||
|  | 	 * | ||||||
|  | 	 * @uses ::call_hooks | ||||||
|  | 	 */ | ||||||
|  | 	public function testPermsFilter() { | ||||||
|  | 		// There are 18 default perms | ||||||
|  | 		$permsCount = 18; | ||||||
|  |  | ||||||
|  | 		// Create a stub for global function t() with expectation | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
|  | 		$t->expects($this->exactly(2*$permsCount))->willReturnCallback( | ||||||
|  | 				function ($string) { | ||||||
|  | 					return $string; | ||||||
|  | 				} | ||||||
|  | 		); | ||||||
|  |  | ||||||
|  | 		$perms = Permissions::Perms('view_'); | ||||||
|  | 		$this->assertEquals($permsCount, count($perms)); | ||||||
|  |  | ||||||
|  | 		$this->assertEquals('Can view my channel stream and posts', $perms['view_stream']); | ||||||
|  |  | ||||||
|  | 		$perms = Permissions::Perms('invalid_perm'); | ||||||
|  | 		$this->assertEquals($permsCount, count($perms)); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Better should mock Permissions::Perms, but not possible with static methods. | ||||||
|  | 	 * | ||||||
|  | 	 * @uses ::call_hooks | ||||||
|  | 	 * | ||||||
| 	 * @dataProvider FilledPermsProvider | 	 * @dataProvider FilledPermsProvider | ||||||
|  | 	 * | ||||||
|  | 	 * @param array $permarr An indexed permissions array to pass | ||||||
|  | 	 * @param array $expected The expected result perms array | ||||||
| 	 */ | 	 */ | ||||||
| 	public function testFilledPerms($permarr, $expected) { | 	public function testFilledPerms($permarr, $expected) { | ||||||
| 		$this->markTestIncomplete( | 		// Create a stub for global function t() | ||||||
| 			'Need to mock static function Permissions::Perms() ...' | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
| 		); |  | ||||||
| 		//$this->assertEquals($expected, Permissions::FilledPerms($permarr)); |  | ||||||
|  |  | ||||||
| /*		$perms = $this->getMockBuilder(Permissions::class) | 		$this->assertEquals($expected, Permissions::FilledPerms($permarr)); | ||||||
| 			->setMethods(['Perms']) |  | ||||||
| 			->getMock(); |  | ||||||
| 		$perms->expects($this->once()) |  | ||||||
| 			->method('Perms'); |  | ||||||
| 		// still calls the static self::Perms() |  | ||||||
| 		$perms->FilledPerms($permarr); |  | ||||||
| */ |  | ||||||
| 	} | 	} | ||||||
|  | 	/** | ||||||
|  | 	 * @return array An associative array with test values for FilledPerms() | ||||||
|  | 	 *   * \e array Indexed array which is passed as parameter to FilledPerms() | ||||||
|  | 	 *   * \e array Expected associative result array with filled perms | ||||||
|  | 	 */ | ||||||
| 	public function FilledPermsProvider() { | 	public function FilledPermsProvider() { | ||||||
| 		return [ | 		return [ | ||||||
| 				'empty' => [ | 				'Empty param array' => [ | ||||||
| 						[], | 						[], | ||||||
| 						['perm1' => 0, 'perm2' => 0] | 						[ | ||||||
|  | 								'view_stream' => 0, | ||||||
|  | 								'send_stream' => 0, | ||||||
|  | 								'view_profile' => 0, | ||||||
|  | 								'view_contacts' => 0, | ||||||
|  | 								'view_storage' => 0, | ||||||
|  | 								'write_storage' => 0, | ||||||
|  | 								'view_pages' => 0, | ||||||
|  | 								'view_wiki' => 0, | ||||||
|  | 								'write_pages' => 0, | ||||||
|  | 								'write_wiki' => 0, | ||||||
|  | 								'post_wall' => 0, | ||||||
|  | 								'post_comments' => 0, | ||||||
|  | 								'post_mail' => 0, | ||||||
|  | 								'post_like' => 0, | ||||||
|  | 								'tag_deliver' => 0, | ||||||
|  | 								'chat' => 0, | ||||||
|  | 								'republish' => 0, | ||||||
|  | 								'delegate' => 0 | ||||||
|  | 						] | ||||||
| 				], | 				], | ||||||
| 				'valid' => [ | 				'provide view_stream and view_pages as param' => [ | ||||||
| 						[['perm1' => 1]], | 						['view_stream', 'view_pages'], | ||||||
| 						['perm1' => 1, 'perm2' => 0] | 						[ | ||||||
|  | 								'view_stream' => 1, | ||||||
|  | 								'send_stream' => 0, | ||||||
|  | 								'view_profile' => 0, | ||||||
|  | 								'view_contacts' => 0, | ||||||
|  | 								'view_storage' => 0, | ||||||
|  | 								'write_storage' => 0, | ||||||
|  | 								'view_pages' => 1, | ||||||
|  | 								'view_wiki' => 0, | ||||||
|  | 								'write_pages' => 0, | ||||||
|  | 								'write_wiki' => 0, | ||||||
|  | 								'post_wall' => 0, | ||||||
|  | 								'post_comments' => 0, | ||||||
|  | 								'post_mail' => 0, | ||||||
|  | 								'post_like' => 0, | ||||||
|  | 								'tag_deliver' => 0, | ||||||
|  | 								'chat' => 0, | ||||||
|  | 								'republish' => 0, | ||||||
|  | 								'delegate' => 0 | ||||||
|  | 						] | ||||||
|  | 				], | ||||||
|  | 				'provide an unknown param' => [ | ||||||
|  | 						['view_stream', 'unknown_perm'], | ||||||
|  | 						[ | ||||||
|  | 								'view_stream' => 1, | ||||||
|  | 								'send_stream' => 0, | ||||||
|  | 								'view_profile' => 0, | ||||||
|  | 								'view_contacts' => 0, | ||||||
|  | 								'view_storage' => 0, | ||||||
|  | 								'write_storage' => 0, | ||||||
|  | 								'view_pages' => 0, | ||||||
|  | 								'view_wiki' => 0, | ||||||
|  | 								'write_pages' => 0, | ||||||
|  | 								'write_wiki' => 0, | ||||||
|  | 								'post_wall' => 0, | ||||||
|  | 								'post_comments' => 0, | ||||||
|  | 								'post_mail' => 0, | ||||||
|  | 								'post_like' => 0, | ||||||
|  | 								'tag_deliver' => 0, | ||||||
|  | 								'chat' => 0, | ||||||
|  | 								'republish' => 0, | ||||||
|  | 								'delegate' => 0 | ||||||
|  | 						] | ||||||
| 				] | 				] | ||||||
| 		]; | 		]; | ||||||
| 	} | 	} | ||||||
| /*	public function testFilledPermsNull() { | 	/** | ||||||
| 		// need to mock global function btlogger(); | 	 * @uses ::call_hooks | ||||||
| 		Permissions::FilledPerms(null); | 	 */ | ||||||
|  | 	public function testFilledPermsNull() { | ||||||
|  | 		// Create a stub for global function t() with expectation | ||||||
|  | 		$t = $this->getFunctionMock('Zotlabs\Access', 't'); | ||||||
|  | 		$t->expects($this->atLeastOnce()); | ||||||
|  | 		// Create a stub for global function bt() with expectations | ||||||
|  | 		$bt = $this->getFunctionMock('Zotlabs\Access', 'btlogger'); | ||||||
|  | 		$bt->expects($this->once())->with($this->equalTo('FilledPerms: null')); | ||||||
|  |  | ||||||
|  | 		$result = [ | ||||||
|  | 				'view_stream' => 0, | ||||||
|  | 				'send_stream' => 0, | ||||||
|  | 				'view_profile' => 0, | ||||||
|  | 				'view_contacts' => 0, | ||||||
|  | 				'view_storage' => 0, | ||||||
|  | 				'write_storage' => 0, | ||||||
|  | 				'view_pages' => 0, | ||||||
|  | 				'view_wiki' => 0, | ||||||
|  | 				'write_pages' => 0, | ||||||
|  | 				'write_wiki' => 0, | ||||||
|  | 				'post_wall' => 0, | ||||||
|  | 				'post_comments' => 0, | ||||||
|  | 				'post_mail' => 0, | ||||||
|  | 				'post_like' => 0, | ||||||
|  | 				'tag_deliver' => 0, | ||||||
|  | 				'chat' => 0, | ||||||
|  | 				'republish' => 0, | ||||||
|  | 				'delegate' => 0 | ||||||
|  | 		]; | ||||||
|  |  | ||||||
|  | 		$this->assertEquals($result, Permissions::FilledPerms(null)); | ||||||
| 	} | 	} | ||||||
| */ |  | ||||||
| 	/** | 	/** | ||||||
| 	 * @dataProvider OPermsProvider | 	 * @dataProvider OPermsProvider | ||||||
| 	 * | 	 * | ||||||
| 	 * @param array $permarr | 	 * @param array $permarr The params to pass to the OPerms method | ||||||
| 	 * @param array $expected | 	 * @param array $expected The expected result | ||||||
| 	 */ | 	 */ | ||||||
| 	public function testOPerms($permarr, $expected) { | 	public function testOPerms($permarr, $expected) { | ||||||
| 		$this->assertEquals($expected, Permissions::OPerms($permarr)); | 		$this->assertEquals($expected, Permissions::OPerms($permarr)); | ||||||
| 	} | 	} | ||||||
| 	/** | 	/** | ||||||
| 	 * @return Associative array with test values for OPerms() | 	 * @return array An associative array with test values for OPerms() | ||||||
| 	 *   * \e array Array to test | 	 *   * \e array Array with perms to test | ||||||
| 	 *   * \e array Expect array | 	 *   * \e array Expected result array | ||||||
| 	 */ | 	 */ | ||||||
| 	public function OPermsProvider() { | 	public function OPermsProvider() { | ||||||
| 		return [ | 		return [ | ||||||
| @@ -99,22 +274,21 @@ class PermissionsTest extends UnitTestCase { | |||||||
| 		]; | 		]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| 	 * @dataProvider permsCompareProvider | 	 * @dataProvider permsCompareProvider | ||||||
| 	 * | 	 * | ||||||
| 	 * @param array $p1 | 	 * @param array $p1 The first permission | ||||||
| 	 * @param array $p2 | 	 * @param array $p2 The second permission | ||||||
| 	 * @param boolean $expectedresult | 	 * @param boolean $expectedresult The expected result of the tested method | ||||||
| 	 */ | 	 */ | ||||||
| 	public function testPermsCompare($p1, $p2, $expectedresult) { | 	public function testPermsCompare($p1, $p2, $expectedresult) { | ||||||
| 		$this->assertEquals($expectedresult, Permissions::PermsCompare($p1, $p2)); | 		$this->assertEquals($expectedresult, Permissions::PermsCompare($p1, $p2)); | ||||||
| 	} | 	} | ||||||
| 	/** | 	/** | ||||||
| 	 * @return Associative array with test values for PermsCompare() | 	 * @return array An associative array with test values for PermsCompare() | ||||||
| 	 *   * \e array 1st array | 	 *   * \e array 1st array with perms | ||||||
| 	 *   * \e array 2nd array | 	 *   * \e array 2nd array with perms | ||||||
| 	 *   * \e boolean expected result for the test | 	 *   * \e boolean expected result for the perms comparison | ||||||
| 	 */ | 	 */ | ||||||
| 	public function permsCompareProvider() { | 	public function permsCompareProvider() { | ||||||
| 		return [ | 		return [ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user