diff options
Diffstat (limited to 'apps/provisioning_api/tests/Controller/UsersControllerTest.php')
-rw-r--r-- | apps/provisioning_api/tests/Controller/UsersControllerTest.php | 75 |
1 files changed, 72 insertions, 3 deletions
diff --git a/apps/provisioning_api/tests/Controller/UsersControllerTest.php b/apps/provisioning_api/tests/Controller/UsersControllerTest.php index c2ad36c455c..a8a5e4a0591 100644 --- a/apps/provisioning_api/tests/Controller/UsersControllerTest.php +++ b/apps/provisioning_api/tests/Controller/UsersControllerTest.php @@ -34,6 +34,9 @@ namespace OCA\Provisioning_API\Tests\Controller; use Exception; use OC\Accounts\AccountManager; use OC\Group\Manager; +use OCA\FederatedFileSharing\AppInfo\Application; +use OCA\FederatedFileSharing\FederatedShareProvider; +use OCA\Provisioning_API\FederatedFileSharingFactory; use OCP\App\IAppManager; use OCP\AppFramework\OCS\OCSException; use OCP\Mail\IEMailTemplate; @@ -80,6 +83,8 @@ class UsersControllerTest extends TestCase { private $l10nFactory; /** @var NewUserMailHelper|PHPUnit_Framework_MockObject_MockObject */ private $newUserMailHelper; + /** @var FederatedFileSharingFactory|\PHPUnit_Framework_MockObject_MockObject */ + private $federatedFileSharingFactory; protected function setUp() { parent::setUp(); @@ -94,6 +99,7 @@ class UsersControllerTest extends TestCase { $this->accountManager = $this->createMock(AccountManager::class); $this->l10nFactory = $this->createMock(IFactory::class); $this->newUserMailHelper = $this->createMock(NewUserMailHelper::class); + $this->federatedFileSharingFactory = $this->createMock(FederatedFileSharingFactory::class); $this->api = $this->getMockBuilder(UsersController::class) ->setConstructorArgs([ @@ -107,7 +113,8 @@ class UsersControllerTest extends TestCase { $this->accountManager, $this->logger, $this->l10nFactory, - $this->newUserMailHelper + $this->newUserMailHelper, + $this->federatedFileSharingFactory ]) ->setMethods(['fillStorageInfo']) ->getMock(); @@ -2877,7 +2884,8 @@ class UsersControllerTest extends TestCase { $this->accountManager, $this->logger, $this->l10nFactory, - $this->newUserMailHelper + $this->newUserMailHelper, + $this->federatedFileSharingFactory ]) ->setMethods(['getUserData']) ->getMock(); @@ -2938,7 +2946,8 @@ class UsersControllerTest extends TestCase { $this->accountManager, $this->logger, $this->l10nFactory, - $this->newUserMailHelper + $this->newUserMailHelper, + $this->federatedFileSharingFactory ]) ->setMethods(['getUserData']) ->getMock(); @@ -3318,4 +3327,64 @@ class UsersControllerTest extends TestCase { $this->api->resendWelcomeMessage('UserToGet'); } + + + public function dataGetEditableFields() { + return [ + [false, false, []], + [false, true, [ + AccountManager::PROPERTY_PHONE, + AccountManager::PROPERTY_ADDRESS, + AccountManager::PROPERTY_WEBSITE, + AccountManager::PROPERTY_TWITTER, + ]], + [ true, false, [ + AccountManager::PROPERTY_DISPLAYNAME, + AccountManager::PROPERTY_EMAIL, + ]], + [ true, true ,[ + AccountManager::PROPERTY_DISPLAYNAME, + AccountManager::PROPERTY_EMAIL, + AccountManager::PROPERTY_PHONE, + AccountManager::PROPERTY_ADDRESS, + AccountManager::PROPERTY_WEBSITE, + AccountManager::PROPERTY_TWITTER, + ]] + ]; + } + + /** + * @dataProvider dataGetEditableFields + * + * @param bool $allowedToChangeDisplayName + * @param bool $federatedSharingEnabled + * @param array $expected + */ + public function testGetEditableFields(bool $allowedToChangeDisplayName, bool $federatedSharingEnabled, array $expected) { + $this->config + ->method('getSystemValue') + ->with( + $this->equalTo('allow_user_to_change_display_name'), + $this->anything() + )->willReturn($allowedToChangeDisplayName); + $this->appManager + ->method('isEnabledForUser') + ->with($this->equalTo('federatedfilesharing')) + ->willReturn($federatedSharingEnabled); + + $shareprovider = $this->createMock(FederatedShareProvider::class); + $shareprovider->method('isLookupServerUploadEnabled')->willReturn(true); + + $federatedFileSharing = $this->createMock(Application::class); + $federatedFileSharing + ->method('getFederatedShareProvider') + ->willReturn($shareprovider); + + $this->federatedFileSharingFactory + ->method('get') + ->willReturn($federatedFileSharing); + + $expectedResp = new DataResponse($expected); + $this->assertEquals($expectedResp, $this->api->getEditableFields()); + } } |