Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorDaniel Calviño Sánchez <danxuliu@gmail.com>2018-02-19 01:52:44 +0300
committerDaniel Calviño Sánchez <danxuliu@gmail.com>2018-03-11 14:17:18 +0300
commitc62c7dda825893212c7fb64a8096a00c70739480 (patch)
treeb2769c54acf10f9cd8a73a6836eca193af81d14c /tests
parent6bd630d2ea797c9eeb4053d8b799dfbb27d6b223 (diff)
Extract file list locators and steps to its own class
Besides the extraction some minor adjustments (moving parametrized locators like "fileActionsMenuItemFor" above the locators that use them and placing "descendantOf" calls always in a new line) were made too. Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/acceptance/config/behat.yml1
-rw-r--r--tests/acceptance/features/bootstrap/FileListContext.php181
-rw-r--r--tests/acceptance/features/bootstrap/FilesAppContext.php147
3 files changed, 183 insertions, 146 deletions
diff --git a/tests/acceptance/config/behat.yml b/tests/acceptance/config/behat.yml
index 10e1d425022..9af01efcf09 100644
--- a/tests/acceptance/config/behat.yml
+++ b/tests/acceptance/config/behat.yml
@@ -11,6 +11,7 @@ default:
- AppNavigationContext
- FeatureContext
+ - FileListContext
- FilesAppContext
- FilesSharingAppContext
- LoginPageContext
diff --git a/tests/acceptance/features/bootstrap/FileListContext.php b/tests/acceptance/features/bootstrap/FileListContext.php
new file mode 100644
index 00000000000..227cdd2614e
--- /dev/null
+++ b/tests/acceptance/features/bootstrap/FileListContext.php
@@ -0,0 +1,181 @@
+<?php
+
+/**
+ *
+ * @copyright Copyright (c) 2018, Daniel Calviño Sánchez (danxuliu@gmail.com)
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+use Behat\Behat\Context\Context;
+
+class FileListContext implements Context, ActorAwareInterface {
+
+ use ActorAware;
+
+ /**
+ * @return Locator
+ */
+ public static function rowForFile($fileName) {
+ return Locator::forThe()->xpath("//*[@id = 'fileList']//span[contains(concat(' ', normalize-space(@class), ' '), ' nametext ') and normalize-space() = '$fileName']/ancestor::tr")->
+ descendantOf(FilesAppContext::currentSectionMainView())->
+ describedAs("Row for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function favoriteActionForFile($fileName) {
+ return Locator::forThe()->css(".action-favorite")->
+ descendantOf(self::rowForFile($fileName))->
+ describedAs("Favorite action for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function favoritedStateIconForFile($fileName) {
+ return Locator::forThe()->css(".icon-starred")->
+ descendantOf(self::favoriteActionForFile($fileName))->
+ describedAs("Favorited state icon for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function mainLinkForFile($fileName) {
+ return Locator::forThe()->css(".name")->
+ descendantOf(self::rowForFile($fileName))->
+ describedAs("Main link for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function renameInputForFile($fileName) {
+ return Locator::forThe()->css("input.filename")->
+ descendantOf(self::rowForFile($fileName))->
+ describedAs("Rename input for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function shareActionForFile($fileName) {
+ return Locator::forThe()->css(".action-share")->
+ descendantOf(self::rowForFile($fileName))->
+ describedAs("Share action for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function fileActionsMenuButtonForFile($fileName) {
+ return Locator::forThe()->css(".action-menu")->
+ descendantOf(self::rowForFile($fileName))->
+ describedAs("File actions menu button for file $fileName in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function fileActionsMenu() {
+ return Locator::forThe()->css(".fileActionsMenu")->
+ describedAs("File actions menu in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ private static function fileActionsMenuItemFor($itemText) {
+ return Locator::forThe()->xpath("//a[normalize-space() = '$itemText']")->
+ descendantOf(self::fileActionsMenu())->
+ describedAs($itemText . " item in file actions menu in Files app");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function detailsMenuItem() {
+ return self::fileActionsMenuItemFor("Details");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function renameMenuItem() {
+ return self::fileActionsMenuItemFor("Rename");
+ }
+
+ /**
+ * @return Locator
+ */
+ public static function viewFileInFolderMenuItem() {
+ return self::fileActionsMenuItemFor("View in folder");
+ }
+
+ /**
+ * @Given I open the details view for :fileName
+ */
+ public function iOpenTheDetailsViewFor($fileName) {
+ $this->actor->find(self::fileActionsMenuButtonForFile($fileName), 10)->click();
+
+ $this->actor->find(self::detailsMenuItem(), 2)->click();
+ }
+
+ /**
+ * @Given I rename :fileName1 to :fileName2
+ */
+ public function iRenameTo($fileName1, $fileName2) {
+ $this->actor->find(self::fileActionsMenuButtonForFile($fileName1), 10)->click();
+
+ $this->actor->find(self::renameMenuItem(), 2)->click();
+
+ $this->actor->find(self::renameInputForFile($fileName1), 10)->setValue($fileName2 . "\r");
+ }
+
+ /**
+ * @Given I mark :fileName as favorite
+ */
+ public function iMarkAsFavorite($fileName) {
+ $this->actor->find(self::favoriteActionForFile($fileName), 10)->click();
+ }
+
+ /**
+ * @When I view :fileName in folder
+ */
+ public function iViewInFolder($fileName) {
+ $this->actor->find(self::fileActionsMenuButtonForFile($fileName), 10)->click();
+
+ $this->actor->find(self::viewFileInFolderMenuItem(), 2)->click();
+ }
+
+ /**
+ * @Then I see that the file list contains a file named :fileName
+ */
+ public function iSeeThatTheFileListContainsAFileNamed($fileName) {
+ PHPUnit_Framework_Assert::assertNotNull($this->actor->find(self::rowForFile($fileName), 10));
+ }
+
+ /**
+ * @Then I see that :fileName is marked as favorite
+ */
+ public function iSeeThatIsMarkedAsFavorite($fileName) {
+ PHPUnit_Framework_Assert::assertNotNull($this->actor->find(self::favoritedStateIconForFile($fileName), 10));
+ }
+
+}
diff --git a/tests/acceptance/features/bootstrap/FilesAppContext.php b/tests/acceptance/features/bootstrap/FilesAppContext.php
index 76921ba7383..dfa8f9114d2 100644
--- a/tests/acceptance/features/bootstrap/FilesAppContext.php
+++ b/tests/acceptance/features/bootstrap/FilesAppContext.php
@@ -233,110 +233,6 @@ class FilesAppContext implements Context, ActorAwareInterface {
}
/**
- * @return Locator
- */
- public static function rowForFile($fileName) {
- return Locator::forThe()->xpath("//*[@id = 'fileList']//span[contains(concat(' ', normalize-space(@class), ' '), ' nametext ') and normalize-space() = '$fileName']/ancestor::tr")->
- descendantOf(self::currentSectionMainView())->
- describedAs("Row for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function favoriteActionForFile($fileName) {
- return Locator::forThe()->css(".action-favorite")->descendantOf(self::rowForFile($fileName))->
- describedAs("Favorite action for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function favoritedStateIconForFile($fileName) {
- return Locator::forThe()->css(".icon-starred")->descendantOf(self::favoriteActionForFile($fileName))->
- describedAs("Favorited state icon for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function mainLinkForFile($fileName) {
- return Locator::forThe()->css(".name")->descendantOf(self::rowForFile($fileName))->
- describedAs("Main link for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function renameInputForFile($fileName) {
- return Locator::forThe()->css("input.filename")->descendantOf(self::rowForFile($fileName))->
- describedAs("Rename input for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function shareActionForFile($fileName) {
- return Locator::forThe()->css(".action-share")->descendantOf(self::rowForFile($fileName))->
- describedAs("Share action for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function fileActionsMenuButtonForFile($fileName) {
- return Locator::forThe()->css(".action-menu")->descendantOf(self::rowForFile($fileName))->
- describedAs("File actions menu button for file $fileName in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function fileActionsMenu() {
- return Locator::forThe()->css(".fileActionsMenu")->
- describedAs("File actions menu in Files app");
- }
-
- /**
- * @return Locator
- */
- public static function detailsMenuItem() {
- return self::fileActionsMenuItemFor("Details");
- }
-
- /**
- * @return Locator
- */
- public static function renameMenuItem() {
- return self::fileActionsMenuItemFor("Rename");
- }
-
- /**
- * @return Locator
- */
- public static function viewFileInFolderMenuItem() {
- return self::fileActionsMenuItemFor("View in folder");
- }
-
- /**
- * @return Locator
- */
- private static function fileActionsMenuItemFor($itemText) {
- return Locator::forThe()->xpath("//a[normalize-space() = '$itemText']")->
- descendantOf(self::fileActionsMenu())->
- describedAs($itemText . " item in file actions menu in Files app");
- }
-
- /**
- * @Given I open the details view for :fileName
- */
- public function iOpenTheDetailsViewFor($fileName) {
- $this->actor->find(self::fileActionsMenuButtonForFile($fileName), 10)->click();
-
- $this->actor->find(self::detailsMenuItem(), 2)->click();
- }
-
- /**
* @Given I open the input field for tags in the details view
*/
public function iOpenTheInputFieldForTagsInTheDetailsView() {
@@ -351,28 +247,10 @@ class FilesAppContext implements Context, ActorAwareInterface {
}
/**
- * @Given I rename :fileName1 to :fileName2
- */
- public function iRenameTo($fileName1, $fileName2) {
- $this->actor->find(self::fileActionsMenuButtonForFile($fileName1), 10)->click();
-
- $this->actor->find(self::renameMenuItem(), 2)->click();
-
- $this->actor->find(self::renameInputForFile($fileName1), 10)->setValue($fileName2 . "\r");
- }
-
- /**
- * @Given I mark :fileName as favorite
- */
- public function iMarkAsFavorite($fileName) {
- $this->actor->find(self::favoriteActionForFile($fileName), 10)->click();
- }
-
- /**
* @Given I share the link for :fileName
*/
public function iShareTheLinkFor($fileName) {
- $this->actor->find(self::shareActionForFile($fileName), 10)->click();
+ $this->actor->find(FileListContext::shareActionForFile($fileName), 10)->click();
$this->actor->find(self::shareLinkCheckbox(), 5)->click();
}
@@ -394,15 +272,6 @@ class FilesAppContext implements Context, ActorAwareInterface {
}
/**
- * @When I view :fileName in folder
- */
- public function iViewInFolder($fileName) {
- $this->actor->find(self::fileActionsMenuButtonForFile($fileName), 10)->click();
-
- $this->actor->find(self::viewFileInFolderMenuItem(), 2)->click();
- }
-
- /**
* @When I check the tag :tag in the dropdown for tags in the details view
*/
public function iCheckTheTagInTheDropdownForTagsInTheDetailsView($tag) {
@@ -472,20 +341,6 @@ class FilesAppContext implements Context, ActorAwareInterface {
}
/**
- * @Then I see that the file list contains a file named :fileName
- */
- public function iSeeThatTheFileListContainsAFileNamed($fileName) {
- PHPUnit_Framework_Assert::assertNotNull($this->actor->find(self::rowForFile($fileName), 10));
- }
-
- /**
- * @Then I see that :fileName is marked as favorite
- */
- public function iSeeThatIsMarkedAsFavorite($fileName) {
- PHPUnit_Framework_Assert::assertNotNull($this->actor->find(self::favoritedStateIconForFile($fileName), 10));
- }
-
- /**
* @Then I see that the file name shown in the details view is :fileName
*/
public function iSeeThatTheFileNameShownInTheDetailsViewIs($fileName) {