summaryrefslogtreecommitdiffstats
path: root/apps/dav/tests/unit
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2020-01-31 16:10:19 +0100
committerRoeland Jago Douma <roeland@famdouma.nl>2020-03-18 13:41:04 +0100
commit7819a904d7fe2db2bf48a1e041db6aa84976e4bd (patch)
tree1cc91541fd308824084ec64521d73d966e1853ce /apps/dav/tests/unit
parent95cd44c41e5202738721f8e67eb88d488257612d (diff)
downloadnextcloud-server-7819a904d7fe2db2bf48a1e041db6aa84976e4bd.tar.gz
nextcloud-server-7819a904d7fe2db2bf48a1e041db6aa84976e4bd.zip
handle long property paths to hasing paths >250 chars
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps/dav/tests/unit')
-rw-r--r--apps/dav/tests/unit/DAV/CustomPropertiesBackendTest.php52
1 files changed, 41 insertions, 11 deletions
diff --git a/apps/dav/tests/unit/DAV/CustomPropertiesBackendTest.php b/apps/dav/tests/unit/DAV/CustomPropertiesBackendTest.php
index 45be59151ec..3250361ed17 100644
--- a/apps/dav/tests/unit/DAV/CustomPropertiesBackendTest.php
+++ b/apps/dav/tests/unit/DAV/CustomPropertiesBackendTest.php
@@ -100,6 +100,14 @@ class CustomPropertiesBackendTest extends TestCase {
parent::tearDown();
}
+ private function formatPath(string $path): string {
+ if (strlen($path) > 250) {
+ return sha1($path);
+ } else {
+ return $path;
+ }
+ }
+
protected function insertProps(string $user, string $path, array $props) {
foreach ($props as $name => $value) {
$this->insertProp($user, $path, $name, $value);
@@ -111,7 +119,7 @@ class CustomPropertiesBackendTest extends TestCase {
$query->insert('properties')
->values([
'userid' => $query->createNamedParameter($user),
- 'propertypath' => $query->createNamedParameter($path),
+ 'propertypath' => $query->createNamedParameter($this->formatPath($path)),
'propertyname' => $query->createNamedParameter($name),
'propertyvalue' => $query->createNamedParameter($value),
]);
@@ -123,7 +131,7 @@ class CustomPropertiesBackendTest extends TestCase {
$query->select('propertyname', 'propertyvalue')
->from('properties')
->where($query->expr()->eq('userid', $query->createNamedParameter($user)))
- ->where($query->expr()->eq('propertypath', $query->createNamedParameter($path)));
+ ->where($query->expr()->eq('propertypath', $query->createNamedParameter($this->formatPath($path))));
return $query->execute()->fetchAll(\PDO::FETCH_KEY_PAIR);
}
@@ -213,23 +221,45 @@ class CustomPropertiesBackendTest extends TestCase {
}
public function propPatchProvider() {
+ $longPath = str_repeat('long_path', 100);
return [
['foo_bar_path_1337', [], ['{DAV:}displayname' => 'anything'], ['{DAV:}displayname' => 'anything']],
['foo_bar_path_1337', ['{DAV:}displayname' => 'foo'], ['{DAV:}displayname' => 'anything'], ['{DAV:}displayname' => 'anything']],
['foo_bar_path_1337', ['{DAV:}displayname' => 'foo'], ['{DAV:}displayname' => null], []],
+ [$longPath, [], ['{DAV:}displayname' => 'anything'], ['{DAV:}displayname' => 'anything']],
];
}
- public function testDelete() {
- $this->insertProps('dummy_user_42', 'foo_bar_path_1337', ['foo' => 'bar']);
- $this->backend->delete('foo_bar_path_1337');
- $this->assertEquals([], $this->getProps('dummy_user_42', 'foo_bar_path_1337'));
+ /**
+ * @dataProvider deleteProvider
+ */
+ public function testDelete(string $path) {
+ $this->insertProps('dummy_user_42', $path, ['foo' => 'bar']);
+ $this->backend->delete($path);
+ $this->assertEquals([], $this->getProps('dummy_user_42', $path));
}
- public function testMove() {
- $this->insertProps('dummy_user_42', 'foo_bar_path_1337', ['foo' => 'bar']);
- $this->backend->move('foo_bar_path_1337', 'bar_foo_path_7331');
- $this->assertEquals([], $this->getProps('dummy_user_42', 'foo_bar_path_1337'));
- $this->assertEquals(['foo' => 'bar'], $this->getProps('dummy_user_42', 'bar_foo_path_7331'));
+ public function deleteProvider() {
+ return [
+ ['foo_bar_path_1337'],
+ [str_repeat('long_path', 100)]
+ ];
+ }
+
+ /**
+ * @dataProvider moveProvider
+ */
+ public function testMove(string $source, string $target) {
+ $this->insertProps('dummy_user_42', $source, ['foo' => 'bar']);
+ $this->backend->move($source, $target);
+ $this->assertEquals([], $this->getProps('dummy_user_42', $source));
+ $this->assertEquals(['foo' => 'bar'], $this->getProps('dummy_user_42', $target));
+ }
+
+ public function moveProvider() {
+ return [
+ ['foo_bar_path_1337', 'foo_bar_path_7333'],
+ [str_repeat('long_path1', 100), str_repeat('long_path2', 100)]
+ ];
}
}