123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- <?php
- namespace OCA\FederatedFileSharing\Tests;
- use OC\Federation\CloudIdManager;
- use OCA\FederatedFileSharing\AddressHandler;
- use OCP\Contacts\IManager;
- use OCP\EventDispatcher\IEventDispatcher;
- use OCP\HintException;
- use OCP\ICacheFactory;
- use OCP\IL10N;
- use OCP\IURLGenerator;
- use OCP\IUserManager;
- class AddressHandlerTest extends \Test\TestCase {
-
- protected $contactsManager;
-
- private $addressHandler;
-
- private $urlGenerator;
-
- private $il10n;
-
- private $cloudIdManager;
- protected function setUp(): void {
- parent::setUp();
- $this->urlGenerator = $this->getMockBuilder(IURLGenerator::class)
- ->getMock();
- $this->il10n = $this->getMockBuilder(IL10N::class)
- ->getMock();
- $this->contactsManager = $this->createMock(IManager::class);
- $this->cloudIdManager = new CloudIdManager(
- $this->contactsManager,
- $this->urlGenerator,
- $this->createMock(IUserManager::class),
- $this->createMock(ICacheFactory::class),
- $this->createMock(IEventDispatcher::class)
- );
- $this->addressHandler = new AddressHandler($this->urlGenerator, $this->il10n, $this->cloudIdManager);
- }
- public function dataTestSplitUserRemote() {
- $userPrefix = ['user@name', 'username'];
- $protocols = ['', 'http://', 'https://'];
- $remotes = [
- 'localhost',
- 'local.host',
- 'dev.local.host',
- 'dev.local.host/path',
- 'dev.local.host/at@inpath',
- '127.0.0.1',
- '::1',
- '::192.0.2.128',
- '::192.0.2.128/at@inpath',
- ];
- $testCases = [];
- foreach ($userPrefix as $user) {
- foreach ($remotes as $remote) {
- foreach ($protocols as $protocol) {
- $baseUrl = $user . '@' . $protocol . $remote;
- if ($protocol === '') {
-
- $protocol = 'https://';
- }
- $testCases[] = [$baseUrl, $user, $protocol . $remote];
- $testCases[] = [$baseUrl . '/', $user, $protocol . $remote];
- $testCases[] = [$baseUrl . '/index.php', $user, $protocol . $remote];
- $testCases[] = [$baseUrl . '/index.php/s/token', $user, $protocol . $remote];
- }
- }
- }
- return $testCases;
- }
-
- public function testSplitUserRemote($remote, $expectedUser, $expectedUrl): void {
- $this->contactsManager->expects($this->any())
- ->method('search')
- ->willReturn([]);
- [$remoteUser, $remoteUrl] = $this->addressHandler->splitUserRemote($remote);
- $this->assertSame($expectedUser, $remoteUser);
- $this->assertSame($expectedUrl, $remoteUrl);
- }
- public function dataTestSplitUserRemoteError() {
- return [
-
- ['user@'],
-
- ['@server'],
- ['us/er@server'],
- ['us:er@server'],
-
- ['user'],
- [''],
- ['us/erserver'],
- ['us:erserver'],
- ];
- }
-
- public function testSplitUserRemoteError($id): void {
- $this->expectException(HintException::class);
- $this->addressHandler->splitUserRemote($id);
- }
-
- public function testCompareAddresses($user1, $server1, $user2, $server2, $expected): void {
- $this->assertSame($expected,
- $this->addressHandler->compareAddresses($user1, $server1, $user2, $server2)
- );
- }
- public function dataTestCompareAddresses() {
- return [
- ['user1', 'http://server1', 'user1', 'http://server1', true],
- ['user1', 'https://server1', 'user1', 'http://server1', true],
- ['user1', 'http://serVer1', 'user1', 'http://server1', true],
- ['user1', 'http://server1/', 'user1', 'http://server1', true],
- ['user1', 'server1', 'user1', 'http://server1', true],
- ['user1', 'http://server1', 'user1', 'http://server2', false],
- ['user1', 'https://server1', 'user1', 'http://server2', false],
- ['user1', 'http://serVer1', 'user1', 'http://serer2', false],
- ['user1', 'http://server1/', 'user1', 'http://server2', false],
- ['user1', 'server1', 'user1', 'http://server2', false],
- ['user1', 'http://server1', 'user2', 'http://server1', false],
- ['user1', 'https://server1', 'user2', 'http://server1', false],
- ['user1', 'http://serVer1', 'user2', 'http://server1', false],
- ['user1', 'http://server1/', 'user2', 'http://server1', false],
- ['user1', 'server1', 'user2', 'http://server1', false],
- ];
- }
-
- public function testRemoveProtocolFromUrl($url, $expectedResult): void {
- $result = $this->addressHandler->removeProtocolFromUrl($url);
- $this->assertSame($expectedResult, $result);
- }
- public function dataTestRemoveProtocolFromUrl() {
- return [
- ['http://owncloud.org', 'owncloud.org'],
- ['https://owncloud.org', 'owncloud.org'],
- ['owncloud.org', 'owncloud.org'],
- ];
- }
-
- public function testUrlContainProtocol($url, $expectedResult): void {
- $result = $this->addressHandler->urlContainProtocol($url);
- $this->assertSame($expectedResult, $result);
- }
- public function dataTestUrlContainProtocol() {
- return [
- ['http://nextcloud.com', true],
- ['https://nextcloud.com', true],
- ['nextcloud.com', false],
- ['httpserver.com', false],
- ];
- }
- }
|