From 533eb89b546dc1bae5138b55ef0011406f841e67 Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Thu, 27 May 2021 14:56:22 +0200 Subject: [PATCH] Add integration tests for the editable fields Signed-off-by: Joas Schilling --- .../features/bootstrap/Provisioning.php | 30 +++++++++++++++++++ .../features/provisioning-v1.feature | 26 ++++++++++++++++ 2 files changed, 56 insertions(+) diff --git a/build/integration/features/bootstrap/Provisioning.php b/build/integration/features/bootstrap/Provisioning.php index cbe11403ba..d613986df6 100644 --- a/build/integration/features/bootstrap/Provisioning.php +++ b/build/integration/features/bootstrap/Provisioning.php @@ -177,6 +177,36 @@ trait Provisioning { } } + /** + * @Then /^user "([^"]*)" has editable fields$/ + * + * @param string $user + * @param \Behat\Gherkin\Node\TableNode|null $fields + */ + public function userHasEditableFields($user, $fields) { + $fullUrl = $this->baseUrl . "v{$this->apiVersion}.php/cloud/user/fields"; + if ($user !== 'self') { + $fullUrl .= '/' . $user; + } + $client = new Client(); + $options = []; + if ($this->currentUser === 'admin') { + $options['auth'] = $this->adminUser; + } else { + $options['auth'] = [$this->currentUser, $this->regularUser]; + } + $options['headers'] = [ + 'OCS-APIREQUEST' => 'true', + ]; + + $response = $client->get($fullUrl, $options); + $fieldsArray = json_decode(json_encode(simplexml_load_string($response->getBody())->data->element), 1); + + $expectedFields = $fields->getRows(); + $expectedFields = $this->simplifyArray($expectedFields); + Assert::assertEquals($expectedFields, $fieldsArray); + } + /** * @Then /^search users by phone for region "([^"]*)" with$/ * diff --git a/build/integration/features/provisioning-v1.feature b/build/integration/features/provisioning-v1.feature index 03aaad4b85..9a7db6f4af 100644 --- a/build/integration/features/provisioning-v1.feature +++ b/build/integration/features/provisioning-v1.feature @@ -56,6 +56,32 @@ Feature: provisioning | brand-new-user | | admin | + Scenario: Get editable fields + Given As an "admin" + And user "brand-new-user" exists + Then user "brand-new-user" has editable fields + | displayname | + | email | + | phone | + | address | + | website | + | twitter | + Given As an "brand-new-user" + Then user "brand-new-user" has editable fields + | displayname | + | email | + | phone | + | address | + | website | + | twitter | + Then user "self" has editable fields + | displayname | + | email | + | phone | + | address | + | website | + | twitter | + Scenario: Edit a user Given As an "admin" And user "brand-new-user" exists