summaryrefslogtreecommitdiffstats
path: root/tests/lib/Repair/RepairUnmergedSharesTest.php
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2016-07-22 10:08:05 +0200
committerRoeland Jago Douma <roeland@famdouma.nl>2016-08-03 10:16:28 +0200
commit0c6352e0955cb2b47496655f275ee06db2298a52 (patch)
tree67418d723a9a04781e1a9fc44393f7605c7e9660 /tests/lib/Repair/RepairUnmergedSharesTest.php
parent0c7c9a3b950ce4261a6fc76cb23f97c3673a03e4 (diff)
downloadnextcloud-server-0c6352e0955cb2b47496655f275ee06db2298a52.tar.gz
nextcloud-server-0c6352e0955cb2b47496655f275ee06db2298a52.zip
Fix RepairUnmergedShares to not skip valid repair cases
The repair step was a bit overeager to skip repairing so it missed the case where a group share exists without subshares but with an additional direct user share.
Diffstat (limited to 'tests/lib/Repair/RepairUnmergedSharesTest.php')
-rw-r--r--tests/lib/Repair/RepairUnmergedSharesTest.php44
1 files changed, 42 insertions, 2 deletions
diff --git a/tests/lib/Repair/RepairUnmergedSharesTest.php b/tests/lib/Repair/RepairUnmergedSharesTest.php
index 20dabac2e6b..fe9b3e5b96f 100644
--- a/tests/lib/Repair/RepairUnmergedSharesTest.php
+++ b/tests/lib/Repair/RepairUnmergedSharesTest.php
@@ -329,7 +329,28 @@ class RepairUnmergedSharesTest extends TestCase {
]
],
[
- // #7 legitimate share with own group:
+ // #7 bogus share:
+ // - outsider shares with group1 and also user2
+ // - no subshare at all
+ // - one extra share entry for direct share to user2
+ // - non-matching targets
+ // - user share has more permissions
+ [
+ [Constants::SHARE_TYPE_GROUP, 123, 'recipientgroup1', '/test', 1],
+ [Constants::SHARE_TYPE_USER, 123, 'user2', '/test (2)', 31],
+ // different unrelated share
+ [Constants::SHARE_TYPE_GROUP, 456, 'recipientgroup1', '/test (5)', 31],
+ ],
+ [
+ ['/test', 1],
+ // user share repaired
+ ['/test', 31],
+ // leave unrelated alone
+ ['/test (5)', 31],
+ ]
+ ],
+ [
+ // #8 legitimate share with own group:
// - insider shares with both groups the user is already in
// - no subshares in this case
[
@@ -347,7 +368,7 @@ class RepairUnmergedSharesTest extends TestCase {
]
],
[
- // #7 legitimate shares:
+ // #9 legitimate shares:
// - group share with same group
// - group share with other group
// - user share where recipient renamed
@@ -370,6 +391,25 @@ class RepairUnmergedSharesTest extends TestCase {
['/test (4)', 31],
]
],
+ [
+ // #10 legitimate share:
+ // - outsider shares with group and user directly with different permissions
+ // - no subshares
+ // - same targets
+ [
+ [Constants::SHARE_TYPE_GROUP, 123, 'samegroup1', '/test', 1],
+ [Constants::SHARE_TYPE_USER, 123, 'user3', '/test', 31],
+ // different unrelated share
+ [Constants::SHARE_TYPE_GROUP, 456, 'recipientgroup1', '/test (4)', 31],
+ ],
+ [
+ // leave all alone
+ ['/test', 1],
+ ['/test', 31],
+ // leave unrelated alone
+ ['/test (4)', 31],
+ ]
+ ],
];
}