123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- <?php
- namespace Test\Share;
- use OC\Share\Share;
- use OCP\IDBConnection;
- use OCP\IGroup;
- use OCP\IGroupManager;
- use OCP\IUser;
- use OCP\IUserManager;
- class ShareTest extends \Test\TestCase {
- protected $itemType;
- protected IUser $user1;
- protected IUser $user2;
- protected IUser $user3;
- protected IUser $user4;
- protected IUser $user5;
- protected IUser $user6;
- protected IUser $groupAndUser_user;
- protected IGroup $group1;
- protected IGroup $group2;
- protected IGroup $groupAndUser_group;
- protected string $resharing;
- protected string $dateInFuture;
- protected string $dateInPast;
- protected IGroupManager $groupManager;
- protected IUserManager $userManager;
- private IDBConnection $connection;
- protected function setUp(): void {
- parent::setUp();
- $this->groupManager = \OC::$server->getGroupManager();
- $this->userManager = \OC::$server->getUserManager();
- $this->userManager->clearBackends();
- $this->userManager->registerBackend(new \Test\Util\User\Dummy());
- $this->user1 = $this->userManager->createUser($this->getUniqueID('user1_'), 'pass');
- $this->user2 = $this->userManager->createUser($this->getUniqueID('user2_'), 'pass');
- $this->user3 = $this->userManager->createUser($this->getUniqueID('user3_'), 'pass');
- $this->user4 = $this->userManager->createUser($this->getUniqueID('user4_'), 'pass');
- $this->user5 = $this->userManager->createUser($this->getUniqueID('user5_'), 'pass');
- $this->user6 = $this->userManager->createUser($this->getUniqueID('user6_'), 'pass');
- $groupAndUserId = $this->getUniqueID('groupAndUser_');
- $this->groupAndUser_user = $this->userManager->createUser($groupAndUserId, 'pass');
- \OC_User::setUserId($this->user1->getUID());
- $this->groupManager->clearBackends();
- $this->groupManager->addBackend(new \Test\Util\Group\Dummy());
- $this->group1 = $this->groupManager->createGroup($this->getUniqueID('group1_'));
- $this->group2 = $this->groupManager->createGroup($this->getUniqueID('group2_'));
- $this->groupAndUser_group = $this->groupManager->createGroup($groupAndUserId);
- $this->connection = \OC::$server->get(IDBConnection::class);
- $this->group1->addUser($this->user1);
- $this->group1->addUser($this->user2);
- $this->group1->addUser($this->user3);
- $this->group2->addUser($this->user2);
- $this->group2->addUser($this->user4);
- $this->groupAndUser_group->addUser($this->user2);
- $this->groupAndUser_group->addUser($this->user3);
- Share::registerBackend('test', 'Test\Share\Backend');
- \OC_Hook::clear('OCP\\Share');
- \OC::registerShareHooks(\OC::$server->getSystemConfig());
- $this->resharing = \OC::$server->getConfig()->getAppValue('core', 'shareapi_allow_resharing', 'yes');
- \OC::$server->getConfig()->setAppValue('core', 'shareapi_allow_resharing', 'yes');
-
- $now = time();
- $dateFormat = 'Y-m-d H:i:s';
- $this->dateInPast = date($dateFormat, $now - 20 * 60);
- $this->dateInFuture = date($dateFormat, $now + 20 * 60);
- }
- protected function tearDown(): void {
- $query = $this->connection->getQueryBuilder();
- $query->delete('share')->andWhere($query->expr()->eq('item_type', $query->createNamedParameter('test')));
- $query->executeStatement();
- \OC::$server->getConfig()->setAppValue('core', 'shareapi_allow_resharing', $this->resharing);
- $this->user1->delete();
- $this->user2->delete();
- $this->user3->delete();
- $this->user4->delete();
- $this->user5->delete();
- $this->user6->delete();
- $this->groupAndUser_user->delete();
- $this->group1->delete();
- $this->group2->delete();
- $this->groupAndUser_group->delete();
- $this->logout();
- parent::tearDown();
- }
- public function verifyResult($result, $expected) {
- foreach ($result as $r) {
- if (in_array($r['item_target'], $expected)) {
- $key = array_search($r['item_target'], $expected);
- unset($expected[$key]);
- }
- }
- $this->assertEmpty($expected, 'did not found all expected values');
- }
-
- public function testRemoveProtocolFromUrl($url, $expectedResult): void {
- $share = new Share();
- $result = self::invokePrivate($share, 'removeProtocolFromUrl', [$url]);
- $this->assertSame($expectedResult, $result);
- }
- public function urls() {
- return [
- ['http://owncloud.org', 'owncloud.org'],
- ['https://owncloud.org', 'owncloud.org'],
- ['owncloud.org', 'owncloud.org'],
- ];
- }
-
- public function testGroupItems($ungrouped, $grouped): void {
- $result = DummyShareClass::groupItemsTest($ungrouped);
- $this->compareArrays($grouped, $result);
- }
- public function compareArrays($result, $expectedResult) {
- foreach ($expectedResult as $key => $value) {
- if (is_array($value)) {
- $this->compareArrays($result[$key], $value);
- } else {
- $this->assertSame($value, $result[$key]);
- }
- }
- }
- public function dataProviderTestGroupItems() {
- return [
-
- [
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_ALL, 'item_target' => 't1']],
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_ALL, 'item_target' => 't1']]],
-
- [
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ, 'item_target' => 't1'],
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't1'],
- ],
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't1',
- 'grouped' => [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ, 'item_target' => 't1'],
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't1'],
- ]
- ],
- ]
- ],
-
- [
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ, 'item_target' => 't1'],
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't2'],
- ],
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ, 'item_target' => 't1'],
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't2'],
- ]
- ],
-
- [
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ, 'item_target' => 't1'],
- ['item_source' => 2, 'permissions' => \OCP\Constants::PERMISSION_CREATE, 'item_target' => 't2'],
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't1'],
- ],
- [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't1',
- 'grouped' => [
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_READ, 'item_target' => 't1'],
- ['item_source' => 1, 'permissions' => \OCP\Constants::PERMISSION_UPDATE, 'item_target' => 't1'],
- ]
- ],
- ['item_source' => 2, 'permissions' => \OCP\Constants::PERMISSION_CREATE, 'item_target' => 't2'],
- ]
- ],
- ];
- }
- }
- class DummyShareClass extends Share {
- public static function groupItemsTest($items) {
- return parent::groupItems($items, 'test');
- }
- }
- class DummyHookListener {
- public static $shareType = null;
- public static function listen($params) {
- self::$shareType = $params['shareType'];
- }
- }
|