aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files_trashbin/tests
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2023-03-27 17:55:24 +0200
committerRobin Appelman <robin@icewind.nl>2023-04-03 18:59:02 +0200
commit9a731ad617816110d98fceb5c46360a372e2c750 (patch)
tree6d36ae5f6812b7609423c9193b220a8f0ff1178b /apps/files_trashbin/tests
parent5024f295dcfdf850d2d95f419bcf122bf08be5c8 (diff)
downloadnextcloud-server-9a731ad617816110d98fceb5c46360a372e2c750.tar.gz
nextcloud-server-9a731ad617816110d98fceb5c46360a372e2c750.zip
add a bit more verbose option for trashbin cleanup
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps/files_trashbin/tests')
-rw-r--r--apps/files_trashbin/tests/Command/CleanUpTest.php52
1 files changed, 32 insertions, 20 deletions
diff --git a/apps/files_trashbin/tests/Command/CleanUpTest.php b/apps/files_trashbin/tests/Command/CleanUpTest.php
index 949d0529fd6..2f582ed428b 100644
--- a/apps/files_trashbin/tests/Command/CleanUpTest.php
+++ b/apps/files_trashbin/tests/Command/CleanUpTest.php
@@ -32,6 +32,7 @@ use OCP\Files\IRootFolder;
use OCP\IDBConnection;
use Symfony\Component\Console\Exception\InvalidOptionException;
use Symfony\Component\Console\Input\InputInterface;
+use Symfony\Component\Console\Output\NullOutput;
use Symfony\Component\Console\Output\OutputInterface;
use Test\TestCase;
@@ -101,27 +102,27 @@ class CleanUpTest extends TestCase {
* @dataProvider dataTestRemoveDeletedFiles
* @param boolean $nodeExists
*/
- public function testRemoveDeletedFiles($nodeExists) {
+ public function testRemoveDeletedFiles(bool $nodeExists) {
$this->initTable();
- $this->rootFolder->expects($this->once())
+ $this->rootFolder
->method('nodeExists')
->with('/' . $this->user0 . '/files_trashbin')
- ->willReturn($nodeExists);
+ ->willReturnOnConsecutiveCalls($nodeExists, false);
if ($nodeExists) {
- $this->rootFolder->expects($this->once())
+ $this->rootFolder
->method('get')
->with('/' . $this->user0 . '/files_trashbin')
->willReturn($this->rootFolder);
- $this->rootFolder->expects($this->once())
+ $this->rootFolder
->method('delete');
} else {
$this->rootFolder->expects($this->never())->method('get');
$this->rootFolder->expects($this->never())->method('delete');
}
- $this->invokePrivate($this->cleanup, 'removeDeletedFiles', [$this->user0]);
+ $this->invokePrivate($this->cleanup, 'removeDeletedFiles', [$this->user0, new NullOutput(), false]);
if ($nodeExists) {
- // if the delete operation was execute only files from user1
+ // if the delete operation was executed only files from user1
// should be left.
$query = $this->dbConnection->getQueryBuilder();
$query->select('user')
@@ -136,7 +137,7 @@ class CleanUpTest extends TestCase {
$this->assertSame('user1', $r['user']);
}
} else {
- // if no delete operation was execute we should still have all 10
+ // if no delete operation was executed we should still have all 10
// database entries
$getAllQuery = $this->dbConnection->getQueryBuilder();
$result = $getAllQuery->select('id')
@@ -171,9 +172,14 @@ class CleanUpTest extends TestCase {
->method('userExists')->willReturn(true);
$inputInterface = $this->getMockBuilder('\Symfony\Component\Console\Input\InputInterface')
->disableOriginalConstructor()->getMock();
- $inputInterface->expects($this->once())->method('getArgument')
+ $inputInterface->method('getArgument')
->with('user_id')
->willReturn($userIds);
+ $inputInterface->method('getOption')
+ ->willReturnMap([
+ ['all-users', false],
+ ['verbose', false],
+ ]);
$outputInterface = $this->getMockBuilder('\Symfony\Component\Console\Output\OutputInterface')
->disableOriginalConstructor()->getMock();
$this->invokePrivate($instance, 'execute', [$inputInterface, $outputInterface]);
@@ -190,7 +196,7 @@ class CleanUpTest extends TestCase {
->setConstructorArgs([$this->rootFolder, $this->userManager, $this->dbConnection])
->getMock();
$backend = $this->createMock(\OCP\UserInterface::class);
- $backend->expects($this->once())->method('getUsers')
+ $backend->method('getUsers')
->with('', 500, 0)
->willReturn($backendUsers);
$instance->expects($this->exactly(count($backendUsers)))
@@ -199,14 +205,16 @@ class CleanUpTest extends TestCase {
$this->assertTrue(in_array($user, $backendUsers));
});
$inputInterface = $this->createMock(InputInterface::class);
- $inputInterface->expects($this->once())->method('getArgument')
+ $inputInterface->method('getArgument')
->with('user_id')
->willReturn($userIds);
$inputInterface->method('getOption')
- ->with('all-users')
- ->willReturn(true);
+ ->willReturnMap([
+ ['all-users', true],
+ ['verbose', false],
+ ]);
$outputInterface = $this->createMock(OutputInterface::class);
- $this->userManager->expects($this->once())
+ $this->userManager
->method('getBackends')
->willReturn([$backend]);
$this->invokePrivate($instance, 'execute', [$inputInterface, $outputInterface]);
@@ -214,12 +222,14 @@ class CleanUpTest extends TestCase {
public function testExecuteNoUsersAndNoAllUsers() {
$inputInterface = $this->createMock(InputInterface::class);
- $inputInterface->expects($this->once())->method('getArgument')
+ $inputInterface->method('getArgument')
->with('user_id')
->willReturn([]);
$inputInterface->method('getOption')
- ->with('all-users')
- ->willReturn(false);
+ ->willReturnMap([
+ ['all-users', false],
+ ['verbose', false],
+ ]);
$outputInterface = $this->createMock(OutputInterface::class);
$this->expectException(InvalidOptionException::class);
@@ -230,12 +240,14 @@ class CleanUpTest extends TestCase {
public function testExecuteUsersAndAllUsers() {
$inputInterface = $this->createMock(InputInterface::class);
- $inputInterface->expects($this->once())->method('getArgument')
+ $inputInterface->method('getArgument')
->with('user_id')
->willReturn(['user1', 'user2']);
$inputInterface->method('getOption')
- ->with('all-users')
- ->willReturn(true);
+ ->willReturnMap([
+ ['all-users', true],
+ ['verbose', false],
+ ]);
$outputInterface = $this->createMock(OutputInterface::class);
$this->expectException(InvalidOptionException::class);