summaryrefslogtreecommitdiffstats
path: root/build/integration/features
diff options
context:
space:
mode:
authorSergio Bertolin <sbertolin@solidgear.es>2015-10-02 07:40:25 +0000
committerRoeland Jago Douma <rullzer@owncloud.com>2015-10-06 10:30:31 +0200
commitfd709b4b49f18113dce1523fdda88ef60f2c23a4 (patch)
tree15e07d791dab00028f2d167bc95f2126fad75b53 /build/integration/features
parentac478b19103c14990a5ca023362d87e7b7eeba55 (diff)
downloadnextcloud-server-fd709b4b49f18113dce1523fdda88ef60f2c23a4.tar.gz
nextcloud-server-fd709b4b49f18113dce1523fdda88ef60f2c23a4.zip
Being explicit between http and ocs return codes
Diffstat (limited to 'build/integration/features')
-rw-r--r--build/integration/features/bootstrap/FeatureContext.php34
-rw-r--r--build/integration/features/provisioning-v1.feature21
-rw-r--r--build/integration/features/provisioning-v2.feature2
3 files changed, 37 insertions, 20 deletions
diff --git a/build/integration/features/bootstrap/FeatureContext.php b/build/integration/features/bootstrap/FeatureContext.php
index da5b62153b8..766f3a667f5 100644
--- a/build/integration/features/bootstrap/FeatureContext.php
+++ b/build/integration/features/bootstrap/FeatureContext.php
@@ -49,28 +49,36 @@ class FeatureContext extends BehatContext {
$this->sendingToWith($verb, $url, null);
}
- // /**
- // * @Then /^the status code should be "([^"]*)"$/
- // */
- // public function theStatusCodeShouldBe($statusCode) {
- // PHPUnit_Framework_Assert::assertEquals($statusCode, $this->response->getStatusCode());
- // }
-
-
+
+ /**
+ * Parses the xml answer to get ocs response which doesn't match with
+ * http one in v1 of the api.
+ */
public function getOCSResponse($response){
return $response->xml()->meta[0]->statuscode;
}
+
/**
- * @Then /^the status code should be "([^"]*)"$/
+ * @Then /^the OCS status code should be "([^"]*)"$/
*/
- public function theStatusCodeShouldBe($statusCode) {
+ public function theOCSStatusCodeShouldBe($statusCode) {
PHPUnit_Framework_Assert::assertEquals($statusCode, $this->getOCSResponse($this->response));
}
+ /**
+ * @Then /^the HTTP status code should be "([^"]*)"$/
+ */
+ public function theHTTPStatusCodeShouldBe($statusCode) {
+ PHPUnit_Framework_Assert::assertEquals($statusCode, $this->response->getStatusCode());
+ }
+
+
+
+
/**
* @Given /^As an "([^"]*)"$/
*/
@@ -89,7 +97,7 @@ class FeatureContext extends BehatContext {
* @Given /^user "([^"]*)" exists$/
*/
public function userExists($user) {
- $fullUrl = $this->baseUrl . "v{$this->apiVersion}.php/cloud/users/$user";
+ $fullUrl = $this->baseUrl . "v2.php/cloud/users/$user";
$client = new Client();
$options = [];
if ($this->currentUser === 'admin') {
@@ -97,6 +105,7 @@ class FeatureContext extends BehatContext {
}
$this->response = $client->get($fullUrl, $options);
+ PHPUnit_Framework_Assert::assertEquals(200, $this->response->getStatusCode());
}
/**
@@ -155,7 +164,7 @@ class FeatureContext extends BehatContext {
* @Given /^group "([^"]*)" exists$/
*/
public function groupExists($group) {
- $fullUrl = $this->baseUrl . "v{$this->apiVersion}.php/cloud/groups/$group";
+ $fullUrl = $this->baseUrl . "v2.php/cloud/groups/$group";
$client = new Client();
$options = [];
if ($this->currentUser === 'admin') {
@@ -163,6 +172,7 @@ class FeatureContext extends BehatContext {
}
$this->response = $client->get($fullUrl, $options);
+ PHPUnit_Framework_Assert::assertEquals(200, $this->response->getStatusCode());
}
/**
diff --git a/build/integration/features/provisioning-v1.feature b/build/integration/features/provisioning-v1.feature
index 384452d50a3..2bfd6a06d0d 100644
--- a/build/integration/features/provisioning-v1.feature
+++ b/build/integration/features/provisioning-v1.feature
@@ -5,12 +5,14 @@ Feature: provisioning
Scenario: Getting an not existing user
Given As an "admin"
When sending "GET" to "/cloud/users/test"
- Then the status code should be "998"
+ Then the OCS status code should be "998"
+ And the HTTP status code should be "200"
Scenario: Listing all users
Given As an "admin"
When sending "GET" to "/cloud/users"
- Then the status code should be "100"
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
Scenario: Create a user
Given As an "admin"
@@ -18,7 +20,8 @@ Feature: provisioning
When sending "POST" to "/cloud/users" with
| userid | brand-new-user |
| password | 123456 |
- Then the status code should be "100"
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
And user "brand-new-user" exists
@@ -30,7 +33,8 @@ Feature: provisioning
| value | 12MB |
| key | email |
| value | brand-new-user@gmail.com |
- Then the status code should be "100"
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
And user "brand-new-user" exists
@@ -38,7 +42,8 @@ Feature: provisioning
Given As an "admin"
And user "brand-new-user" exists
When sending "DELETE" to "/cloud/users/brand-new-user"
- Then the status code should be "100"
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
And user "brand-new-user" does not exist
@@ -49,7 +54,8 @@ Feature: provisioning
| groupid | new-group |
| password | 123456 |
- Then the status code should be "100"
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
And group "new-group" exists
@@ -57,7 +63,8 @@ Feature: provisioning
Given As an "admin"
And group "new-group" exists
When sending "DELETE" to "/cloud/groups/new-group"
- Then the status code should be "100"
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
And group "new-group" does not exist
diff --git a/build/integration/features/provisioning-v2.feature b/build/integration/features/provisioning-v2.feature
index 72ceed5d6a5..6140128684d 100644
--- a/build/integration/features/provisioning-v2.feature
+++ b/build/integration/features/provisioning-v2.feature
@@ -5,5 +5,5 @@ Feature: provisioning
Scenario: Getting an not existing user
Given As an "admin"
When sending "GET" to "/cloud/users/test"
- Then the status code should be "404"
+ Then the HTTP status code should be "404"