|
|
|
|
@ -33,6 +33,7 @@ use OC\KnownUser\KnownUserService;
|
|
|
|
|
use OC\User\User;
|
|
|
|
|
use OCA\DAV\CalDAV\Proxy\Proxy;
|
|
|
|
|
use OCA\DAV\CalDAV\Proxy\ProxyMapper;
|
|
|
|
|
use OCA\DAV\Connector\Sabre\Principal;
|
|
|
|
|
use OCP\App\IAppManager;
|
|
|
|
|
use OCP\IConfig;
|
|
|
|
|
use OCP\IGroup;
|
|
|
|
|
@ -40,38 +41,42 @@ use OCP\IGroupManager;
|
|
|
|
|
use OCP\IUser;
|
|
|
|
|
use OCP\IUserManager;
|
|
|
|
|
use OCP\IUserSession;
|
|
|
|
|
use OCP\L10N\IFactory;
|
|
|
|
|
use OCP\Share\IManager;
|
|
|
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
|
|
|
|
use Sabre\DAV\Exception;
|
|
|
|
|
use Sabre\DAV\PropPatch;
|
|
|
|
|
use Test\TestCase;
|
|
|
|
|
|
|
|
|
|
class PrincipalTest extends TestCase {
|
|
|
|
|
|
|
|
|
|
/** @var IUserManager | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var IUserManager | MockObject */
|
|
|
|
|
private $userManager;
|
|
|
|
|
|
|
|
|
|
/** @var \OCA\DAV\Connector\Sabre\Principal */
|
|
|
|
|
/** @var Principal */
|
|
|
|
|
private $connector;
|
|
|
|
|
|
|
|
|
|
/** @var IGroupManager | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var IGroupManager | MockObject */
|
|
|
|
|
private $groupManager;
|
|
|
|
|
|
|
|
|
|
/** @var IManager | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var IManager | MockObject */
|
|
|
|
|
private $shareManager;
|
|
|
|
|
|
|
|
|
|
/** @var IUserSession | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var IUserSession | MockObject */
|
|
|
|
|
private $userSession;
|
|
|
|
|
|
|
|
|
|
/** @var IAppManager | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var IAppManager | MockObject */
|
|
|
|
|
private $appManager;
|
|
|
|
|
|
|
|
|
|
/** @var ProxyMapper | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var ProxyMapper | MockObject */
|
|
|
|
|
private $proxyMapper;
|
|
|
|
|
|
|
|
|
|
/** @var KnownUserService|MockObject */
|
|
|
|
|
private $knownUserService;
|
|
|
|
|
/** @var IConfig | \PHPUnit\Framework\MockObject\MockObject */
|
|
|
|
|
/** @var IConfig | MockObject */
|
|
|
|
|
private $config;
|
|
|
|
|
/** @var IFactory|MockObject */
|
|
|
|
|
private $languageFactory;
|
|
|
|
|
|
|
|
|
|
protected function setUp(): void {
|
|
|
|
|
$this->userManager = $this->createMock(IUserManager::class);
|
|
|
|
|
@ -82,8 +87,9 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->proxyMapper = $this->createMock(ProxyMapper::class);
|
|
|
|
|
$this->knownUserService = $this->createMock(KnownUserService::class);
|
|
|
|
|
$this->config = $this->createMock(IConfig::class);
|
|
|
|
|
$this->languageFactory = $this->createMock(IFactory::class);
|
|
|
|
|
|
|
|
|
|
$this->connector = new \OCA\DAV\Connector\Sabre\Principal(
|
|
|
|
|
$this->connector = new Principal(
|
|
|
|
|
$this->userManager,
|
|
|
|
|
$this->groupManager,
|
|
|
|
|
$this->shareManager,
|
|
|
|
|
@ -91,37 +97,38 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->appManager,
|
|
|
|
|
$this->proxyMapper,
|
|
|
|
|
$this->knownUserService,
|
|
|
|
|
$this->config
|
|
|
|
|
$this->config,
|
|
|
|
|
$this->languageFactory
|
|
|
|
|
);
|
|
|
|
|
parent::setUp();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetPrincipalsByPrefixWithoutPrefix() {
|
|
|
|
|
public function testGetPrincipalsByPrefixWithoutPrefix(): void {
|
|
|
|
|
$response = $this->connector->getPrincipalsByPrefix('');
|
|
|
|
|
$this->assertSame([], $response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetPrincipalsByPrefixWithUsers() {
|
|
|
|
|
public function testGetPrincipalsByPrefixWithUsers(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('foo');
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getDisplayName')
|
|
|
|
|
->willReturn('Dr. Foo-Bar');
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getEMailAddress')
|
|
|
|
|
->willReturn('');
|
|
|
|
|
$barUser = $this->createMock(User::class);
|
|
|
|
|
$barUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('bar');
|
|
|
|
|
$barUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getEMailAddress')
|
|
|
|
|
->willReturn('bar@nextcloud.com');
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -130,16 +137,24 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
->with('')
|
|
|
|
|
->willReturn([$fooUser, $barUser]);
|
|
|
|
|
|
|
|
|
|
$this->languageFactory
|
|
|
|
|
->expects($this->exactly(2))
|
|
|
|
|
->method('getUserLanguage')
|
|
|
|
|
->withConsecutive([$fooUser], [$barUser])
|
|
|
|
|
->willReturnOnConsecutiveCalls('de', 'en');
|
|
|
|
|
|
|
|
|
|
$expectedResponse = [
|
|
|
|
|
0 => [
|
|
|
|
|
'uri' => 'principals/users/foo',
|
|
|
|
|
'{DAV:}displayname' => 'Dr. Foo-Bar',
|
|
|
|
|
'{urn:ietf:params:xml:ns:caldav}calendar-user-type' => 'INDIVIDUAL',
|
|
|
|
|
'{http://nextcloud.com/ns}language' => 'de',
|
|
|
|
|
],
|
|
|
|
|
1 => [
|
|
|
|
|
'uri' => 'principals/users/bar',
|
|
|
|
|
'{DAV:}displayname' => 'bar',
|
|
|
|
|
'{urn:ietf:params:xml:ns:caldav}calendar-user-type' => 'INDIVIDUAL',
|
|
|
|
|
'{http://nextcloud.com/ns}language' => 'en',
|
|
|
|
|
'{http://sabredav.org/ns}email-address' => 'bar@nextcloud.com',
|
|
|
|
|
]
|
|
|
|
|
];
|
|
|
|
|
@ -147,7 +162,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->assertSame($expectedResponse, $response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetPrincipalsByPrefixEmpty() {
|
|
|
|
|
public function testGetPrincipalsByPrefixEmpty(): void {
|
|
|
|
|
$this->userManager
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('search')
|
|
|
|
|
@ -158,10 +173,10 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->assertSame([], $response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetPrincipalsByPathWithoutMail() {
|
|
|
|
|
public function testGetPrincipalsByPathWithoutMail(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('foo');
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -170,23 +185,30 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
->with('foo')
|
|
|
|
|
->willReturn($fooUser);
|
|
|
|
|
|
|
|
|
|
$this->languageFactory
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUserLanguage')
|
|
|
|
|
->with($fooUser)
|
|
|
|
|
->willReturn('de');
|
|
|
|
|
|
|
|
|
|
$expectedResponse = [
|
|
|
|
|
'uri' => 'principals/users/foo',
|
|
|
|
|
'{DAV:}displayname' => 'foo',
|
|
|
|
|
'{urn:ietf:params:xml:ns:caldav}calendar-user-type' => 'INDIVIDUAL',
|
|
|
|
|
'{http://nextcloud.com/ns}language' => 'de'
|
|
|
|
|
];
|
|
|
|
|
$response = $this->connector->getPrincipalByPath('principals/users/foo');
|
|
|
|
|
$this->assertSame($expectedResponse, $response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetPrincipalsByPathWithMail() {
|
|
|
|
|
public function testGetPrincipalsByPathWithMail(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getEMailAddress')
|
|
|
|
|
->willReturn('foo@nextcloud.com');
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('foo');
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -195,17 +217,24 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
->with('foo')
|
|
|
|
|
->willReturn($fooUser);
|
|
|
|
|
|
|
|
|
|
$this->languageFactory
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUserLanguage')
|
|
|
|
|
->with($fooUser)
|
|
|
|
|
->willReturn('de');
|
|
|
|
|
|
|
|
|
|
$expectedResponse = [
|
|
|
|
|
'uri' => 'principals/users/foo',
|
|
|
|
|
'{DAV:}displayname' => 'foo',
|
|
|
|
|
'{urn:ietf:params:xml:ns:caldav}calendar-user-type' => 'INDIVIDUAL',
|
|
|
|
|
'{http://nextcloud.com/ns}language' => 'de',
|
|
|
|
|
'{http://sabredav.org/ns}email-address' => 'foo@nextcloud.com',
|
|
|
|
|
];
|
|
|
|
|
$response = $this->connector->getPrincipalByPath('principals/users/foo');
|
|
|
|
|
$this->assertSame($expectedResponse, $response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetPrincipalsByPathEmpty() {
|
|
|
|
|
public function testGetPrincipalsByPathEmpty(): void {
|
|
|
|
|
$this->userManager
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('get')
|
|
|
|
|
@ -213,17 +242,17 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
->willReturn(null);
|
|
|
|
|
|
|
|
|
|
$response = $this->connector->getPrincipalByPath('principals/users/foo');
|
|
|
|
|
$this->assertSame(null, $response);
|
|
|
|
|
$this->assertNull($response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetGroupMemberSet() {
|
|
|
|
|
public function testGetGroupMemberSet(): void {
|
|
|
|
|
$response = $this->connector->getGroupMemberSet('principals/users/foo');
|
|
|
|
|
$this->assertSame([], $response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function testGetGroupMemberSetEmpty() {
|
|
|
|
|
$this->expectException(\Sabre\DAV\Exception::class);
|
|
|
|
|
public function testGetGroupMemberSetEmpty(): void {
|
|
|
|
|
$this->expectException(Exception::class);
|
|
|
|
|
$this->expectExceptionMessage('Principal not found');
|
|
|
|
|
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -235,10 +264,10 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->connector->getGroupMemberSet('principals/users/foo/calendar-proxy-read');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetGroupMemberSetProxyRead() {
|
|
|
|
|
public function testGetGroupMemberSetProxyRead(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('foo');
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -267,10 +296,10 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->assertEquals(['proxyId1'], $this->connector->getGroupMemberSet('principals/users/foo/calendar-proxy-read'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetGroupMemberSetProxyWrite() {
|
|
|
|
|
public function testGetGroupMemberSetProxyWrite(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('foo');
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -299,7 +328,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->assertEquals(['proxyId2', 'proxyId3'], $this->connector->getGroupMemberSet('principals/users/foo/calendar-proxy-write'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testGetGroupMembership() {
|
|
|
|
|
public function testGetGroupMembership(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$group1 = $this->createMock(IGroup::class);
|
|
|
|
|
$group1->expects($this->once())
|
|
|
|
|
@ -347,8 +376,8 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function testGetGroupMembershipEmpty() {
|
|
|
|
|
$this->expectException(\Sabre\DAV\Exception::class);
|
|
|
|
|
public function testGetGroupMembershipEmpty(): void {
|
|
|
|
|
$this->expectException(Exception::class);
|
|
|
|
|
$this->expectExceptionMessage('Principal not found');
|
|
|
|
|
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -361,22 +390,22 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function testSetGroupMembership() {
|
|
|
|
|
$this->expectException(\Sabre\DAV\Exception::class);
|
|
|
|
|
public function testSetGroupMembership(): void {
|
|
|
|
|
$this->expectException(Exception::class);
|
|
|
|
|
$this->expectExceptionMessage('Setting members of the group is not supported yet');
|
|
|
|
|
|
|
|
|
|
$this->connector->setGroupMemberSet('principals/users/foo', ['foo']);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSetGroupMembershipProxy() {
|
|
|
|
|
public function testSetGroupMembershipProxy(): void {
|
|
|
|
|
$fooUser = $this->createMock(User::class);
|
|
|
|
|
$fooUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('foo');
|
|
|
|
|
$barUser = $this->createMock(User::class);
|
|
|
|
|
$barUser
|
|
|
|
|
->expects($this->exactly(1))
|
|
|
|
|
->expects($this->once())
|
|
|
|
|
->method('getUID')
|
|
|
|
|
->willReturn('bar');
|
|
|
|
|
$this->userManager
|
|
|
|
|
@ -415,15 +444,15 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->connector->setGroupMemberSet('principals/users/foo/calendar-proxy-write', ['principals/users/bar']);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testUpdatePrincipal() {
|
|
|
|
|
public function testUpdatePrincipal(): void {
|
|
|
|
|
$this->assertSame(0, $this->connector->updatePrincipal('foo', new PropPatch([])));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalsWithEmptySearchProperties() {
|
|
|
|
|
public function testSearchPrincipalsWithEmptySearchProperties(): void {
|
|
|
|
|
$this->assertSame([], $this->connector->searchPrincipals('principals/users', []));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalsWithWrongPrefixPath() {
|
|
|
|
|
public function testSearchPrincipalsWithWrongPrefixPath(): void {
|
|
|
|
|
$this->assertSame([], $this->connector->searchPrincipals('principals/groups',
|
|
|
|
|
['{http://sabredav.org/ns}email-address' => 'foo']));
|
|
|
|
|
}
|
|
|
|
|
@ -431,7 +460,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
/**
|
|
|
|
|
* @dataProvider searchPrincipalsDataProvider
|
|
|
|
|
*/
|
|
|
|
|
public function testSearchPrincipals($sharingEnabled, $groupsOnly, $test, $result) {
|
|
|
|
|
public function testSearchPrincipals($sharingEnabled, $groupsOnly, $test, $result): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn($sharingEnabled);
|
|
|
|
|
@ -515,7 +544,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
'{DAV:}displayname' => 'User 12'], $test));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function searchPrincipalsDataProvider() {
|
|
|
|
|
public function searchPrincipalsDataProvider(): array {
|
|
|
|
|
return [
|
|
|
|
|
[true, false, 'allof', ['principals/users/user3']],
|
|
|
|
|
[true, false, 'anyof', ['principals/users/user2', 'principals/users/user3', 'principals/users/user4']],
|
|
|
|
|
@ -526,7 +555,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalByCalendarUserAddressSet() {
|
|
|
|
|
public function testSearchPrincipalByCalendarUserAddressSet(): void {
|
|
|
|
|
$this->shareManager->expects($this->exactly(2))
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -556,7 +585,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{urn:ietf:params:xml:ns:caldav}calendar-user-address-set' => 'user@example.com']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledDisplayname() {
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledDisplayname(): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -595,7 +624,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{DAV:}displayname' => 'User 2']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledDisplaynameOnFullMatch() {
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledDisplaynameOnFullMatch(): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -616,7 +645,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{DAV:}displayname' => 'User 2']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledEmail() {
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledEmail(): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -655,7 +684,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{http://sabredav.org/ns}email-address' => 'user2@foo.bar']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledEmailOnFullMatch() {
|
|
|
|
|
public function testSearchPrincipalWithEnumerationDisabledEmailOnFullMatch(): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -677,7 +706,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{http://sabredav.org/ns}email-address' => 'user2@foo.bar']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalWithEnumerationLimitedDisplayname() {
|
|
|
|
|
public function testSearchPrincipalWithEnumerationLimitedDisplayname(): void {
|
|
|
|
|
$this->shareManager->expects($this->at(0))
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -738,7 +767,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{DAV:}displayname' => 'User']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testSearchPrincipalWithEnumerationLimitedMail() {
|
|
|
|
|
public function testSearchPrincipalWithEnumerationLimitedMail(): void {
|
|
|
|
|
$this->shareManager->expects($this->at(0))
|
|
|
|
|
->method('shareAPIEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -799,7 +828,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
['{http://sabredav.org/ns}email-address' => 'user']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testFindByUriSharingApiDisabled() {
|
|
|
|
|
public function testFindByUriSharingApiDisabled(): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareApiEnabled')
|
|
|
|
|
->willReturn(false);
|
|
|
|
|
@ -810,7 +839,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
/**
|
|
|
|
|
* @dataProvider findByUriWithGroupRestrictionDataProvider
|
|
|
|
|
*/
|
|
|
|
|
public function testFindByUriWithGroupRestriction($uri, $email, $expects) {
|
|
|
|
|
public function testFindByUriWithGroupRestriction($uri, $email, $expects): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareApiEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -854,7 +883,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->assertEquals($expects, $this->connector->findByUri($uri, 'principals/users'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function findByUriWithGroupRestrictionDataProvider() {
|
|
|
|
|
public function findByUriWithGroupRestrictionDataProvider(): array {
|
|
|
|
|
return [
|
|
|
|
|
['mailto:user2@foo.bar', 'user2@foo.bar', 'principals/users/user2'],
|
|
|
|
|
['mailto:user3@foo.bar', 'user3@foo.bar', null],
|
|
|
|
|
@ -864,7 +893,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
/**
|
|
|
|
|
* @dataProvider findByUriWithoutGroupRestrictionDataProvider
|
|
|
|
|
*/
|
|
|
|
|
public function testFindByUriWithoutGroupRestriction($uri, $email, $expects) {
|
|
|
|
|
public function testFindByUriWithoutGroupRestriction($uri, $email, $expects): void {
|
|
|
|
|
$this->shareManager->expects($this->once())
|
|
|
|
|
->method('shareApiEnabled')
|
|
|
|
|
->willReturn(true);
|
|
|
|
|
@ -886,7 +915,7 @@ class PrincipalTest extends TestCase {
|
|
|
|
|
$this->assertEquals($expects, $this->connector->findByUri($uri, 'principals/users'));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function findByUriWithoutGroupRestrictionDataProvider() {
|
|
|
|
|
public function findByUriWithoutGroupRestrictionDataProvider(): array {
|
|
|
|
|
return [
|
|
|
|
|
['mailto:user2@foo.bar', 'user2@foo.bar', 'principals/users/user2'],
|
|
|
|
|
['mailto:user3@foo.bar', 'user3@foo.bar', 'principals/users/user3'],
|
|
|
|
|
|