Skip to content

Commit

Permalink
Add configuration flag to disable the background job for files_trashbin
Browse files Browse the repository at this point in the history
Signed-off-by: Daniel Kesselberg <[email protected]>
  • Loading branch information
kesselb committed Oct 7, 2021
1 parent 339c6ed commit 134f213
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 14 deletions.
20 changes: 16 additions & 4 deletions apps/files_trashbin/lib/BackgroundJob/ExpireTrash.php
Original file line number Diff line number Diff line change
Expand Up @@ -30,16 +30,20 @@
use OCA\Files_Trashbin\Expiration;
use OCA\Files_Trashbin\Helper;
use OCA\Files_Trashbin\Trashbin;
use OCP\IConfig;
use OCP\IUser;
use OCP\IUserManager;

class ExpireTrash extends \OC\BackgroundJob\TimedJob {

/** @var IConfig */
private $config;

/**
* @var Expiration
*/
private $expiration;

/**
* @var IUserManager
*/
Expand All @@ -49,14 +53,16 @@ class ExpireTrash extends \OC\BackgroundJob\TimedJob {
* @param IUserManager|null $userManager
* @param Expiration|null $expiration
*/
public function __construct(IUserManager $userManager = null,
public function __construct(IConfig $config = null,
IUserManager $userManager = null,
Expiration $expiration = null) {
// Run once per 30 minutes
$this->setInterval(60 * 30);

if (is_null($expiration) || is_null($userManager)) {
if ($config === null || is_null($expiration) || is_null($userManager)) {
$this->fixDIForJobs();
} else {
$this->config = $config;
$this->userManager = $userManager;
$this->expiration = $expiration;
}
Expand All @@ -65,6 +71,7 @@ public function __construct(IUserManager $userManager = null,
protected function fixDIForJobs() {
/** @var Application $application */
$application = \OC::$server->query(Application::class);
$this->config = $application->getContainer()->get(IConfig::class);
$this->userManager = \OC::$server->getUserManager();
$this->expiration = $application->getContainer()->query('Expiration');
}
Expand All @@ -74,6 +81,11 @@ protected function fixDIForJobs() {
* @throws \Exception
*/
protected function run($argument) {
$backgroundJob = $this->config->getAppValue('files_trashbin', 'background_job_expire_trash', 'yes');
if ($backgroundJob === 'no') {
return;
}

$maxAge = $this->expiration->getMaxAgeAsTimestamp();
if (!$maxAge) {
return;
Expand All @@ -87,7 +99,7 @@ protected function run($argument) {
$dirContent = Helper::getTrashFiles('/', $uid, 'mtime');
Trashbin::deleteExpiredFiles($dirContent, $uid);
});

\OC_Util::tearDownFS();
}

Expand Down
59 changes: 49 additions & 10 deletions apps/files_trashbin/tests/BackgroundJob/ExpireTrashTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,23 +22,62 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>
*
*/

namespace OCA\Files_Trashbin\Tests\BackgroundJob;

use OCA\Files_Trashbin\BackgroundJob\ExpireTrash;
use OCA\Files_Trashbin\Expiration;
use OCP\BackgroundJob\IJobList;
use OCP\IConfig;
use OCP\ILogger;
use OCP\IUserManager;
use PHPUnit\Framework\MockObject\MockObject;
use Test\TestCase;

class ExpireTrashTest extends TestCase {
/** @var IConfig|MockObject */
private $config;

/** @var IUserManager|MockObject */
private $userManager;

/** @var Expiration|MockObject */
private $expiration;

/** @var IJobList|MockObject */
private $jobList;

/** @var ILogger|MockObject */
private $logger;

class ExpireTrashTest extends \Test\TestCase {
public function testConstructAndRun() {
$backgroundJob = new ExpireTrash(
$this->createMock(IUserManager::class),
$this->getMockBuilder('OCA\Files_Trashbin\Expiration')->disableOriginalConstructor()->getMock()
);
protected function setUp(): void {
parent::setUp();

$this->config = $this->createMock(IConfig::class);
$this->userManager = $this->createMock(IUserManager::class);
$this->expiration = $this->createMock(Expiration::class);
$this->jobList = $this->createMock(IJobList::class);
$this->logger = $this->createMock(ILogger::class);

$this->jobList->expects($this->once())
->method('setLastRun');
$this->jobList->expects($this->once())
->method('setExecutionTime');
}

public function testConstructAndRun(): void {
$job = new ExpireTrash($this->config, $this->userManager, $this->expiration);
$job->execute($this->jobList, $this->logger);
}

$jobList = $this->createMock(IJobList::class);
public function testBackgroundJobDeactivated(): void {
$this->config->method('getAppValue')
->with('files_trashbin', 'background_job_expire_trash', 'yes')
->willReturn('no');
$this->expiration->expects($this->never())
->method('getMaxAgeAsTimestamp');

/** @var \OC\BackgroundJob\JobList $jobList */
$backgroundJob->execute($jobList);
$this->addToAssertionCount(1);
$job = new ExpireTrash($this->config, $this->userManager, $this->expiration);
$job->execute($this->jobList, $this->logger);
}
}

0 comments on commit 134f213

Please sign in to comment.