diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2015-11-23 13:28:49 +0100 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2015-11-23 13:28:49 +0100 |
commit | 240cc1c4ead5f89e3c296bfb8f0b34b7c3748316 (patch) | |
tree | 71db2e2cf332560502f0ab49412a4b02bee83a26 /tests | |
parent | f85282c90af5dd07bbbf2e80342ba969d2b8b688 (diff) | |
parent | 1360e22d7c924f01c9eab1025271a3e84bd5b173 (diff) | |
download | nextcloud-server-240cc1c4ead5f89e3c296bfb8f0b34b7c3748316.tar.gz nextcloud-server-240cc1c4ead5f89e3c296bfb8f0b34b7c3748316.zip |
Merge pull request #20543 from owncloud/share2.0_fix_hooks
Move hook and delete children logic to share manager
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/share20/defaultshareprovidertest.php | 326 | ||||
-rw-r--r-- | tests/lib/share20/managertest.php | 295 |
2 files changed, 410 insertions, 211 deletions
diff --git a/tests/lib/share20/defaultshareprovidertest.php b/tests/lib/share20/defaultshareprovidertest.php index f8b6f98be7c..4c0b5523947 100644 --- a/tests/lib/share20/defaultshareprovidertest.php +++ b/tests/lib/share20/defaultshareprovidertest.php @@ -368,47 +368,8 @@ class DefaultShareProviderTest extends \Test\TestCase { $cursor->closeCursor(); - $path = $this->getMock('OCP\Files\File'); - $path - ->expects($this->exactly(2)) - ->method('getId') - ->willReturn(42); - - $sharedWith = $this->getMock('OCP\IUser'); - $sharedWith - ->expects($this->once()) - ->method('getUID') - ->willReturn('sharedWith'); - $sharedBy = $this->getMock('OCP\IUser'); - $sharedBy - ->expects($this->once()) - ->method('getUID') - ->willReturn('sharedBy'); - $share = $this->getMock('OC\Share20\IShare'); - $share - ->method('getId') - ->willReturn($id); - $share - ->expects($this->once()) - ->method('getShareType') - ->willReturn(\OCP\Share::SHARE_TYPE_USER); - $share - ->expects($this->exactly(3)) - ->method('getPath') - ->willReturn($path); - $share - ->expects($this->once()) - ->method('getSharedWith') - ->willReturn($sharedWith); - $share - ->expects($this->once()) - ->method('getSharedBy') - ->willReturn($sharedBy); - $share - ->expects($this->once()) - ->method('getTarget') - ->willReturn('myTarget'); + $share->method('getId')->willReturn($id); $provider = $this->getMockBuilder('OC\Share20\DefaultShareProvider') ->setConstructorArgs([ @@ -418,38 +379,13 @@ class DefaultShareProviderTest extends \Test\TestCase { $this->userFolder, ] ) - ->setMethods(['deleteChildren', 'getShareById']) + ->setMethods(['getShareById']) ->getMock(); $provider ->expects($this->once()) - ->method('deleteChildren'); - $provider - ->expects($this->once()) ->method('getShareById') ->willReturn($share); - $hookListner = $this->getMockBuilder('Dummy')->setMethods(['listen'])->getMock(); - \OCP\Util::connectHook('OCP\Share', 'pre_unshare', $hookListner, 'listen'); - \OCP\Util::connectHook('OCP\Share', 'post_unshare', $hookListner, 'listen'); - - $hookListnerExpects = [ - 'id' => $id, - 'itemType' => 'file', - 'itemSource' => 42, - 'shareType' => \OCP\Share::SHARE_TYPE_USER, - 'shareWith' => 'sharedWith', - 'itemparent' => null, - 'uidOwner' => 'sharedBy', - 'fileSource' => 42, - 'fileTarget' => 'myTarget', - ]; - - $hookListner - ->expects($this->exactly(2)) - ->method('listen') - ->with($hookListnerExpects); - - $provider->delete($share); $qb = $this->dbConn->getQueryBuilder(); @@ -463,116 +399,6 @@ class DefaultShareProviderTest extends \Test\TestCase { $this->assertEmpty($result); } - public function testDeleteNestedShares() { - $qb = $this->dbConn->getQueryBuilder(); - $qb->insert('share') - ->values([ - 'share_type' => $qb->expr()->literal(\OCP\Share::SHARE_TYPE_USER), - 'share_with' => $qb->expr()->literal('sharedWith'), - 'uid_owner' => $qb->expr()->literal('sharedBy'), - 'item_type' => $qb->expr()->literal('file'), - 'file_source' => $qb->expr()->literal(42), - 'file_target' => $qb->expr()->literal('myTarget'), - 'permissions' => $qb->expr()->literal(13), - ]); - $this->assertEquals(1, $qb->execute()); - - // Get the id - $qb = $this->dbConn->getQueryBuilder(); - $cursor = $qb->select('id') - ->from('share') - ->setMaxResults(1) - ->orderBy('id', 'DESC') - ->execute(); - $id1 = $cursor->fetch(); - $id1 = $id1['id']; - $cursor->closeCursor(); - - - $qb = $this->dbConn->getQueryBuilder(); - $qb->insert('share') - ->values([ - 'share_type' => $qb->expr()->literal(\OCP\Share::SHARE_TYPE_USER), - 'share_with' => $qb->expr()->literal('sharedWith'), - 'uid_owner' => $qb->expr()->literal('sharedBy'), - 'item_type' => $qb->expr()->literal('file'), - 'file_source' => $qb->expr()->literal(42), - 'file_target' => $qb->expr()->literal('myTarget'), - 'permissions' => $qb->expr()->literal(13), - 'parent' => $qb->expr()->literal($id1), - ]); - $this->assertEquals(1, $qb->execute()); - - // Get the id - $qb = $this->dbConn->getQueryBuilder(); - $cursor = $qb->select('id') - ->from('share') - ->setMaxResults(1) - ->orderBy('id', 'DESC') - ->execute(); - $id2 = $cursor->fetch(); - $id2 = $id2['id']; - $cursor->closeCursor(); - - - $qb = $this->dbConn->getQueryBuilder(); - $qb->insert('share') - ->values([ - 'share_type' => $qb->expr()->literal(\OCP\Share::SHARE_TYPE_USER), - 'share_with' => $qb->expr()->literal('sharedWith'), - 'uid_owner' => $qb->expr()->literal('sharedBy'), - 'item_type' => $qb->expr()->literal('file'), - 'file_source' => $qb->expr()->literal(42), - 'file_target' => $qb->expr()->literal('myTarget'), - 'permissions' => $qb->expr()->literal(13), - 'parent' => $qb->expr()->literal($id2), - ]); - $this->assertEquals(1, $qb->execute()); - - $storage = $this->getMock('OC\Files\Storage\Storage'); - $storage - ->method('getOwner') - ->willReturn('shareOwner'); - $path = $this->getMock('OCP\Files\Node'); - $path - ->method('getStorage') - ->wilLReturn($storage); - $this->userFolder - ->method('getById') - ->with(42) - ->willReturn([$path]); - - $sharedWith = $this->getMock('OCP\IUser'); - $sharedWith - ->method('getUID') - ->willReturn('sharedWith'); - $sharedBy = $this->getMock('OCP\IUser'); - $sharedBy - ->method('getUID') - ->willReturn('sharedBy'); - $shareOwner = $this->getMock('OCP\IUser'); - $this->userManager - ->method('get') - ->will($this->returnValueMap([ - ['sharedWith', $sharedWith], - ['sharedBy', $sharedBy], - ['shareOwner', $shareOwner], - ])); - - $share = $this->provider->getShareById($id1); - $this->provider->delete($share); - - $qb = $this->dbConn->getQueryBuilder(); - $qb->select('*') - ->from('share'); - - $cursor = $qb->execute(); - $result = $cursor->fetchAll(); - $cursor->closeCursor(); - - $this->assertEmpty($result); - } - /** * @expectedException \OC\Share20\Exception\BackendError */ @@ -581,29 +407,6 @@ class DefaultShareProviderTest extends \Test\TestCase { $share ->method('getId') ->willReturn(42); - $share - ->expects($this->once()) - ->method('getShareType') - ->willReturn(\OCP\Share::SHARE_TYPE_LINK); - - $path = $this->getMock('OCP\Files\Folder'); - $path - ->expects($this->exactly(2)) - ->method('getId') - ->willReturn(100); - $share - ->expects($this->exactly(3)) - ->method('getPath') - ->willReturn($path); - - $sharedBy = $this->getMock('OCP\IUser'); - $sharedBy - ->expects($this->once()) - ->method('getUID'); - $share - ->expects($this->once()) - ->method('getSharedBy') - ->willReturn($sharedBy); $expr = $this->getMock('OCP\DB\QueryBuilder\IExpressionBuilder'); $qb = $this->getMock('OCP\DB\QueryBuilder\IQueryBuilder'); @@ -637,18 +440,133 @@ class DefaultShareProviderTest extends \Test\TestCase { $this->userFolder, ] ) - ->setMethods(['deleteChildren', 'getShareById']) + ->setMethods(['getShareById']) ->getMock(); $provider ->expects($this->once()) - ->method('deleteChildren') - ->with($share); - $provider - ->expects($this->once()) ->method('getShareById') ->with(42) ->willReturn($share); $provider->delete($share); } + + public function testGetChildren() { + $qb = $this->dbConn->getQueryBuilder(); + $qb->insert('share') + ->values([ + 'share_type' => $qb->expr()->literal(\OCP\Share::SHARE_TYPE_USER), + 'share_with' => $qb->expr()->literal('sharedWith'), + 'uid_owner' => $qb->expr()->literal('sharedBy'), + 'item_type' => $qb->expr()->literal('file'), + 'file_source' => $qb->expr()->literal(42), + 'file_target' => $qb->expr()->literal('myTarget'), + 'permissions' => $qb->expr()->literal(13), + ]); + $qb->execute(); + + // Get the id + $qb = $this->dbConn->getQueryBuilder(); + $cursor = $qb->select('id') + ->from('share') + ->setMaxResults(1) + ->orderBy('id', 'DESC') + ->execute(); + $id = $cursor->fetch(); + $id = $id['id']; + $cursor->closeCursor(); + + $qb = $this->dbConn->getQueryBuilder(); + $qb->insert('share') + ->values([ + 'share_type' => $qb->expr()->literal(\OCP\Share::SHARE_TYPE_USER), + 'share_with' => $qb->expr()->literal('user1'), + 'uid_owner' => $qb->expr()->literal('user2'), + 'item_type' => $qb->expr()->literal('file'), + 'file_source' => $qb->expr()->literal(1), + 'file_target' => $qb->expr()->literal('myTarget1'), + 'permissions' => $qb->expr()->literal(2), + 'parent' => $qb->expr()->literal($id), + ]); + $qb->execute(); + + $qb = $this->dbConn->getQueryBuilder(); + $qb->insert('share') + ->values([ + 'share_type' => $qb->expr()->literal(\OCP\Share::SHARE_TYPE_GROUP), + 'share_with' => $qb->expr()->literal('group1'), + 'uid_owner' => $qb->expr()->literal('user3'), + 'item_type' => $qb->expr()->literal('folder'), + 'file_source' => $qb->expr()->literal(3), + 'file_target' => $qb->expr()->literal('myTarget2'), + 'permissions' => $qb->expr()->literal(4), + 'parent' => $qb->expr()->literal($id), + ]); + $qb->execute(); + + + $storage = $this->getMock('OC\Files\Storage\Storage'); + $storage + ->method('getOwner') + ->willReturn('shareOwner'); + $path1 = $this->getMock('OCP\Files\File'); + $path1->expects($this->once())->method('getStorage')->willReturn($storage); + $path2 = $this->getMock('OCP\Files\Folder'); + $path2->expects($this->once())->method('getStorage')->willReturn($storage); + $this->userFolder + ->method('getById') + ->will($this->returnValueMap([ + [1, [$path1]], + [3, [$path2]], + ])); + + $shareOwner = $this->getMock('OCP\IUser'); + $user1 = $this->getMock('OCP\IUser'); + $user2 = $this->getMock('OCP\IUser'); + $user3 = $this->getMock('OCP\IUser'); + $this->userManager + ->method('get') + ->will($this->returnValueMap([ + ['shareOwner', $shareOwner], + ['user1', $user1], + ['user2', $user2], + ['user3', $user3], + ])); + + $group1 = $this->getMock('OCP\IGroup'); + $this->groupManager + ->method('get') + ->will($this->returnValueMap([ + ['group1', $group1] + ])); + + $share = $this->getMock('\OC\Share20\IShare'); + $share->method('getId')->willReturn($id); + + $children = $this->provider->getChildren($share); + + $this->assertCount(2, $children); + + //Child1 + $this->assertEquals(\OCP\Share::SHARE_TYPE_USER, $children[0]->getShareType()); + $this->assertEquals($user1, $children[0]->getSharedWith()); + $this->assertEquals($user2, $children[0]->getSharedBy()); + $this->assertEquals($shareOwner, $children[0]->getShareOwner()); + $this->assertEquals($path1, $children[0]->getPath()); + $this->assertEquals(2, $children[0]->getPermissions()); + $this->assertEquals(null, $children[0]->getToken()); + $this->assertEquals(null, $children[0]->getExpirationDate()); + $this->assertEquals('myTarget1', $children[0]->getTarget()); + + //Child2 + $this->assertEquals(\OCP\Share::SHARE_TYPE_GROUP, $children[1]->getShareType()); + $this->assertEquals($group1, $children[1]->getSharedWith()); + $this->assertEquals($user3, $children[1]->getSharedBy()); + $this->assertEquals($shareOwner, $children[1]->getShareOwner()); + $this->assertEquals($path2, $children[1]->getPath()); + $this->assertEquals(4, $children[1]->getPermissions()); + $this->assertEquals(null, $children[1]->getToken()); + $this->assertEquals(null, $children[1]->getExpirationDate()); + $this->assertEquals('myTarget2', $children[1]->getTarget()); + } } diff --git a/tests/lib/share20/managertest.php b/tests/lib/share20/managertest.php index fc6c30692f5..54be9033567 100644 --- a/tests/lib/share20/managertest.php +++ b/tests/lib/share20/managertest.php @@ -94,20 +94,301 @@ class ManagerTest extends \Test\TestCase { $this->manager->deleteShare($share); } - public function testDelete() { + public function dataTestDelete() { + $user = $this->getMock('\OCP\IUser'); + $user->method('getUID')->willReturn('sharedWithUser'); + + $group = $this->getMock('\OCP\IGroup'); + $group->method('getGID')->willReturn('sharedWithGroup'); + + return [ + [\OCP\Share::SHARE_TYPE_USER, $user, 'sharedWithUser'], + [\OCP\Share::SHARE_TYPE_GROUP, $group, 'sharedWithGroup'], + [\OCP\Share::SHARE_TYPE_LINK, '', ''], + [\OCP\Share::SHARE_TYPE_REMOTE, 'foo@bar.com', 'foo@bar.com'], + ]; + } + + /** + * @dataProvider dataTestDelete + */ + public function testDelete($shareType, $sharedWith, $sharedWith_string) { + $manager = $this->getMockBuilder('\OC\Share20\Manager') + ->setConstructorArgs([ + $this->user, + $this->userManager, + $this->groupManager, + $this->logger, + $this->appConfig, + $this->userFolder, + $this->defaultProvider + ]) + ->setMethods(['getShareById', 'deleteChildren']) + ->getMock(); + + $sharedBy = $this->getMock('\OCP\IUser'); + $sharedBy->method('getUID')->willReturn('sharedBy'); + + $path = $this->getMock('\OCP\Files\File'); + $path->method('getId')->willReturn(1); + $share = $this->getMock('\OC\Share20\IShare'); + $share->method('getId')->willReturn(42); + $share->method('getShareType')->willReturn($shareType); + $share->method('getSharedWith')->willReturn($sharedWith); + $share->method('getSharedBy')->willReturn($sharedBy); + $share->method('getPath')->willReturn($path); + $share->method('getTarget')->willReturn('myTarget'); + + $manager->expects($this->once())->method('getShareById')->with(42)->willReturn($share); + $manager->expects($this->once())->method('deleteChildren')->with($share); - $share - ->expects($this->once()) - ->method('getId') - ->with() - ->willReturn(42); $this->defaultProvider ->expects($this->once()) ->method('delete') ->with($share); - $this->manager->deleteShare($share); + $hookListner = $this->getMockBuilder('Dummy')->setMethods(['pre', 'post'])->getMock(); + \OCP\Util::connectHook('OCP\Share', 'pre_unshare', $hookListner, 'pre'); + \OCP\Util::connectHook('OCP\Share', 'post_unshare', $hookListner, 'post'); + + $hookListnerExpectsPre = [ + 'id' => 42, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => $shareType, + 'shareWith' => $sharedWith_string, + 'itemparent' => null, + 'uidOwner' => 'sharedBy', + 'fileSource' => 1, + 'fileTarget' => 'myTarget', + ]; + + $hookListnerExpectsPost = [ + 'id' => 42, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => $shareType, + 'shareWith' => $sharedWith_string, + 'itemparent' => null, + 'uidOwner' => 'sharedBy', + 'fileSource' => 1, + 'fileTarget' => 'myTarget', + 'deletedShares' => [ + [ + 'id' => 42, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => $shareType, + 'shareWith' => $sharedWith_string, + 'itemparent' => null, + 'uidOwner' => 'sharedBy', + 'fileSource' => 1, + 'fileTarget' => 'myTarget', + ], + ], + ]; + + + $hookListner + ->expects($this->exactly(1)) + ->method('pre') + ->with($hookListnerExpectsPre); + $hookListner + ->expects($this->exactly(1)) + ->method('post') + ->with($hookListnerExpectsPost); + + $manager->deleteShare($share); + } + + public function testDeleteNested() { + $manager = $this->getMockBuilder('\OC\Share20\Manager') + ->setConstructorArgs([ + $this->user, + $this->userManager, + $this->groupManager, + $this->logger, + $this->appConfig, + $this->userFolder, + $this->defaultProvider + ]) + ->setMethods(['getShareById']) + ->getMock(); + + $sharedBy1 = $this->getMock('\OCP\IUser'); + $sharedBy1->method('getUID')->willReturn('sharedBy1'); + $sharedBy2 = $this->getMock('\OCP\IUser'); + $sharedBy2->method('getUID')->willReturn('sharedBy2'); + $sharedBy3 = $this->getMock('\OCP\IUser'); + $sharedBy3->method('getUID')->willReturn('sharedBy3'); + + $sharedWith1 = $this->getMock('\OCP\IUser'); + $sharedWith1->method('getUID')->willReturn('sharedWith1'); + $sharedWith2 = $this->getMock('\OCP\IGroup'); + $sharedWith2->method('getGID')->willReturn('sharedWith2'); + + $path = $this->getMock('\OCP\Files\File'); + $path->method('getId')->willReturn(1); + + $share1 = $this->getMock('\OC\Share20\IShare'); + $share1->method('getId')->willReturn(42); + $share1->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_USER); + $share1->method('getSharedWith')->willReturn($sharedWith1); + $share1->method('getSharedBy')->willReturn($sharedBy1); + $share1->method('getPath')->willReturn($path); + $share1->method('getTarget')->willReturn('myTarget1'); + + $share2 = $this->getMock('\OC\Share20\IShare'); + $share2->method('getId')->willReturn(43); + $share2->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_GROUP); + $share2->method('getSharedWith')->willReturn($sharedWith2); + $share2->method('getSharedBy')->willReturn($sharedBy2); + $share2->method('getPath')->willReturn($path); + $share2->method('getTarget')->willReturn('myTarget2'); + $share2->method('getParent')->willReturn(42); + + $share3 = $this->getMock('\OC\Share20\IShare'); + $share3->method('getId')->willReturn(44); + $share3->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_LINK); + $share3->method('getSharedBy')->willReturn($sharedBy3); + $share3->method('getPath')->willReturn($path); + $share3->method('getTarget')->willReturn('myTarget3'); + $share3->method('getParent')->willReturn(43); + + $manager->expects($this->once())->method('getShareById')->with(42)->willReturn($share1); + + $this->defaultProvider + ->method('getChildren') + ->will($this->returnValueMap([ + [$share1, [$share2]], + [$share2, [$share3]], + [$share3, []], + ])); + + $this->defaultProvider + ->method('delete') + ->withConsecutive($share3, $share2, $share1); + + $hookListner = $this->getMockBuilder('Dummy')->setMethods(['pre', 'post'])->getMock(); + \OCP\Util::connectHook('OCP\Share', 'pre_unshare', $hookListner, 'pre'); + \OCP\Util::connectHook('OCP\Share', 'post_unshare', $hookListner, 'post'); + + $hookListnerExpectsPre = [ + 'id' => 42, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => \OCP\Share::SHARE_TYPE_USER, + 'shareWith' => 'sharedWith1', + 'itemparent' => null, + 'uidOwner' => 'sharedBy1', + 'fileSource' => 1, + 'fileTarget' => 'myTarget1', + ]; + + $hookListnerExpectsPost = [ + 'id' => 42, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => \OCP\Share::SHARE_TYPE_USER, + 'shareWith' => 'sharedWith1', + 'itemparent' => null, + 'uidOwner' => 'sharedBy1', + 'fileSource' => 1, + 'fileTarget' => 'myTarget1', + 'deletedShares' => [ + [ + 'id' => 44, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => \OCP\Share::SHARE_TYPE_LINK, + 'shareWith' => '', + 'itemparent' => 43, + 'uidOwner' => 'sharedBy3', + 'fileSource' => 1, + 'fileTarget' => 'myTarget3', + ], + [ + 'id' => 43, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => \OCP\Share::SHARE_TYPE_GROUP, + 'shareWith' => 'sharedWith2', + 'itemparent' => 42, + 'uidOwner' => 'sharedBy2', + 'fileSource' => 1, + 'fileTarget' => 'myTarget2', + ], + [ + 'id' => 42, + 'itemType' => 'file', + 'itemSource' => 1, + 'shareType' => \OCP\Share::SHARE_TYPE_USER, + 'shareWith' => 'sharedWith1', + 'itemparent' => null, + 'uidOwner' => 'sharedBy1', + 'fileSource' => 1, + 'fileTarget' => 'myTarget1', + ], + ], + ]; + + + $hookListner + ->expects($this->exactly(1)) + ->method('pre') + ->with($hookListnerExpectsPre); + $hookListner + ->expects($this->exactly(1)) + ->method('post') + ->with($hookListnerExpectsPost); + + $manager->deleteShare($share1); + } + + public function testDeleteChildren() { + $manager = $this->getMockBuilder('\OC\Share20\Manager') + ->setConstructorArgs([ + $this->user, + $this->userManager, + $this->groupManager, + $this->logger, + $this->appConfig, + $this->userFolder, + $this->defaultProvider + ]) + ->setMethods(['deleteShare']) + ->getMock(); + + $share = $this->getMock('\OC\Share20\IShare'); + + $child1 = $this->getMock('\OC\Share20\IShare'); + $child2 = $this->getMock('\OC\Share20\IShare'); + $child3 = $this->getMock('\OC\Share20\IShare'); + + $shares = [ + $child1, + $child2, + $child3, + ]; + + $this->defaultProvider + ->expects($this->exactly(4)) + ->method('getChildren') + ->will($this->returnCallback(function($_share) use ($share, $shares) { + if ($_share === $share) { + return $shares; + } + return []; + })); + + $this->defaultProvider + ->expects($this->exactly(3)) + ->method('delete') + ->withConsecutive($child1, $child2, $child3); + + $result = $this->invokePrivate($manager, 'deleteChildren', [$share]); + $this->assertSame($shares, $result); } /** |