summaryrefslogtreecommitdiffstats
path: root/tests/lib/share/hooktests.php
blob: f980baf35742cc7f61b716579c10a42df17b66b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?php
/**
 * @author Björn Schießle <schiessle@owncloud.com>
 *
 * @copyright Copyright (c) 2015, ownCloud, Inc.
 * @license AGPL-3.0
 *
 * This code is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License, version 3,
 * as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License, version 3,
 * along with this program.  If not, see <http://www.gnu.org/licenses/>
 *
 */


namespace OC\Tests\Share;


use Test\TestCase;

class HookTests extends TestCase {

	protected function setUp() {
		parent::setUp();
	}

	protected function tearDown() {
		$query = \OC_DB::prepare('DELETE FROM `*PREFIX*share` WHERE `item_type` = ?');
		$query->execute(array('test'));

		parent::tearDown();
	}

	public function testPostAddToGroup() {

		/** @var \OC\DB\Connection $connection */
		$connection = \OC::$server->getDatabaseConnection();
		$query = $connection->createQueryBuilder();
		$expr = $query->expr();

		// add some dummy values to the private $updateTargets variable
		$this->invokePrivate(
			new \OC\Share\Hooks(),
			'updateTargets',
			[
				[
					'group1' =>
						[
							[
								'`item_type`' => $expr->literal('test'),
								'`item_source`' => $expr->literal('42'),
								'`item_target`' => $expr->literal('42'),
								'`file_target`' => $expr->literal('test'),
								'`share_type`' => $expr->literal('2'),
								'`share_with`' => $expr->literal('group1'),
								'`uid_owner`' => $expr->literal('owner'),
								'`permissions`' => $expr->literal('0'),
								'`stime`' => $expr->literal('676584'),
								'`file_source`' => $expr->literal('42'),
							],
							[
								'`item_type`' => $expr->literal('test'),
								'`item_source`' => $expr->literal('42'),
								'`item_target`' => $expr->literal('42 (2)'),
								'`share_type`' => $expr->literal('2'),
								'`share_with`' => $expr->literal('group1'),
								'`uid_owner`' => $expr->literal('owner'),
								'`permissions`' => $expr->literal('0'),
								'`stime`' => $expr->literal('676584'),
							]
						],
					'group2' =>
						[
							[
								'`item_type`' => $expr->literal('test'),
								'`item_source`' => $expr->literal('42'),
								'`item_target`' => $expr->literal('42'),
								'`share_type`' => $expr->literal('2'),
								'`share_with`' => $expr->literal('group2'),
								'`uid_owner`' => $expr->literal('owner'),
								'`permissions`' => $expr->literal('0'),
								'`stime`' => $expr->literal('676584'),
							]
						]
				]
			]
		);

		// add unique targets for group1 to database
		\OC\Share\Hooks::post_addToGroup(['gid' => 'group1']);


		$query->select('`share_with`')->from('`*PREFIX*share`');
		$result = $query->execute()->fetchAll();
		$this->assertSame(2, count($result));
		foreach ($result as $r) {
			$this->assertSame('group1', $r['share_with']);
		}
	}

}