mirror of
https://github.com/nextcloud/server.git
synced 2024-12-29 00:18:42 +00:00
9836e9b164
Signed-off-by: provokateurin <kate@provokateurin.de>
161 lines
5.5 KiB
PHP
161 lines
5.5 KiB
PHP
<?php
|
|
|
|
/**
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
namespace OCA\FederatedFileSharing\Tests;
|
|
|
|
use OCA\FederatedFileSharing\AddressHandler;
|
|
use OCA\FederatedFileSharing\Notifications;
|
|
use OCP\BackgroundJob\IJobList;
|
|
use OCP\EventDispatcher\IEventDispatcher;
|
|
use OCP\Federation\ICloudFederationFactory;
|
|
use OCP\Federation\ICloudFederationProviderManager;
|
|
use OCP\Http\Client\IClientService;
|
|
use OCP\OCS\IDiscoveryService;
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
class NotificationsTest extends \Test\TestCase {
|
|
/** @var AddressHandler|MockObject */
|
|
private $addressHandler;
|
|
|
|
/** @var IClientService|MockObject */
|
|
private $httpClientService;
|
|
|
|
/** @var IDiscoveryService|MockObject */
|
|
private $discoveryService;
|
|
|
|
/** @var IJobList|MockObject */
|
|
private $jobList;
|
|
|
|
/** @var ICloudFederationProviderManager|MockObject */
|
|
private $cloudFederationProviderManager;
|
|
|
|
/** @var ICloudFederationFactory|MockObject */
|
|
private $cloudFederationFactory;
|
|
|
|
/** @var IEventDispatcher|MockObject */
|
|
private $eventDispatcher;
|
|
|
|
/** @var LoggerInterface|MockObject */
|
|
private $logger;
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
|
|
$this->jobList = $this->getMockBuilder('OCP\BackgroundJob\IJobList')->getMock();
|
|
$this->discoveryService = $this->getMockBuilder(IDiscoveryService::class)->getMock();
|
|
$this->httpClientService = $this->getMockBuilder('OCP\Http\Client\IClientService')->getMock();
|
|
$this->addressHandler = $this->getMockBuilder('OCA\FederatedFileSharing\AddressHandler')
|
|
->disableOriginalConstructor()->getMock();
|
|
$this->logger = $this->createMock(LoggerInterface::class);
|
|
$this->cloudFederationProviderManager = $this->createMock(ICloudFederationProviderManager::class);
|
|
$this->cloudFederationFactory = $this->createMock(ICloudFederationFactory::class);
|
|
$this->eventDispatcher = $this->createMock(IEventDispatcher::class);
|
|
}
|
|
|
|
/**
|
|
* get instance of Notifications class
|
|
*
|
|
* @param array $mockedMethods methods which should be mocked
|
|
* @return Notifications | \PHPUnit\Framework\MockObject\MockObject
|
|
*/
|
|
private function getInstance(array $mockedMethods = []) {
|
|
if (empty($mockedMethods)) {
|
|
$instance = new Notifications(
|
|
$this->addressHandler,
|
|
$this->httpClientService,
|
|
$this->discoveryService,
|
|
$this->jobList,
|
|
$this->cloudFederationProviderManager,
|
|
$this->cloudFederationFactory,
|
|
$this->eventDispatcher,
|
|
$this->logger,
|
|
);
|
|
} else {
|
|
$instance = $this->getMockBuilder('OCA\FederatedFileSharing\Notifications')
|
|
->setConstructorArgs(
|
|
[
|
|
$this->addressHandler,
|
|
$this->httpClientService,
|
|
$this->discoveryService,
|
|
$this->jobList,
|
|
$this->cloudFederationProviderManager,
|
|
$this->cloudFederationFactory,
|
|
$this->eventDispatcher,
|
|
$this->logger,
|
|
]
|
|
)->setMethods($mockedMethods)->getMock();
|
|
}
|
|
|
|
return $instance;
|
|
}
|
|
|
|
|
|
/**
|
|
* @dataProvider dataTestSendUpdateToRemote
|
|
*
|
|
* @param int $try
|
|
* @param array $httpRequestResult
|
|
* @param bool $expected
|
|
*/
|
|
public function testSendUpdateToRemote($try, $httpRequestResult, $expected): void {
|
|
$remote = 'http://remote';
|
|
$id = 42;
|
|
$timestamp = 63576;
|
|
$token = 'token';
|
|
$action = 'unshare';
|
|
$instance = $this->getInstance(['tryHttpPostToShareEndpoint', 'getTimestamp']);
|
|
|
|
$instance->expects($this->any())->method('getTimestamp')->willReturn($timestamp);
|
|
|
|
$instance->expects($this->once())->method('tryHttpPostToShareEndpoint')
|
|
->with($remote, '/' . $id . '/unshare', ['token' => $token, 'data1Key' => 'data1Value', 'remoteId' => $id], $action)
|
|
->willReturn($httpRequestResult);
|
|
|
|
// only add background job on first try
|
|
if ($try === 0 && $expected === false) {
|
|
$this->jobList->expects($this->once())->method('add')
|
|
->with(
|
|
'OCA\FederatedFileSharing\BackgroundJob\RetryJob',
|
|
[
|
|
'remote' => $remote,
|
|
'remoteId' => $id,
|
|
'action' => 'unshare',
|
|
'data' => json_encode(['data1Key' => 'data1Value']),
|
|
'token' => $token,
|
|
'try' => $try,
|
|
'lastRun' => $timestamp
|
|
]
|
|
);
|
|
} else {
|
|
$this->jobList->expects($this->never())->method('add');
|
|
}
|
|
|
|
$this->assertSame($expected,
|
|
$instance->sendUpdateToRemote($remote, $id, $token, $action, ['data1Key' => 'data1Value'], $try)
|
|
);
|
|
}
|
|
|
|
|
|
public function dataTestSendUpdateToRemote() {
|
|
return [
|
|
// test if background job is added correctly
|
|
[0, ['success' => true, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 200]]])], true],
|
|
[1, ['success' => true, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 200]]])], true],
|
|
[0, ['success' => false, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 200]]])], false],
|
|
[1, ['success' => false, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 200]]])], false],
|
|
// test all combinations of 'statuscode' and 'success'
|
|
[0, ['success' => true, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 200]]])], true],
|
|
[0, ['success' => true, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 100]]])], true],
|
|
[0, ['success' => true, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 400]]])], false],
|
|
[0, ['success' => false, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 200]]])], false],
|
|
[0, ['success' => false, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 100]]])], false],
|
|
[0, ['success' => false, 'result' => json_encode(['ocs' => ['meta' => ['statuscode' => 400]]])], false],
|
|
];
|
|
}
|
|
}
|