userManager = $this->createMock(IUserManager::class); $this->groupManager = $this->createMock(IGroupManager::class); $this->shareManager = $this->createMock(IManager::class); $this->config = $this->createMock(IConfig::class); $this->l10n = $this->createMock(IL10N::class); $this->calDav = $this->createMock(CalDavBackend::class); $this->logger = $this->createMock(LoggerInterface::class); $this->command = new MoveCalendar( $this->userManager, $this->groupManager, $this->shareManager, $this->config, $this->l10n, $this->calDav, $this->logger ); } public function dataExecute() { return [ [false, true], [true, false] ]; } /** * @dataProvider dataExecute * * @param $userOriginExists * @param $userDestinationExists */ public function testWithBadUserOrigin($userOriginExists, $userDestinationExists): void { $this->expectException(\InvalidArgumentException::class); $this->userManager->expects($this->exactly($userOriginExists ? 2 : 1)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturnOnConsecutiveCalls( $userOriginExists, $userDestinationExists, ); $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => $this->command->getName(), 'sourceuid' => 'user', 'destinationuid' => 'user2', ]); } public function testMoveWithInexistantCalendar(): void { $this->expectException(\InvalidArgumentException::class); $this->expectExceptionMessage('User has no calendar named . You can run occ dav:list-calendars to list calendars URIs for this user.'); $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->once())->method('getCalendarByUri') ->with('principals/users/user', 'personal') ->willReturn(null); $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', ]); } public function testMoveWithExistingDestinationCalendar(): void { $this->expectException(\InvalidArgumentException::class); $this->expectExceptionMessage('User already has a calendar named .'); $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->exactly(2)) ->method('getCalendarByUri') ->withConsecutive( ['principals/users/user', 'personal'], ['principals/users/user2', 'personal'], ) ->willReturn([ 'id' => 1234, ]); $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', ]); } public function testMove(): void { $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->exactly(2)) ->method('getCalendarByUri') ->withConsecutive( ['principals/users/user', 'personal'], ['principals/users/user2', 'personal'], ) ->willReturnOnConsecutiveCalls( [ 'id' => 1234, ], null, ); $this->calDav->expects($this->once())->method('getShares') ->with(1234) ->willReturn([]); $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', ]); $this->assertStringContainsString("[OK] Calendar was moved from user to ", $commandTester->getDisplay()); } public function dataTestMoveWithDestinationNotPartOfGroup(): array { return [ [true], [false] ]; } /** * @dataProvider dataTestMoveWithDestinationNotPartOfGroup */ public function testMoveWithDestinationNotPartOfGroup(bool $shareWithGroupMembersOnly): void { $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->exactly(2)) ->method('getCalendarByUri') ->withConsecutive( ['principals/users/user', 'personal'], ['principals/users/user2', 'personal'], ) ->willReturnOnConsecutiveCalls( [ 'id' => 1234, 'uri' => 'personal', ], null, ); $this->shareManager->expects($this->once())->method('shareWithGroupMembersOnly') ->willReturn($shareWithGroupMembersOnly); $this->calDav->expects($this->once())->method('getShares') ->with(1234) ->willReturn([ ['href' => 'principal:principals/groups/nextclouders'] ]); if ($shareWithGroupMembersOnly === true) { $this->expectException(InvalidArgumentException::class); $this->expectExceptionMessage("User is not part of the group with whom the calendar was shared. You may use -f to move the calendar while deleting this share."); } $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', ]); } public function testMoveWithDestinationPartOfGroup(): void { $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->exactly(2)) ->method('getCalendarByUri') ->withConsecutive( ['principals/users/user', 'personal'], ['principals/users/user2', 'personal'], ) ->willReturnOnConsecutiveCalls( [ 'id' => 1234, 'uri' => 'personal', ], null, ); $this->shareManager->expects($this->once())->method('shareWithGroupMembersOnly') ->willReturn(true); $this->calDav->expects($this->once())->method('getShares') ->with(1234) ->willReturn([ ['href' => 'principal:principals/groups/nextclouders'] ]); $this->groupManager->expects($this->once())->method('isInGroup') ->with('user2', 'nextclouders') ->willReturn(true); $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', ]); $this->assertStringContainsString("[OK] Calendar was moved from user to ", $commandTester->getDisplay()); } public function testMoveWithDestinationNotPartOfGroupAndForce(): void { $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->exactly(2)) ->method('getCalendarByUri') ->withConsecutive( ['principals/users/user', 'personal'], ['principals/users/user2', 'personal'], ) ->willReturnOnConsecutiveCalls( [ 'id' => 1234, 'uri' => 'personal', '{DAV:}displayname' => 'Personal' ], null, ); $this->shareManager->expects($this->once())->method('shareWithGroupMembersOnly') ->willReturn(true); $this->calDav->expects($this->once())->method('getShares') ->with(1234) ->willReturn([ [ 'href' => 'principal:principals/groups/nextclouders', '{DAV:}displayname' => 'Personal' ] ]); $this->calDav->expects($this->once())->method('updateShares'); $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', '--force' => true ]); $this->assertStringContainsString("[OK] Calendar was moved from user to ", $commandTester->getDisplay()); } public function dataTestMoveWithCalendarAlreadySharedToDestination(): array { return [ [true], [false] ]; } /** * @dataProvider dataTestMoveWithCalendarAlreadySharedToDestination */ public function testMoveWithCalendarAlreadySharedToDestination(bool $force): void { $this->userManager->expects($this->exactly(2)) ->method('userExists') ->withConsecutive( ['user'], ['user2'], ) ->willReturn(true); $this->calDav->expects($this->exactly(2)) ->method('getCalendarByUri') ->withConsecutive( ['principals/users/user', 'personal'], ['principals/users/user2', 'personal'], ) ->willReturnOnConsecutiveCalls( [ 'id' => 1234, 'uri' => 'personal', '{DAV:}displayname' => 'Personal' ], null, ); $this->calDav->expects($this->once())->method('getShares') ->with(1234) ->willReturn([ [ 'href' => 'principal:principals/users/user2', '{DAV:}displayname' => 'Personal' ] ]); if ($force === false) { $this->expectException(InvalidArgumentException::class); $this->expectExceptionMessage("The calendar is already shared to user .You may use -f to move the calendar while deleting this share."); } else { $this->calDav->expects($this->once())->method('updateShares'); } $commandTester = new CommandTester($this->command); $commandTester->execute([ 'name' => 'personal', 'sourceuid' => 'user', 'destinationuid' => 'user2', '--force' => $force, ]); } }