summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-11-10 17:40:35 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2015-11-10 17:40:35 +0100
commit27e3d130144f807bf930362e54cc68f1c878141a (patch)
treec459168f16e97c3f1ca8b6984c205bc18d5e24f9
parente4900c6c4c7f28261cceb7e6ddc30bce5bc87bd4 (diff)
parent7aa6e9b6432462da606b12058297fda7fba56fe3 (diff)
downloadnextcloud-server-27e3d130144f807bf930362e54cc68f1c878141a.tar.gz
nextcloud-server-27e3d130144f807bf930362e54cc68f1c878141a.zip
Merge pull request #20429 from owncloud/sharing-api-integration-tests-get-share-by-id
Added test to get info of a specific share id
-rw-r--r--build/integration/features/bootstrap/FeatureContext.php29
-rw-r--r--build/integration/features/sharing-v1.feature27
2 files changed, 54 insertions, 2 deletions
diff --git a/build/integration/features/bootstrap/FeatureContext.php b/build/integration/features/bootstrap/FeatureContext.php
index 69fa018d0e6..4a0299d6e49 100644
--- a/build/integration/features/bootstrap/FeatureContext.php
+++ b/build/integration/features/bootstrap/FeatureContext.php
@@ -672,7 +672,10 @@ class FeatureContext implements Context, SnippetAcceptingContext {
public function isFieldInResponse($field, $content_expected){
$data = $this->response->xml()->data[0];
foreach($data as $element) {
- if ($element->$field == $content_expected){
+ if ($content_expected == "A_NUMBER"){
+ return is_numeric((string)$element->$field);
+ }
+ elseif ($element->$field == $content_expected){
return True;
}
}
@@ -744,10 +747,32 @@ class FeatureContext implements Context, SnippetAcceptingContext {
*/
public function deletingLastShare(){
$share_id = $this->lastShareData->data[0]->id;
- $url = "/apps/files_sharing/api/v{$this->apiVersion}/shares/$share_id";
+ $url = "/apps/files_sharing/api/v{$this->sharingApiVersion}/shares/$share_id";
$this->sendingToWith("DELETE", $url, null);
}
+ /**
+ * @When /^Getting info of last share$/
+ */
+ public function gettingInfoOfLastShare(){
+ $share_id = $this->lastShareData->data[0]->id;
+ $url = "/apps/files_sharing/api/v{$this->sharingApiVersion}/shares/$share_id";
+ $this->sendingToWith("GET", $url, null);
+ }
+
+ /**
+ * @Then /^Share fields of last share match with$/
+ * @param \Behat\Gherkin\Node\TableNode|null $formData
+ */
+ public function checkShareFields($body){
+ if ($body instanceof \Behat\Gherkin\Node\TableNode) {
+ $fd = $body->getRowsHash();
+ foreach($fd as $field => $value) {
+ PHPUnit_Framework_Assert::assertEquals(True, $this->isFieldInResponse($field, $value));
+ }
+ }
+ }
+
public static function removeFile($path, $filename){
if (file_exists("$path" . "$filename")) {
unlink("$path" . "$filename");
diff --git a/build/integration/features/sharing-v1.feature b/build/integration/features/sharing-v1.feature
index b73fb39d5da..36e729d2a13 100644
--- a/build/integration/features/sharing-v1.feature
+++ b/build/integration/features/sharing-v1.feature
@@ -108,6 +108,33 @@ Feature: sharing
And User "user2" should be included in the response
And User "user3" should not be included in the response
+ Scenario: getting share info of a share
+ Given user "user0" exists
+ And user "user1" exists
+ And file "textfile0.txt" from user "user0" is shared with user "user1"
+ And As an "user0"
+ When Getting info of last share
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
+ And Share fields of last share match with
+ | id | A_NUMBER |
+ | item_type | file |
+ | item_source | A_NUMBER |
+ | share_type | 0 |
+ | share_with | user1 |
+ | file_source | A_NUMBER |
+ | file_target | /textfile0.txt |
+ | path | /textfile0.txt |
+ | permissions | 23 |
+ | stime | A_NUMBER |
+ | storage | A_NUMBER |
+ | mail_send | 0 |
+ | uid_owner | user0 |
+ | storage_id | home::user0 |
+ | file_parent | A_NUMBER |
+ | share_with_displayname | user1 |
+ | displayname_owner | user0 |
+
Scenario: delete a share
Given user "user0" exists
And user "user1" exists