Merge pull request #20463 from owncloud/sharing-api-integration-tests-adding-cases
Sharing api integration tests adding cases
This commit is contained in:
commit
f0af761fa6
2 changed files with 257 additions and 13 deletions
|
@ -562,7 +562,30 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
* @param \Behat\Gherkin\Node\TableNode|null $formData
|
||||
*/
|
||||
public function createPublicShare($body) {
|
||||
$this->sendingToWith("POST", "/apps/files_sharing/api/v1/shares", $body);
|
||||
$fullUrl = $this->baseUrl . "v{$this->apiVersion}.php/apps/files_sharing/api/v1/shares";
|
||||
$client = new Client();
|
||||
$options = [];
|
||||
if ($this->currentUser === 'admin') {
|
||||
$options['auth'] = $this->adminUser;
|
||||
} else {
|
||||
$options['auth'] = [$this->currentUser, $this->regularUser];
|
||||
}
|
||||
|
||||
if ($body instanceof \Behat\Gherkin\Node\TableNode) {
|
||||
$fd = $body->getRowsHash();
|
||||
if (array_key_exists('expireDate', $fd)){
|
||||
$dateModification = $fd['expireDate'];
|
||||
$fd['expireDate'] = date('Y-m-d', strtotime($dateModification));
|
||||
}
|
||||
$options['body'] = $fd;
|
||||
}
|
||||
|
||||
try {
|
||||
$this->response = $client->send($client->createRequest("POST", $fullUrl, $options));
|
||||
} catch (\GuzzleHttp\Exception\ClientException $ex) {
|
||||
$this->response = $ex->getResponse();
|
||||
}
|
||||
|
||||
$this->lastShareData = $this->response->xml();
|
||||
}
|
||||
|
||||
|
@ -572,7 +595,12 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
public function checkPublicSharedFile($filename) {
|
||||
$client = new Client();
|
||||
$options = [];
|
||||
$url = $this->lastShareData->data[0]->url;
|
||||
if (count($this->lastShareData->data->element) > 0){
|
||||
$url = $this->lastShareData->data[0]->url;
|
||||
}
|
||||
else{
|
||||
$url = $this->lastShareData->data->url;
|
||||
}
|
||||
$fullUrl = $url . "/download";
|
||||
$options['save_to'] = "./$filename";
|
||||
$this->response = $client->get($fullUrl, $options);
|
||||
|
@ -590,7 +618,13 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
public function checkPublicSharedFileWithPassword($filename, $password) {
|
||||
$client = new Client();
|
||||
$options = [];
|
||||
$token = $this->lastShareData->data[0]->token;
|
||||
if (count($this->lastShareData->data->element) > 0){
|
||||
$token = $this->lastShareData->data[0]->token;
|
||||
}
|
||||
else{
|
||||
$token = $this->lastShareData->data->token;
|
||||
}
|
||||
|
||||
$fullUrl = substr($this->baseUrl, 0, -4) . "public.php/webdav";
|
||||
$options['auth'] = [$token, $password];
|
||||
$options['save_to'] = "./$filename";
|
||||
|
@ -622,6 +656,40 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
PHPUnit_Framework_Assert::assertEquals(200, $this->response->getStatusCode());
|
||||
}
|
||||
|
||||
/**
|
||||
* @When /^Updating last share with$/
|
||||
* @param \Behat\Gherkin\Node\TableNode|null $formData
|
||||
*/
|
||||
public function updatingLastShare($body) {
|
||||
$share_id = $this->lastShareData->data[0]->id;
|
||||
$fullUrl = $this->baseUrl . "v{$this->apiVersion}.php/apps/files_sharing/api/v{$this->sharingApiVersion}/shares/$share_id";
|
||||
$client = new Client();
|
||||
$options = [];
|
||||
if ($this->currentUser === 'admin') {
|
||||
$options['auth'] = $this->adminUser;
|
||||
} else {
|
||||
$options['auth'] = [$this->currentUser, $this->regularUser];
|
||||
}
|
||||
|
||||
if ($body instanceof \Behat\Gherkin\Node\TableNode) {
|
||||
$fd = $body->getRowsHash();
|
||||
if (array_key_exists('expireDate', $fd)){
|
||||
$dateModification = $fd['expireDate'];
|
||||
$fd['expireDate'] = date('Y-m-d', strtotime($dateModification));
|
||||
}
|
||||
$options['body'] = $fd;
|
||||
}
|
||||
|
||||
try {
|
||||
$this->response = $client->send($client->createRequest("PUT", $fullUrl, $options));
|
||||
} catch (\GuzzleHttp\Exception\ClientException $ex) {
|
||||
$this->response = $ex->getResponse();
|
||||
}
|
||||
|
||||
PHPUnit_Framework_Assert::assertEquals(200, $this->response->getStatusCode());
|
||||
}
|
||||
|
||||
|
||||
public function createShare($user,
|
||||
$path = null,
|
||||
$shareType = null,
|
||||
|
@ -669,17 +737,49 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
|
||||
}
|
||||
|
||||
public function isFieldInResponse($field, $content_expected){
|
||||
public function isExpectedUrl($possibleUrl, $finalPart){
|
||||
$baseUrlChopped = substr($this->baseUrl, 0, -4);
|
||||
$endCharacter = strlen($baseUrlChopped) + strlen($finalPart);
|
||||
return (substr($possibleUrl,0,$endCharacter) == "$baseUrlChopped" . "$finalPart");
|
||||
}
|
||||
|
||||
public function isFieldInResponse($field, $contentExpected){
|
||||
$data = $this->response->xml()->data[0];
|
||||
foreach($data as $element) {
|
||||
if ($content_expected == "A_NUMBER"){
|
||||
return is_numeric((string)$element->$field);
|
||||
}
|
||||
elseif ($element->$field == $content_expected){
|
||||
return True;
|
||||
}
|
||||
if ((string)$field == 'expiration'){
|
||||
$contentExpected = date('Y-m-d', strtotime($contentExpected)) . " 00:00:00";
|
||||
}
|
||||
if (count($data->element) > 0){
|
||||
foreach($data as $element) {
|
||||
if ($contentExpected == "A_TOKEN"){
|
||||
return (strlen((string)$element->$field) == 15);
|
||||
}
|
||||
elseif ($contentExpected == "A_NUMBER"){
|
||||
return is_numeric((string)$element->$field);
|
||||
}
|
||||
elseif($contentExpected == "AN_URL"){
|
||||
return $this->isExpectedUrl((string)$element->$field, "index.php/s/");
|
||||
}
|
||||
elseif ($element->$field == $contentExpected){
|
||||
return True;
|
||||
}
|
||||
}
|
||||
|
||||
return False;
|
||||
} else {
|
||||
if ($contentExpected == "A_TOKEN"){
|
||||
return (strlen((string)$data->$field) == 15);
|
||||
}
|
||||
elseif ($contentExpected == "A_NUMBER"){
|
||||
return is_numeric((string)$data->$field);
|
||||
}
|
||||
elseif($contentExpected == "AN_URL"){
|
||||
return $this->isExpectedUrl((string)$data->$field, "index.php/s/");
|
||||
}
|
||||
elseif ($data->$field == $contentExpected){
|
||||
return True;
|
||||
}
|
||||
return False;
|
||||
}
|
||||
return False;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -767,6 +867,7 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
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));
|
||||
}
|
||||
|
@ -786,6 +887,9 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
for ($i=0; $i<5; $i++){
|
||||
file_put_contents("../../core/skeleton/" . "textfile" . "$i" . ".txt", "ownCloud test text file\n");
|
||||
}
|
||||
if (!file_exists("../../core/skeleton/FOLDER")) {
|
||||
mkdir("../../core/skeleton/FOLDER", 0777, true);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
@ -796,6 +900,9 @@ class FeatureContext implements Context, SnippetAcceptingContext {
|
|||
for ($i=0; $i<5; $i++){
|
||||
self::removeFile("../../core/skeleton/", "textfile" . "$i" . ".txt");
|
||||
}
|
||||
if (!is_dir("../../core/skeleton/FOLDER")) {
|
||||
rmdir("../../core/skeleton/FOLDER");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -46,6 +46,25 @@ Feature: sharing
|
|||
And the HTTP status code should be "200"
|
||||
And Public shared file "welcome.txt" with password "publicpw" can be downloaded
|
||||
|
||||
Scenario: Creating a new public share of a folder
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a public share with
|
||||
| path | FOLDER |
|
||||
| shareType | 3 |
|
||||
| password | publicpw |
|
||||
| expireDate | +3 days |
|
||||
| publicUpload | true |
|
||||
| permissions | 7 |
|
||||
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 |
|
||||
| permissions | 7 |
|
||||
| expiration | +3 days |
|
||||
| url | AN_URL |
|
||||
| token | A_TOKEN |
|
||||
|
||||
Scenario: Creating a new public share with password and adding an expiration date
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
|
@ -53,11 +72,129 @@ Feature: sharing
|
|||
| path | welcome.txt |
|
||||
| shareType | 3 |
|
||||
| password | publicpw |
|
||||
And Adding expiration date to last share
|
||||
And Updating last share with
|
||||
| expireDate | +3 days |
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And Public shared file "welcome.txt" with password "publicpw" can be downloaded
|
||||
|
||||
Scenario: Creating a new public share, updating its expiration date and getting its info
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a public share with
|
||||
| path | FOLDER |
|
||||
| shareType | 3 |
|
||||
And Updating last share with
|
||||
| expireDate | +3 days |
|
||||
And 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 | folder |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 3 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /FOLDER |
|
||||
| permissions | 1 |
|
||||
| stime | A_NUMBER |
|
||||
| expiration | +3 days |
|
||||
| token | A_TOKEN |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| displayname_owner | user0 |
|
||||
| url | AN_URL |
|
||||
|
||||
Scenario: Creating a new public share, updating its password and getting its info
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a public share with
|
||||
| path | FOLDER |
|
||||
| shareType | 3 |
|
||||
And Updating last share with
|
||||
| password | publicpw |
|
||||
And 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 | folder |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 3 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /FOLDER |
|
||||
| permissions | 1 |
|
||||
| stime | A_NUMBER |
|
||||
| token | A_TOKEN |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| displayname_owner | user0 |
|
||||
| url | AN_URL |
|
||||
|
||||
Scenario: Creating a new public share, updating its permissions and getting its info
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a public share with
|
||||
| path | FOLDER |
|
||||
| shareType | 3 |
|
||||
And Updating last share with
|
||||
| permissions | 7 |
|
||||
And 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 | folder |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 3 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /FOLDER |
|
||||
| permissions | 7 |
|
||||
| stime | A_NUMBER |
|
||||
| token | A_TOKEN |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| displayname_owner | user0 |
|
||||
| url | AN_URL |
|
||||
|
||||
Scenario: Creating a new public share, updating publicUpload option and getting its info
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a public share with
|
||||
| path | FOLDER |
|
||||
| shareType | 3 |
|
||||
And Updating last share with
|
||||
| publicUpload | true |
|
||||
And 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 | folder |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 3 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /FOLDER |
|
||||
| permissions | 7 |
|
||||
| stime | A_NUMBER |
|
||||
| token | A_TOKEN |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| displayname_owner | user0 |
|
||||
| url | AN_URL |
|
||||
|
||||
Scenario: getting all shares of a user using that user
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
|
|
Loading…
Reference in a new issue