diff options
author | Sergio Bertolin <sbertolin@solidgear.es> | 2015-12-02 17:29:42 +0000 |
---|---|---|
committer | Sergio Bertolin <sbertolin@solidgear.es> | 2015-12-02 17:29:42 +0000 |
commit | e01e894b985d3c8ee88da755abf7d5c139787705 (patch) | |
tree | 3204a887966ed4b3e8e3c5f3ac57b7beeb29b793 /build/integration | |
parent | df5872ec50a68de5d99bd6b5cf17ceb94f2ef833 (diff) | |
download | nextcloud-server-e01e894b985d3c8ee88da755abf7d5c139787705.tar.gz nextcloud-server-e01e894b985d3c8ee88da755abf7d5c139787705.zip |
Added capabilities context and tests
Diffstat (limited to 'build/integration')
-rw-r--r-- | build/integration/capabilities_features/capabilities.feature | 34 | ||||
-rw-r--r-- | build/integration/config/behat.yml | 13 | ||||
-rw-r--r-- | build/integration/features/bootstrap/CapabilitiesContext.php | 45 | ||||
-rw-r--r-- | build/integration/federation_features/federated.feature (renamed from build/integration/federation/federated.feature) | 0 |
4 files changed, 91 insertions, 1 deletions
diff --git a/build/integration/capabilities_features/capabilities.feature b/build/integration/capabilities_features/capabilities.feature new file mode 100644 index 00000000000..4adb884e80a --- /dev/null +++ b/build/integration/capabilities_features/capabilities.feature @@ -0,0 +1,34 @@ +Feature: capabilities + Background: + Given using api version "1" + + Scenario: getting capabilities with admin user + Given As an "admin" + When sending "GET" to "/cloud/capabilities" + Then the HTTP status code should be "200" + And fields of capabilities match with + | capability | feature | value_or_subfeature | value | + | core | pollinterval | 60 | | + | core | webdav-root | remote.php/webdav | | + | files_sharing | api_enabled | 1 | | + | files_sharing | public | enabled | 1 | + | files_sharing | public | password | 1 | + | files_sharing | public | expire_date | 1 | + | files_sharing | public | send_mail | 1 | + | files_sharing | public | upload | 1 | + | files_sharing | resharing | 1 | | + | files_sharing | federation | outgoing | 1 | + | files_sharing | federation | incoming | 1 | + | files | bigfilechunking | 1 | | + | files | undelete | 1 | | + | files | versioning | 1 | | + + + + + + + + + + diff --git a/build/integration/config/behat.yml b/build/integration/config/behat.yml index 37ed2b117f3..42f5f88ac8a 100644 --- a/build/integration/config/behat.yml +++ b/build/integration/config/behat.yml @@ -14,7 +14,7 @@ default: regular_user_password: 123456 federation: paths: - - %paths.base%/../federation + - %paths.base%/../federation_features contexts: - FederationContext: baseUrl: http://localhost:8080/ocs/ @@ -22,6 +22,17 @@ default: - admin - admin regular_user_password: 123456 + capabilities: + paths: + - %paths.base%/../capabilities_features + contexts: + - CapabilitiesContext: + baseUrl: http://localhost:8080/ocs/ + admin: + - admin + - admin + regular_user_password: 123456 + extensions: diff --git a/build/integration/features/bootstrap/CapabilitiesContext.php b/build/integration/features/bootstrap/CapabilitiesContext.php new file mode 100644 index 00000000000..a1a14aa3bb3 --- /dev/null +++ b/build/integration/features/bootstrap/CapabilitiesContext.php @@ -0,0 +1,45 @@ +<?php + +use Behat\Behat\Context\Context; +use Behat\Behat\Context\SnippetAcceptingContext; +use GuzzleHttp\Client; +use GuzzleHttp\Message\ResponseInterface; + +require __DIR__ . '/../../vendor/autoload.php'; + +/** + * Capabilities context. + */ +class CapabilitiesContext implements Context, SnippetAcceptingContext { + + use BasicStructure; + use Provisioning; + use Sharing; + + /** + * @Then /^fields of capabilities match with$/ + * @param \Behat\Gherkin\Node\TableNode|null $formData + */ + public function checkCapabilitiesResponse($formData){ + if ($formData instanceof \Behat\Gherkin\Node\TableNode) { + $fd = $formData->getHash(); + } + + $capabilitiesXML = $this->response->xml()->data->capabilities; + + foreach ($fd as $row) { + if ($row['value'] === ''){ + $answeredValue = (string)$capabilitiesXML->$row['capability']->$row['feature']->$row['value_or_subfeature']; + if ( !$answeredValue === $row['value_or_subfeature']){ + PHPUnit_Framework_Assert::fail("Answered value $answeredValue is different to expected " . $row['value_or_subfeature']); + } + } else{ + $answeredValue = (string)$capabilitiesXML->$row['capability']->$row['feature']->$row['value_or_subfeature']->$row['value']; + if ( !$answeredValue === $row['value']){ + PHPUnit_Framework_Assert::fail("Answered value $answeredValue is different to expected " . $row['value']); + } + } + } + } + +} diff --git a/build/integration/federation/federated.feature b/build/integration/federation_features/federated.feature index 5437d01dee2..5437d01dee2 100644 --- a/build/integration/federation/federated.feature +++ b/build/integration/federation_features/federated.feature |