diff options
-rw-r--r-- | tests/lib/L10N/FactoryTest.php | 118 | ||||
-rw-r--r-- | tests/lib/Mail/MailerTest.php | 2 | ||||
-rw-r--r-- | tests/lib/OCS/ProviderTest.php | 86 | ||||
-rw-r--r-- | tests/lib/Repair/ClearFrontendCachesTest.php | 2 | ||||
-rw-r--r-- | tests/lib/Repair/NC11/FixMountStoragesTest.php | 11 | ||||
-rw-r--r-- | tests/lib/Security/CertificateManagerTest.php | 2 | ||||
-rw-r--r-- | tests/lib/Security/IdentityProof/ManagerTest.php | 48 | ||||
-rw-r--r-- | tests/lib/Share20/ManagerTest.php | 253 | ||||
-rw-r--r-- | tests/lib/Template/JSCombinerTest.php | 116 | ||||
-rw-r--r-- | tests/lib/Updater/VersionCheckTest.php | 218 | ||||
-rw-r--r-- | tests/lib/User/ManagerTest.php | 24 |
11 files changed, 405 insertions, 475 deletions
diff --git a/tests/lib/L10N/FactoryTest.php b/tests/lib/L10N/FactoryTest.php index faf9dff48cc..4e01602a4f7 100644 --- a/tests/lib/L10N/FactoryTest.php +++ b/tests/lib/L10N/FactoryTest.php @@ -146,20 +146,21 @@ class FactoryTest extends TestCase { public function testFindLanguageWithNotExistingRequestLanguageAndNotExistingStoredUserLanguage(): void { $factory = $this->getFactory(['languageExists'], true); $this->invokePrivate($factory, 'requestLanguage', ['de']); - $factory->expects(self::at(0)) - ->method('languageExists') - ->with('MyApp', 'de') - ->willReturn(false); + $factory->expects($this->exactly(3)) + ->method('languageExists') + ->willReturnMap([ + ['MyApp', 'de', false], + ['MyApp', 'jp', false], + ['MyApp', 'es', true], + ]); $this->config - ->expects(self::at(0)) + ->expects($this->exactly(3)) ->method('getSystemValue') - ->with('force_language', false) - ->willReturn(false); - $this->config - ->expects(self::at(1)) - ->method('getSystemValue') - ->with('installed', false) - ->willReturn(true); + ->willReturnMap([ + ['force_language', false, false], + ['installed', false, true], + ['default_language', false, 'es'] + ]); $user = $this->getMockBuilder(IUser::class) ->getMock(); $user->expects(self::once()) @@ -174,19 +175,6 @@ class FactoryTest extends TestCase { ->method('getUserValue') ->with('MyUserUid', 'core', 'lang', null) ->willReturn('jp'); - $factory->expects(self::at(1)) - ->method('languageExists') - ->with('MyApp', 'jp') - ->willReturn(false); - $this->config - ->expects(self::at(3)) - ->method('getSystemValue') - ->with('default_language', false) - ->willReturn('es'); - $factory->expects(self::at(2)) - ->method('languageExists') - ->with('MyApp', 'es') - ->willReturn(true); self::assertSame('es', $factory->findLanguage('MyApp')); } @@ -194,20 +182,21 @@ class FactoryTest extends TestCase { public function testFindLanguageWithNotExistingRequestLanguageAndNotExistingStoredUserLanguageAndNotExistingDefault(): void { $factory = $this->getFactory(['languageExists'], true); $this->invokePrivate($factory, 'requestLanguage', ['de']); - $factory->expects(self::at(0)) - ->method('languageExists') - ->with('MyApp', 'de') - ->willReturn(false); + $factory->expects($this->exactly(3)) + ->method('languageExists') + ->willReturnMap([ + ['MyApp', 'de', false], + ['MyApp', 'jp', false], + ['MyApp', 'es', false], + ]); $this->config - ->expects(self::at(0)) + ->expects($this->exactly(3)) ->method('getSystemValue') - ->with('force_language', false) - ->willReturn(false); - $this->config - ->expects(self::at(1)) - ->method('getSystemValue') - ->with('installed', false) - ->willReturn(true); + ->willReturnMap([ + ['force_language', false, false], + ['installed', false, true], + ['default_language', false, 'es'] + ]); $user = $this->getMockBuilder(IUser::class) ->getMock(); $user->expects(self::once()) @@ -222,19 +211,6 @@ class FactoryTest extends TestCase { ->method('getUserValue') ->with('MyUserUid', 'core', 'lang', null) ->willReturn('jp'); - $factory->expects(self::at(1)) - ->method('languageExists') - ->with('MyApp', 'jp') - ->willReturn(false); - $this->config - ->expects(self::at(3)) - ->method('getSystemValue') - ->with('default_language', false) - ->willReturn('es'); - $factory->expects(self::at(2)) - ->method('languageExists') - ->with('MyApp', 'es') - ->willReturn(false); $this->config ->expects(self::never()) ->method('setUserValue'); @@ -245,20 +221,21 @@ class FactoryTest extends TestCase { public function testFindLanguageWithNotExistingRequestLanguageAndNotExistingStoredUserLanguageAndNotExistingDefaultAndNoAppInScope(): void { $factory = $this->getFactory(['languageExists'], true); $this->invokePrivate($factory, 'requestLanguage', ['de']); - $factory->expects(self::at(0)) - ->method('languageExists') - ->with('MyApp', 'de') - ->willReturn(false); + $factory->expects($this->exactly(3)) + ->method('languageExists') + ->willReturnMap([ + ['MyApp', 'de', false], + ['MyApp', 'jp', false], + ['MyApp', 'es', false], + ]); $this->config - ->expects(self::at(0)) + ->expects($this->exactly(3)) ->method('getSystemValue') - ->with('force_language', false) - ->willReturn(false); - $this->config - ->expects(self::at(1)) - ->method('getSystemValue') - ->with('installed', false) - ->willReturn(true); + ->willReturnMap([ + ['force_language', false, false], + ['installed', false, true], + ['default_language', false, 'es'] + ]); $user = $this->getMockBuilder(IUser::class) ->getMock(); $user->expects(self::once()) @@ -273,19 +250,6 @@ class FactoryTest extends TestCase { ->method('getUserValue') ->with('MyUserUid', 'core', 'lang', null) ->willReturn('jp'); - $factory->expects(self::at(1)) - ->method('languageExists') - ->with('MyApp', 'jp') - ->willReturn(false); - $this->config - ->expects(self::at(3)) - ->method('getSystemValue') - ->with('default_language', false) - ->willReturn('es'); - $factory->expects(self::at(2)) - ->method('languageExists') - ->with('MyApp', 'es') - ->willReturn(false); $this->config ->expects(self::never()) ->method('setUserValue') @@ -298,12 +262,12 @@ class FactoryTest extends TestCase { public function testFindLanguageWithForcedLanguage(): void { $factory = $this->getFactory(['languageExists']); $this->config - ->expects(self::at(0)) + ->expects($this->once()) ->method('getSystemValue') ->with('force_language', false) ->willReturn('de'); - $factory->expects(self::once()) + $factory->expects($this->once()) ->method('languageExists') ->with('MyApp', 'de') ->willReturn(true); diff --git a/tests/lib/Mail/MailerTest.php b/tests/lib/Mail/MailerTest.php index 4b15a4233fd..74c4f2a62ab 100644 --- a/tests/lib/Mail/MailerTest.php +++ b/tests/lib/Mail/MailerTest.php @@ -135,7 +135,7 @@ class MailerTest extends TestCase { $message = $this->createMock(Message::class); $event = new BeforeMessageSent($message); - $this->dispatcher->expects($this->at(0)) + $this->dispatcher->expects($this->once()) ->method('dispatchTyped') ->with($this->equalTo($event)); diff --git a/tests/lib/OCS/ProviderTest.php b/tests/lib/OCS/ProviderTest.php index 3a78793f91d..f66bd2eab01 100644 --- a/tests/lib/OCS/ProviderTest.php +++ b/tests/lib/OCS/ProviderTest.php @@ -41,24 +41,14 @@ class ProviderTest extends \Test\TestCase { public function testBuildProviderListWithoutAnythingEnabled() { $this->appManager - ->expects($this->at(0)) + ->expects($this->exactly(4)) ->method('isEnabledForUser') - ->with('files_sharing') - ->willReturn(false); - $this->appManager - ->expects($this->at(1)) - ->method('isEnabledForUser') - ->with('federation') - ->willReturn(false); - $this->appManager - ->expects($this->at(2)) - ->method('isEnabledForUser') - ->with('activity') - ->willReturn(false); - $this->appManager - ->expects($this->at(3)) - ->method('isEnabledForUser') - ->with('provisioning_api') + ->withConsecutive( + ['files_sharing'], + ['federation'], + ['activity'], + ['provisioning_api'] + ) ->willReturn(false); $expected = new \OCP\AppFramework\Http\JSONResponse( @@ -82,25 +72,20 @@ class ProviderTest extends \Test\TestCase { public function testBuildProviderListWithSharingEnabled() { $this->appManager - ->expects($this->at(0)) - ->method('isEnabledForUser') - ->with('files_sharing') - ->willReturn(true); - $this->appManager - ->expects($this->at(1)) - ->method('isEnabledForUser') - ->with('federation') - ->willReturn(false); - $this->appManager - ->expects($this->at(2)) + ->expects($this->exactly(4)) ->method('isEnabledForUser') - ->with('activity') - ->willReturn(false); - $this->appManager - ->expects($this->at(3)) - ->method('isEnabledForUser') - ->with('provisioning_api') - ->willReturn(false); + ->withConsecutive( + ['files_sharing'], + ['federation'], + ['activity'], + ['provisioning_api'] + ) + ->willReturnOnConsecutiveCalls( + true, + false, + false, + false + ); $expected = new \OCP\AppFramework\Http\JSONResponse( [ @@ -136,25 +121,20 @@ class ProviderTest extends \Test\TestCase { public function testBuildProviderListWithFederationEnabled() { $this->appManager - ->expects($this->at(0)) - ->method('isEnabledForUser') - ->with('files_sharing') - ->willReturn(false); - $this->appManager - ->expects($this->at(1)) + ->expects($this->exactly(4)) ->method('isEnabledForUser') - ->with('federation') - ->willReturn(true); - $this->appManager - ->expects($this->at(2)) - ->method('isEnabledForUser') - ->with('activity') - ->willReturn(false); - $this->appManager - ->expects($this->at(3)) - ->method('isEnabledForUser') - ->with('provisioning_api') - ->willReturn(false); + ->withConsecutive( + ['files_sharing'], + ['federation'], + ['activity'], + ['provisioning_api'] + ) + ->willReturnOnConsecutiveCalls( + false, + true, + false, + false + ); $expected = new \OCP\AppFramework\Http\JSONResponse( [ diff --git a/tests/lib/Repair/ClearFrontendCachesTest.php b/tests/lib/Repair/ClearFrontendCachesTest.php index d89a19e70cc..09b96be7de3 100644 --- a/tests/lib/Repair/ClearFrontendCachesTest.php +++ b/tests/lib/Repair/ClearFrontendCachesTest.php @@ -61,7 +61,7 @@ class ClearFrontendCachesTest extends \Test\TestCase { ->with(''); $this->jsCombiner->expects($this->once()) ->method('resetCache'); - $this->cacheFactory->expects($this->at(0)) + $this->cacheFactory->expects($this->once()) ->method('createDistributed') ->with('imagePath') ->willReturn($imagePathCache); diff --git a/tests/lib/Repair/NC11/FixMountStoragesTest.php b/tests/lib/Repair/NC11/FixMountStoragesTest.php index 9bc61865235..33c3fc1da11 100644 --- a/tests/lib/Repair/NC11/FixMountStoragesTest.php +++ b/tests/lib/Repair/NC11/FixMountStoragesTest.php @@ -70,18 +70,17 @@ class FixMountStoragesTest extends TestCase { /** @var IOutput|\PHPUnit\Framework\MockObject\MockObject $output */ $output = $this->createMock(IOutput::class); - $output->expects($this->at(0)) + $output->expects($this->exactly(2)) ->method('info') - ->with('1 mounts updated'); + ->withConsecutive( + ['1 mounts updated'], + ['No mounts updated'] + ); $this->repair->run($output); $this->assertStorage($mount1, 42); $this->assertStorage($mount2, 23); - $output->expects($this->at(0)) - ->method('info') - ->with('No mounts updated'); - $this->repair->run($output); $this->assertStorage($mount1, 42); $this->assertStorage($mount2, 23); diff --git a/tests/lib/Security/CertificateManagerTest.php b/tests/lib/Security/CertificateManagerTest.php index b1659d1096d..fdc6b40533e 100644 --- a/tests/lib/Security/CertificateManagerTest.php +++ b/tests/lib/Security/CertificateManagerTest.php @@ -163,7 +163,7 @@ class CertificateManagerTest extends \Test\TestCase { $certificateManager->expects($this->any())->method('getFilemtimeOfCaBundle') ->willReturn($CaBundleMtime); - $certificateManager->expects($this->at(0))->method('getCertificateBundle') + $certificateManager->expects($this->once())->method('getCertificateBundle') ->willReturn('targetBundlePath'); $view->expects($this->any())->method('file_exists') diff --git a/tests/lib/Security/IdentityProof/ManagerTest.php b/tests/lib/Security/IdentityProof/ManagerTest.php index 968cfa633ca..8733d5de8be 100644 --- a/tests/lib/Security/IdentityProof/ManagerTest.php +++ b/tests/lib/Security/IdentityProof/ManagerTest.php @@ -117,15 +117,16 @@ class ManagerTest extends TestCase { ->with('EncryptedPrivateKey') ->willReturn('MyPrivateKey'); $folder - ->expects($this->at(0)) + ->expects($this->exactly(2)) ->method('getFile') - ->with('private') - ->willReturn($privateFile); - $folder - ->expects($this->at(1)) - ->method('getFile') - ->with('public') - ->willReturn($publicFile); + ->withConsecutive( + ['private'], + ['public'] + ) + ->willReturnOnConsecutiveCalls( + $privateFile, + $publicFile + ); $this->appData ->expects($this->once()) ->method('getFolder') @@ -142,17 +143,12 @@ class ManagerTest extends TestCase { ->expects($this->once()) ->method('getUID') ->willReturn('MyUid'); - $this->appData - ->expects($this->at(0)) - ->method('getFolder') - ->with('user-MyUid') - ->willThrowException(new \Exception()); $this->manager ->expects($this->once()) ->method('generateKeyPair') ->willReturn(['MyNewPublicKey', 'MyNewPrivateKey']); $this->appData - ->expects($this->at(1)) + ->expects($this->once()) ->method('newFolder') ->with('user-MyUid'); $folder = $this->createMock(ISimpleFolder::class); @@ -172,20 +168,24 @@ class ManagerTest extends TestCase { ->method('putContent') ->with('MyNewPublicKey'); $folder - ->expects($this->at(0)) - ->method('newFile') - ->with('private') - ->willReturn($privateFile); - $folder - ->expects($this->at(1)) + ->expects($this->exactly(2)) ->method('newFile') - ->with('public') - ->willReturn($publicFile); + ->withConsecutive( + ['private'], + ['public'] + ) + ->willReturnOnConsecutiveCalls( + $privateFile, + $publicFile + ); $this->appData - ->expects($this->at(2)) + ->expects($this->exactly(2)) ->method('getFolder') ->with('user-MyUid') - ->willReturn($folder); + ->willReturnOnConsecutiveCalls( + $this->throwException(new \Exception()), + $folder + ); $expected = new Key('MyNewPublicKey', 'MyNewPrivateKey'); diff --git a/tests/lib/Share20/ManagerTest.php b/tests/lib/Share20/ManagerTest.php index 4e613d1cf5c..a7bb6cbcefc 100644 --- a/tests/lib/Share20/ManagerTest.php +++ b/tests/lib/Share20/ManagerTest.php @@ -248,22 +248,18 @@ class ManagerTest extends \Test\TestCase { ->method('delete') ->with($share); - $this->eventDispatcher->expects($this->at(0)) + $this->eventDispatcher->expects($this->exactly(2)) ->method('dispatch') - ->with( - 'OCP\Share::preUnshare', - $this->callBack(function (GenericEvent $e) use ($share) { - return $e->getSubject() === $share; - }) - ); - $this->eventDispatcher->expects($this->at(1)) - ->method('dispatch') - ->with( - 'OCP\Share::postUnshare', - $this->callBack(function (GenericEvent $e) use ($share) { - return $e->getSubject() === $share && - $e->getArgument('deletedShares') === [$share]; - }) + ->withConsecutive( + ['OCP\Share::preUnshare', + $this->callBack(function (GenericEvent $e) use ($share) { + return $e->getSubject() === $share; + })], + ['OCP\Share::postUnshare', + $this->callBack(function (GenericEvent $e) use ($share) { + return $e->getSubject() === $share && + $e->getArgument('deletedShares') === [$share]; + })] ); $manager->deleteShare($share); @@ -296,22 +292,18 @@ class ManagerTest extends \Test\TestCase { ->method('delete') ->with($share); - $this->eventDispatcher->expects($this->at(0)) - ->method('dispatch') - ->with( - 'OCP\Share::preUnshare', - $this->callBack(function (GenericEvent $e) use ($share) { - return $e->getSubject() === $share; - }) - ); - $this->eventDispatcher->expects($this->at(1)) + $this->eventDispatcher->expects($this->exactly(2)) ->method('dispatch') - ->with( - 'OCP\Share::postUnshare', - $this->callBack(function (GenericEvent $e) use ($share) { - return $e->getSubject() === $share && - $e->getArgument('deletedShares') === [$share]; - }) + ->withConsecutive( + ['OCP\Share::preUnshare', + $this->callBack(function (GenericEvent $e) use ($share) { + return $e->getSubject() === $share; + })], + ['OCP\Share::postUnshare', + $this->callBack(function (GenericEvent $e) use ($share) { + return $e->getSubject() === $share && + $e->getArgument('deletedShares') === [$share]; + })] ); $manager->deleteShare($share); @@ -365,22 +357,18 @@ class ManagerTest extends \Test\TestCase { ->method('delete') ->withConsecutive([$share3], [$share2], [$share1]); - $this->eventDispatcher->expects($this->at(0)) - ->method('dispatch') - ->with( - 'OCP\Share::preUnshare', - $this->callBack(function (GenericEvent $e) use ($share1) { - return $e->getSubject() === $share1; - }) - ); - $this->eventDispatcher->expects($this->at(1)) + $this->eventDispatcher->expects($this->exactly(2)) ->method('dispatch') - ->with( - 'OCP\Share::postUnshare', - $this->callBack(function (GenericEvent $e) use ($share1, $share2, $share3) { - return $e->getSubject() === $share1 && - $e->getArgument('deletedShares') === [$share3, $share2, $share1]; - }) + ->withConsecutive( + ['OCP\Share::preUnshare', + $this->callBack(function (GenericEvent $e) use ($share1) { + return $e->getSubject() === $share1; + })], + ['OCP\Share::postUnshare', + $this->callBack(function (GenericEvent $e) use ($share1, $share2, $share3) { + return $e->getSubject() === $share1 && + $e->getArgument('deletedShares') === [$share3, $share2, $share1]; + })] ); $manager->deleteShare($share1); @@ -408,7 +396,7 @@ class ManagerTest extends \Test\TestCase { ->method('deleteFromSelf') ->with($share, $recipientId); - $this->eventDispatcher->expects($this->at(0)) + $this->eventDispatcher->expects($this->once()) ->method('dispatch') ->with( 'OCP\Share::postUnshareFromSelf', @@ -2330,44 +2318,39 @@ class ManagerTest extends \Test\TestCase { return $share->setId(42); }); - // Pre share - $this->eventDispatcher->expects($this->at(0)) + $this->eventDispatcher->expects($this->exactly(2)) ->method('dispatch') - ->with( - $this->equalTo('OCP\Share::preShare'), - $this->callback(function (GenericEvent $e) use ($path, $date) { - /** @var IShare $share */ - $share = $e->getSubject(); - - return $share->getShareType() === IShare::TYPE_LINK && - $share->getNode() === $path && - $share->getSharedBy() === 'sharedBy' && - $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && - $share->getExpirationDate() === $date && - $share->getPassword() === 'hashed' && - $share->getToken() === 'token'; - }) - ); - - // Post share - $this->eventDispatcher->expects($this->at(1)) - ->method('dispatch') - ->with( - $this->equalTo('OCP\Share::postShare'), - $this->callback(function (GenericEvent $e) use ($path, $date) { - /** @var IShare $share */ - $share = $e->getSubject(); - - return $share->getShareType() === IShare::TYPE_LINK && - $share->getNode() === $path && - $share->getSharedBy() === 'sharedBy' && - $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && - $share->getExpirationDate() === $date && - $share->getPassword() === 'hashed' && - $share->getToken() === 'token' && - $share->getId() === '42' && - $share->getTarget() === '/target'; - }) + ->withConsecutive( + // Pre share + [$this->equalTo('OCP\Share::preShare'), + $this->callback(function (GenericEvent $e) use ($path, $date) { + /** @var IShare $share */ + $share = $e->getSubject(); + + return $share->getShareType() === IShare::TYPE_LINK && + $share->getNode() === $path && + $share->getSharedBy() === 'sharedBy' && + $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && + $share->getExpirationDate() === $date && + $share->getPassword() === 'hashed' && + $share->getToken() === 'token'; + })], + // Post share + [$this->equalTo('OCP\Share::postShare'), + $this->callback(function (GenericEvent $e) use ($path, $date) { + /** @var IShare $share */ + $share = $e->getSubject(); + + return $share->getShareType() === IShare::TYPE_LINK && + $share->getNode() === $path && + $share->getSharedBy() === 'sharedBy' && + $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && + $share->getExpirationDate() === $date && + $share->getPassword() === 'hashed' && + $share->getToken() === 'token' && + $share->getId() === '42' && + $share->getTarget() === '/target'; + })] ); /** @var IShare $share */ @@ -2442,44 +2425,37 @@ class ManagerTest extends \Test\TestCase { return $share->setId(42); }); - // Pre share - $this->eventDispatcher->expects($this->at(0)) - ->method('dispatch') - ->with( - $this->equalTo('OCP\Share::preShare'), - $this->callback(function (GenericEvent $e) use ($path) { - /** @var IShare $share */ - $share = $e->getSubject(); - - return $share->getShareType() === IShare::TYPE_EMAIL && - $share->getNode() === $path && - $share->getSharedBy() === 'sharedBy' && - $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && - $share->getExpirationDate() === null && - $share->getPassword() === null && - $share->getToken() === 'token'; - }) - ); - - // Post share - $this->eventDispatcher->expects($this->at(1)) + $this->eventDispatcher->expects($this->exactly(2)) ->method('dispatch') - ->with( - $this->equalTo('OCP\Share::postShare'), - $this->callback(function (GenericEvent $e) use ($path) { - /** @var IShare $share */ - $share = $e->getSubject(); - - return $share->getShareType() === IShare::TYPE_EMAIL && - $share->getNode() === $path && - $share->getSharedBy() === 'sharedBy' && - $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && - $share->getExpirationDate() === null && - $share->getPassword() === null && - $share->getToken() === 'token' && - $share->getId() === '42' && - $share->getTarget() === '/target'; - }) + ->withConsecutive( + [$this->equalTo('OCP\Share::preShare'), + $this->callback(function (GenericEvent $e) use ($path) { + /** @var IShare $share */ + $share = $e->getSubject(); + + return $share->getShareType() === IShare::TYPE_EMAIL && + $share->getNode() === $path && + $share->getSharedBy() === 'sharedBy' && + $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && + $share->getExpirationDate() === null && + $share->getPassword() === null && + $share->getToken() === 'token'; + })], + [$this->equalTo('OCP\Share::postShare'), + $this->callback(function (GenericEvent $e) use ($path) { + /** @var IShare $share */ + $share = $e->getSubject(); + + return $share->getShareType() === IShare::TYPE_EMAIL && + $share->getNode() === $path && + $share->getSharedBy() === 'sharedBy' && + $share->getPermissions() === \OCP\Constants::PERMISSION_ALL && + $share->getExpirationDate() === null && + $share->getPassword() === null && + $share->getToken() === 'token' && + $share->getId() === '42' && + $share->getTarget() === '/target'; + })], ); /** @var IShare $share */ @@ -2868,23 +2844,21 @@ class ManagerTest extends \Test\TestCase { $share = $this->createMock(IShare::class); - $factory->expects($this->at(0)) - ->method('getProviderForType') - ->with(IShare::TYPE_LINK) - ->willReturn($this->defaultProvider); - $factory->expects($this->at(1)) + $factory->expects($this->exactly(2)) ->method('getProviderForType') - ->with(IShare::TYPE_REMOTE) + ->withConsecutive( + [IShare::TYPE_LINK], + [IShare::TYPE_REMOTE] + ) ->willReturn($this->defaultProvider); - $this->defaultProvider->expects($this->at(0)) + $this->defaultProvider->expects($this->exactly(2)) ->method('getShareByToken') ->with('token') - ->will($this->throwException(new ShareNotFound())); - $this->defaultProvider->expects($this->at(1)) - ->method('getShareByToken') - ->with('token') - ->willReturn($share); + ->willReturnOnConsecutiveCalls( + $this->throwException(new ShareNotFound()), + $share + ); $ret = $manager->getShareByToken('token'); $this->assertSame($share, $ret); @@ -2963,10 +2937,12 @@ class ManagerTest extends \Test\TestCase { public function testGetShareByTokenPublicUploadDisabled() { $this->config - ->expects($this->at(0)) + ->expects($this->exactly(2)) ->method('getAppValue') - ->with('core', 'shareapi_allow_links', 'yes') - ->willReturn('yes'); + ->willReturnMap([ + ['core', 'shareapi_allow_links', 'yes', 'yes'], + ['core', 'shareapi_allow_public_upload', 'yes', 'no'], + ]); $share = $this->manager->newShare(); $share->setShareType(IShare::TYPE_LINK) @@ -2975,13 +2951,6 @@ class ManagerTest extends \Test\TestCase { $folder = $this->createMock(\OC\Files\Node\Folder::class); $share->setNode($folder); - $this->config - ->expects($this->at(1)) - ->method('getAppValue') - ->willReturnMap([ - ['core', 'shareapi_allow_public_upload', 'yes', 'no'], - ]); - $this->defaultProvider->expects($this->once()) ->method('getShareByToken') ->willReturn('validToken') diff --git a/tests/lib/Template/JSCombinerTest.php b/tests/lib/Template/JSCombinerTest.php index 5c678840c63..2c98d33d543 100644 --- a/tests/lib/Template/JSCombinerTest.php +++ b/tests/lib/Template/JSCombinerTest.php @@ -59,7 +59,7 @@ class JSCombinerTest extends \Test\TestCase { $this->config = $this->createMock(SystemConfig::class); $this->cacheFactory = $this->createMock(ICacheFactory::class); $this->depsCache = $this->createMock(ICache::class); - $this->cacheFactory->expects($this->at(0)) + $this->cacheFactory->expects($this->atLeastOnce()) ->method('createDistributed') ->willReturn($this->depsCache); $this->logger = $this->createMock(LoggerInterface::class); @@ -85,15 +85,16 @@ class JSCombinerTest extends \Test\TestCase { public function testProcessNotInstalled() { $this->config - ->expects($this->at(0)) + ->expects($this->exactly(2)) ->method('getValue') - ->with('debug') - ->willReturn(false); - $this->config - ->expects($this->at(1)) - ->method('getValue') - ->with('installed') - ->willReturn(false); + ->withConsecutive( + ['debug'], + ['installed'] + ) + ->willReturnOnConsecutiveCalls( + false, + false + ); $actual = $this->jsCombiner->process(__DIR__, '/data/combine.json', 'awesomeapp'); $this->assertFalse($actual); @@ -101,15 +102,16 @@ class JSCombinerTest extends \Test\TestCase { public function testProcessUncachedFileNoAppDataFolder() { $this->config - ->expects($this->at(0)) - ->method('getValue') - ->with('debug') - ->willReturn(false); - $this->config - ->expects($this->at(1)) + ->expects($this->exactly(2)) ->method('getValue') - ->with('installed') - ->willReturn(true); + ->withConsecutive( + ['debug'], + ['installed'] + ) + ->willReturnOnConsecutiveCalls( + false, + true + ); $folder = $this->createMock(ISimpleFolder::class); $this->appData->expects($this->once())->method('getFolder')->with('awesomeapp')->willThrowException(new NotFoundException()); $this->appData->expects($this->once())->method('newFolder')->with('awesomeapp')->willReturn($folder); @@ -140,15 +142,16 @@ class JSCombinerTest extends \Test\TestCase { public function testProcessUncachedFile() { $this->config - ->expects($this->at(0)) - ->method('getValue') - ->with('debug') - ->willReturn(false); - $this->config - ->expects($this->at(1)) + ->expects($this->exactly(2)) ->method('getValue') - ->with('installed') - ->willReturn(true); + ->withConsecutive( + ['debug'], + ['installed'] + ) + ->willReturnOnConsecutiveCalls( + false, + true + ); $folder = $this->createMock(ISimpleFolder::class); $this->appData->expects($this->once())->method('getFolder')->with('awesomeapp')->willReturn($folder); $file = $this->createMock(ISimpleFile::class); @@ -177,15 +180,16 @@ class JSCombinerTest extends \Test\TestCase { public function testProcessCachedFile() { $this->config - ->expects($this->at(0)) + ->expects($this->exactly(2)) ->method('getValue') - ->with('debug') - ->willReturn(false); - $this->config - ->expects($this->at(1)) - ->method('getValue') - ->with('installed') - ->willReturn(true); + ->withConsecutive( + ['debug'], + ['installed'] + ) + ->willReturnOnConsecutiveCalls( + false, + true + ); $folder = $this->createMock(ISimpleFolder::class); $this->appData->expects($this->once())->method('getFolder')->with('awesomeapp')->willReturn($folder); $file = $this->createMock(ISimpleFile::class); @@ -217,15 +221,16 @@ class JSCombinerTest extends \Test\TestCase { public function testProcessCachedFileMemcache() { $this->config - ->expects($this->at(0)) - ->method('getValue') - ->with('debug') - ->willReturn(false); - $this->config - ->expects($this->at(1)) + ->expects($this->exactly(2)) ->method('getValue') - ->with('installed') - ->willReturn(true); + ->withConsecutive( + ['debug'], + ['installed'] + ) + ->willReturnOnConsecutiveCalls( + false, + true + ); $folder = $this->createMock(ISimpleFolder::class); $this->appData->expects($this->once()) ->method('getFolder') @@ -401,13 +406,23 @@ class JSCombinerTest extends \Test\TestCase { $folder = $this->createMock(ISimpleFolder::class); $file = $this->createMock(ISimpleFile::class); $depsFile = $this->createMock(ISimpleFile::class); + $gzFile = $this->createMock(ISimpleFile::class); $path = __DIR__ . '/data/'; - $folder->expects($this->at(0))->method('getFile')->with($fileName)->willReturn($file); - $folder->expects($this->at(1))->method('getFile')->with($fileName . '.deps')->willReturn($depsFile); + $folder->expects($this->exactly(3)) + ->method('getFile') + ->withConsecutive( + [$fileName], + [$fileName . '.deps'], + [$fileName . '.gzip'] + )->willReturnOnConsecutiveCalls( + $file, + $depsFile, + $gzFile + ); - $file->expects($this->at(0)) + $file->expects($this->once()) ->method('putContent') ->with('var a = \'hello\'; @@ -417,7 +432,7 @@ var b = \'world\'; '); $depsFile - ->expects($this->at(0)) + ->expects($this->once()) ->method('putContent') ->with($this->callback( function ($content) { @@ -455,7 +470,7 @@ var b = \'world\'; } ); - $file->expects($this->at(0)) + $file->expects($this->once()) ->method('putContent') ->with('var a = \'hello\'; @@ -464,13 +479,13 @@ var b = \'world\'; '); - $depsFile->expects($this->at(0))->method('putContent')->with($this->callback( + $depsFile->expects($this->once())->method('putContent')->with($this->callback( function ($content) { $deps = json_decode($content, true); return array_key_exists(__DIR__ . '/data//1.js', $deps) && array_key_exists(__DIR__ . '/data//2.js', $deps); })); - $gzFile->expects($this->at(0))->method('putContent')->with($this->callback( + $gzFile->expects($this->once())->method('putContent')->with($this->callback( function ($content) { return gzdecode($content) === 'var a = \'hello\'; @@ -550,9 +565,8 @@ var b = \'world\'; $this->cacheFactory->expects($this->once()) ->method('createDistributed') ->willReturn($cache); - $cache->expects($this->once()) - ->method('clear') - ->with(''); + $cache->expects($this->never()) + ->method('clear'); $this->appData->expects($this->once()) ->method('getDirectoryListing') ->willReturn([$folder]); diff --git a/tests/lib/Updater/VersionCheckTest.php b/tests/lib/Updater/VersionCheckTest.php index f4216ddb0a3..cc2b0a369aa 100644 --- a/tests/lib/Updater/VersionCheckTest.php +++ b/tests/lib/Updater/VersionCheckTest.php @@ -66,20 +66,21 @@ class VersionCheckTest extends \Test\TestCase { ]; $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(true); $this->config - ->expects($this->at(1)) - ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn(time()); - $this->config - ->expects($this->at(2)) + ->expects($this->exactly(2)) ->method('getAppValue') - ->with('core', 'lastupdateResult') - ->willReturn(json_encode($expectedResult)); + ->withConsecutive( + ['core', 'lastupdatedat'], + ['core', 'lastupdateResult'] + ) + ->willReturnOnConsecutiveCalls( + time(), + json_encode($expectedResult) + ); $this->assertSame($expectedResult, $this->updater->check()); } @@ -96,38 +97,37 @@ class VersionCheckTest extends \Test\TestCase { ]; $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(true); $this->config - ->expects($this->at(1)) + ->expects($this->exactly(4)) ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn(0); + ->withConsecutive( + ['core', 'lastupdatedat'], + ['core', 'installedat'], + ['core', 'installedat'], + ['core', 'lastupdatedat'], + ) + ->willReturnOnConsecutiveCalls( + 0, + 'installedat', + 'installedat', + 'lastupdatedat' + ); $this->config - ->expects($this->at(2)) + ->expects($this->once()) ->method('getSystemValue') ->with('updater.server.url', 'https://updates.nextcloud.com/updater_server/') ->willReturnArgument(1); $this->config - ->expects($this->at(3)) - ->method('setAppValue') - ->with('core', 'lastupdatedat', $this->isType('integer')); - $this->config - ->expects($this->at(5)) - ->method('getAppValue') - ->with('core', 'installedat') - ->willReturn('installedat'); - $this->config - ->expects($this->at(6)) - ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn('lastupdatedat'); - $this->config - ->expects($this->at(7)) + ->expects($this->exactly(2)) ->method('setAppValue') - ->with('core', 'lastupdateResult', json_encode($expectedResult)); + ->withConsecutive( + ['core', 'lastupdatedat', $this->isType('integer')], + ['core', 'lastupdateResult', json_encode($expectedResult)] + ); $updateXml = '<?xml version="1.0"?> <owncloud> @@ -149,38 +149,37 @@ class VersionCheckTest extends \Test\TestCase { public function testCheckWithInvalidXml() { $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(true); $this->config - ->expects($this->at(1)) + ->expects($this->exactly(4)) ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn(0); + ->withConsecutive( + ['core', 'lastupdatedat'], + ['core', 'installedat'], + ['core', 'installedat'], + ['core', 'lastupdatedat'], + ) + ->willReturnOnConsecutiveCalls( + 0, + 'installedat', + 'installedat', + 'lastupdatedat' + ); $this->config - ->expects($this->at(2)) + ->expects($this->once()) ->method('getSystemValue') ->with('updater.server.url', 'https://updates.nextcloud.com/updater_server/') ->willReturnArgument(1); $this->config - ->expects($this->at(3)) - ->method('setAppValue') - ->with('core', 'lastupdatedat', $this->isType('integer')); - $this->config - ->expects($this->at(5)) - ->method('getAppValue') - ->with('core', 'installedat') - ->willReturn('installedat'); - $this->config - ->expects($this->at(6)) - ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn('lastupdatedat'); - $this->config - ->expects($this->at(7)) + ->expects($this->exactly(2)) ->method('setAppValue') - ->with('core', 'lastupdateResult', '[]'); + ->withConsecutive( + ['core', 'lastupdatedat', $this->isType('integer')], + ['core', 'lastupdateResult', '[]'] + ); $updateXml = 'Invalid XML Response!'; $this->updater @@ -204,34 +203,37 @@ class VersionCheckTest extends \Test\TestCase { ]; $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(true); $this->config - ->expects($this->at(1)) + ->expects($this->exactly(4)) ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn(0); + ->withConsecutive( + ['core', 'lastupdatedat'], + ['core', 'installedat'], + ['core', 'installedat'], + ['core', 'lastupdatedat'], + ) + ->willReturnOnConsecutiveCalls( + 0, + 'installedat', + 'installedat', + 'lastupdatedat' + ); $this->config - ->expects($this->at(2)) + ->expects($this->once()) ->method('getSystemValue') ->with('updater.server.url', 'https://updates.nextcloud.com/updater_server/') ->willReturnArgument(1); $this->config - ->expects($this->at(3)) + ->expects($this->exactly(2)) ->method('setAppValue') - ->with('core', 'lastupdatedat', $this->isType('integer')); - $this->config - ->expects($this->at(5)) - ->method('getAppValue') - ->with('core', 'installedat') - ->willReturn('installedat'); - $this->config - ->expects($this->at(6)) - ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn('lastupdatedat'); + ->withConsecutive( + ['core', 'lastupdatedat', $this->isType('integer')], + ['core', 'lastupdateResult', $this->isType('string')] + ); $updateXml = '<?xml version="1.0"?> <owncloud> @@ -254,38 +256,37 @@ class VersionCheckTest extends \Test\TestCase { $expectedResult = []; $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(true); $this->config - ->expects($this->at(1)) + ->expects($this->exactly(4)) ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn(0); + ->withConsecutive( + ['core', 'lastupdatedat'], + ['core', 'installedat'], + ['core', 'installedat'], + ['core', 'lastupdatedat'], + ) + ->willReturnOnConsecutiveCalls( + 0, + 'installedat', + 'installedat', + 'lastupdatedat' + ); $this->config - ->expects($this->at(2)) + ->expects($this->once()) ->method('getSystemValue') ->with('updater.server.url', 'https://updates.nextcloud.com/updater_server/') ->willReturnArgument(1); $this->config - ->expects($this->at(3)) - ->method('setAppValue') - ->with('core', 'lastupdatedat', $this->isType('integer')); - $this->config - ->expects($this->at(5)) - ->method('getAppValue') - ->with('core', 'installedat') - ->willReturn('installedat'); - $this->config - ->expects($this->at(6)) - ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn('lastupdatedat'); - $this->config - ->expects($this->at(7)) + ->expects($this->exactly(2)) ->method('setAppValue') - ->with('core', 'lastupdateResult', json_encode($expectedResult)); + ->withConsecutive( + ['core', 'lastupdatedat', $this->isType('integer')], + ['core', 'lastupdateResult', json_encode($expectedResult)] + ); $updateXml = ''; $this->updater @@ -309,34 +310,37 @@ class VersionCheckTest extends \Test\TestCase { ]; $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(true); $this->config - ->expects($this->at(1)) + ->expects($this->exactly(4)) ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn(0); + ->withConsecutive( + ['core', 'lastupdatedat'], + ['core', 'installedat'], + ['core', 'installedat'], + ['core', 'lastupdatedat'], + ) + ->willReturnOnConsecutiveCalls( + 0, + 'installedat', + 'installedat', + 'lastupdatedat' + ); $this->config - ->expects($this->at(2)) + ->expects($this->once()) ->method('getSystemValue') ->with('updater.server.url', 'https://updates.nextcloud.com/updater_server/') ->willReturnArgument(1); $this->config - ->expects($this->at(3)) + ->expects($this->exactly(2)) ->method('setAppValue') - ->with('core', 'lastupdatedat', $this->isType('integer')); - $this->config - ->expects($this->at(5)) - ->method('getAppValue') - ->with('core', 'installedat') - ->willReturn('installedat'); - $this->config - ->expects($this->at(6)) - ->method('getAppValue') - ->with('core', 'lastupdatedat') - ->willReturn('lastupdatedat'); + ->withConsecutive( + ['core', 'lastupdatedat', $this->isType('integer')], + ['core', 'lastupdateResult', $this->isType('string')] + ); // missing autoupdater element should still not fail $updateXml = '<?xml version="1.0"?> @@ -357,7 +361,7 @@ class VersionCheckTest extends \Test\TestCase { public function testNoInternet() { $this->config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getSystemValueBool') ->with('has_internet_connection', true) ->willReturn(false); diff --git a/tests/lib/User/ManagerTest.php b/tests/lib/User/ManagerTest.php index cef578e9555..ec8d931426c 100644 --- a/tests/lib/User/ManagerTest.php +++ b/tests/lib/User/ManagerTest.php @@ -693,24 +693,24 @@ class ManagerTest extends TestCase { ->disableOriginalConstructor() ->getMock(); $config - ->expects($this->at(0)) + ->expects($this->once()) ->method('getUsersForUserValueCaseInsensitive') ->with('settings', 'email', 'test@example.com') ->willReturn(['uid1', 'uid99', 'uid2']); $backend = $this->createMock(\Test\Util\User\Dummy::class); - $backend->expects($this->at(0)) - ->method('userExists') - ->with($this->equalTo('uid1')) - ->willReturn(true); - $backend->expects($this->at(1)) + $backend->expects($this->exactly(3)) ->method('userExists') - ->with($this->equalTo('uid99')) - ->willReturn(false); - $backend->expects($this->at(2)) - ->method('userExists') - ->with($this->equalTo('uid2')) - ->willReturn(true); + ->withConsecutive( + [$this->equalTo('uid1')], + [$this->equalTo('uid99')], + [$this->equalTo('uid2')] + ) + ->willReturnOnConsecutiveCalls( + true, + false, + true + ); $manager = new \OC\User\Manager($config, $this->oldDispatcher, $this->cacheFactory, $this->eventDispatcher); $manager->registerBackend($backend); |