From 7eeb91880a9346311bd05a1251e2d0ef6f94dae7 Mon Sep 17 00:00:00 2001 From: Aaron Carlino Date: Fri, 15 Jun 2018 11:28:40 +1200 Subject: [PATCH] Shift behat test from framework to admin (#8172) --- .travis.yml | 33 +----- behat.yml | 34 ------ tests/behat/README.md | 1 - tests/behat/_manifest_exclude | 0 tests/behat/features/files/document.pdf | Bin 18810 -> 0 bytes tests/behat/features/files/file1.jpg | Bin 2292 -> 0 bytes tests/behat/features/files/file2.jpg | Bin 3886 -> 0 bytes tests/behat/features/files/testfile.jpg | Bin 4477 -> 0 bytes tests/behat/features/login.feature | 35 ------ tests/behat/features/lostpassword.feature | 22 ---- tests/behat/features/manage-users.feature | 74 ------------- tests/behat/features/profile.feature | 62 ----------- tests/behat/features/reauthenticate.feature | 37 ------- .../features/security-permissions.feature | 85 --------------- tests/behat/travis-upload-artifacts.php | 102 ------------------ 15 files changed, 2 insertions(+), 483 deletions(-) delete mode 100644 behat.yml delete mode 100644 tests/behat/README.md delete mode 100644 tests/behat/_manifest_exclude delete mode 100644 tests/behat/features/files/document.pdf delete mode 100644 tests/behat/features/files/file1.jpg delete mode 100644 tests/behat/features/files/file2.jpg delete mode 100644 tests/behat/features/files/testfile.jpg delete mode 100644 tests/behat/features/login.feature delete mode 100644 tests/behat/features/lostpassword.feature delete mode 100644 tests/behat/features/manage-users.feature delete mode 100644 tests/behat/features/profile.feature delete mode 100644 tests/behat/features/reauthenticate.feature delete mode 100644 tests/behat/features/security-permissions.feature delete mode 100644 tests/behat/travis-upload-artifacts.php diff --git a/.travis.yml b/.travis.yml index e94706d0d..70e8be4a5 100644 --- a/.travis.yml +++ b/.travis.yml @@ -2,10 +2,6 @@ language: php dist: trusty -before_install: - - sudo apt-get update - - sudo apt-get install chromium-chromedriver - cache: directories: - $HOME/.composer/cache/files @@ -14,15 +10,10 @@ addons: apt: packages: - tidy - firefox: "31.0" env: global: - COMPOSER_ROOT_VERSION=4.2.x-dev - - DISPLAY=":99" - - XVFBARGS=":99 -ac -screen 0 1024x768x16" - - SS_BASE_URL="http://localhost:8080/" - - SS_ENVIRONMENT_TYPE="dev" matrix: fast_finish: true @@ -52,18 +43,10 @@ matrix: - DB=MYSQL - PDO=1 - PHPUNIT_TEST=framework - - php: 7.0 - env: - - DB=MYSQL - - BEHAT_TEST=framework - php: 7.0 env: - DB=MYSQL - PHPUNIT_TEST=cms - - php: 7.0 - env: - - DB=MYSQL - - BEHAT_TEST=cms allow_failures: - php: nightly env: @@ -74,7 +57,6 @@ matrix: before_script: # Extra $PATH - export PATH=~/.composer/vendor/bin:$PATH - - export PATH=/usr/lib/chromium-browser/:$PATH # Init PHP - pecl channel-update pecl.php.net @@ -88,26 +70,17 @@ before_script: - if [[ $DB == PGSQL ]]; then composer require silverstripe/postgresql:2.0.x-dev --no-update; fi - if [[ $DB == SQLITE ]]; then composer require silverstripe/sqlite3:2.0.x-dev --no-update; fi - composer require silverstripe/recipe-testing:^1 silverstripe/recipe-core:4.2.x-dev silverstripe/admin:1.2.x-dev silverstripe/versioned:1.2.x-dev --no-update - - if [[ $PHPUNIT_TEST == cms ]] || [[ $BEHAT_TEST == cms ]]; then composer require silverstripe/recipe-cms:4.2.x-dev --no-update; fi + - if [[ $PHPUNIT_TEST == cms ]]; then composer require silverstripe/recipe-cms:4.2.x-dev --no-update; fi - if [[ $PHPCS_TEST ]]; then composer global require squizlabs/php_codesniffer:^3 --prefer-dist --no-interaction --no-progress --no-suggest -o; fi - - composer install --prefer-source --no-interaction --no-progress --no-suggest --optimize-autoloader --verbose --profile + - composer install --prefer-dist --no-interaction --no-progress --no-suggest --optimize-autoloader --verbose --profile # Log constants to CI for debugging purposes - php ./tests/dump_constants.php -# Start behat services - - if [[ $BEHAT_TEST ]]; then mkdir artifacts; fi - - if [[ $BEHAT_TEST ]]; then cp composer.lock artifacts/; fi - - if [[ $BEHAT_TEST ]]; then sh -e /etc/init.d/xvfb start; sleep 3; fi - - if [[ $BEHAT_TEST ]]; then (chromedriver > artifacts/chromedriver.log 2>&1 &); fi - - if [[ $BEHAT_TEST == framework ]]; then (vendor/bin/serve --bootstrap-file tests/behat/serve-bootstrap.php &> artifacts/serve.log &); fi - - if [[ $BEHAT_TEST == cms ]]; then (vendor/bin/serve --bootstrap-file vendor/silverstripe/cms/tests/behat/serve-bootstrap.php &> artifacts/serve.log &); fi script: - if [[ $PHPUNIT_TEST ]]; then vendor/bin/phpunit --testsuite $PHPUNIT_TEST; fi - if [[ $PHPUNIT_COVERAGE_TEST ]]; then phpdbg -qrr vendor/bin/phpunit --testsuite $PHPUNIT_COVERAGE_TEST --coverage-clover=coverage.xml; fi - - if [[ $BEHAT_TEST == framework ]]; then vendor/bin/behat @framework; fi - - if [[ $BEHAT_TEST == cms ]]; then vendor/bin/behat @cms; fi - if [[ $PHPCS_TEST ]]; then composer run-script lint; fi - if [[ $PHPCS_TEST ]]; then composer run-script php-peg; fi - if [[ $PHPCS_TEST ]]; then git diff-files --quiet -w --relative=src; fi @@ -116,5 +89,3 @@ script: after_success: - if [[ $PHPUNIT_COVERAGE_TEST ]]; then bash <(curl -s https://codecov.io/bash) -f coverage.xml; fi -after_failure: - - if [[ $BEHAT_TEST ]]; then php ./tests/behat/travis-upload-artifacts.php --if-env BEHAT_TEST,ARTIFACTS_BUCKET,ARTIFACTS_KEY,ARTIFACTS_SECRET --target-path $TRAVIS_REPO_SLUG/$TRAVIS_BUILD_ID/$TRAVIS_JOB_ID --artifacts-base-url https://s3.amazonaws.com/$ARTIFACTS_BUCKET/ --artifacts-path ./artifacts/; fi diff --git a/behat.yml b/behat.yml deleted file mode 100644 index f6d329195..000000000 --- a/behat.yml +++ /dev/null @@ -1,34 +0,0 @@ -# Run framework behat tests with this command (installed with silverstripe/installer) -# Note that framework behat tests require CMS module -# ========================================================================= # -# vendor/bin/selenium-server-standalone -Dwebdriver.firefox.bin="/Applications/Firefox31.app/Contents/MacOS/firefox-bin" -# vendor/bin/serve --bootstrap-file vendor/silverstripe/framework/tests/behat/serve-bootstrap.php -# vendor/bin/behat @framework -# ========================================================================= # -default: - suites: - framework: - paths: - - %paths.modules.framework%/tests/behat/features - contexts: - - SilverStripe\Framework\Tests\Behaviour\FeatureContext - - SilverStripe\Framework\Tests\Behaviour\CmsFormsContext - - SilverStripe\Framework\Tests\Behaviour\CmsUiContext - - SilverStripe\BehatExtension\Context\BasicContext - - SilverStripe\BehatExtension\Context\EmailContext - - SilverStripe\BehatExtension\Context\LoginContext - - - SilverStripe\BehatExtension\Context\FixtureContext: - - %paths.modules.framework%/tests/behat/features/files/ - - extensions: - SilverStripe\BehatExtension\MinkExtension: - default_session: facebook_web_driver - javascript_session: facebook_web_driver - facebook_web_driver: - browser: chrome - wd_host: "http://127.0.0.1:9515" #chromedriver port - - SilverStripe\BehatExtension\Extension: - screenshot_path: %paths.base%/artifacts/screenshots - bootstrap_file: "tests/behat/serve-bootstrap.php" diff --git a/tests/behat/README.md b/tests/behat/README.md deleted file mode 100644 index e072aec9f..000000000 --- a/tests/behat/README.md +++ /dev/null @@ -1 +0,0 @@ -See https://github.com/silverstripe-labs/silverstripe-behat-extension \ No newline at end of file diff --git a/tests/behat/_manifest_exclude b/tests/behat/_manifest_exclude deleted file mode 100644 index e69de29bb..000000000 diff --git a/tests/behat/features/files/document.pdf b/tests/behat/features/files/document.pdf deleted file mode 100644 index c01805e89c1684e79130151abc23bb80401583a9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18810 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 diff --git a/tests/behat/features/files/file1.jpg b/tests/behat/features/files/file1.jpg deleted file mode 100644 index beb5a91b0aba93d3b54dadc12cff0104307d718e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2292 zcmbV~c|6qJ9>;%UHjExS$z>*csbTDTlq4fO5~U_1OJm>1u4{=xiK_^q9w8LDu4RZU z8557($~v-CGowgKGnQ!>GxN;U>viux_m6w;=e)k(*IB;jygu)9j^K@e2FN&K9k2ih z1OOmm0|b2FS6eqbn=>wMhfslj2ScL#15xo9v>{3_E+#l45ar-#k8(U^XOD_EGun3m zMU3+e3yw`f9Y$H2N($xxTR;pXk|>Lb1ObaO6aoQ5U{DzBN5Cb-VQ>jJ3?_~cmyi@m z*pos?N{I%dLw;@*gMz_ONjMDtqvU@|f@grNIA8=Afk7I8m@Eh^3ldNOq!1GN!=8}z zr$Az02owev+CT^kNHRkEV6f0MROnb(og!QZAhJ-oy%-yqysIxV&@@|zq+B&*=`}UidnweWz9W@cqyyPi`}c)O^$RrQ0K+Pa62>RVddNbMa@I=jdNl;?v( ze+<7EpO~DYPQRI%r85>jd|X`mwEUU1w!X2+{?6Ij7IA?9@J}pZ{*PR;LM}1U8^A?e zAh85tfMp@jy%?CBjVs)jD6e6ZF0OFwR%LU)gr>0@Q}JT-n52@H30<2dLi<7X-+^WP zUu6FR`#0AtAO!{q9}g@GSOYtk7S!~}8_$uB+tPfA6|UScm#}l9_X_1u&tL^TQrcdj z>+Q>0tL3s|#Fe0ldmx9gHPI4kJ)~!b1g|z(yjN8XLXuJS` zbkD^*z5G3tsmzY%^l%+H!&dUleDZ1USK^@~9a{$<->ldybWF6F1{a6<+N$d#8AAgp zF*E@{=}DkRUa!e;;(^bU4KCsXbS(Fn>-RVSUwuF-0BsG#=yT*B;m`NAB6s9h`d>5U z*+I!zwFZ}WM9j}@ilS9JY$m9{% zsipE$tY6wzt5%oilB;$vxZ$B)^iwIL(cE|@3X!9 zbDTr53I6Tz7Vf2L?$z^&yIy=qePSj`q;Sh*>J)8~lG@3xHx8B!&?D3*4f z(16K+;)d7>XX`?zlMS|;WkY<4M_lzC8P1ia)Nya69S5E28twV6Tr)4-C%HIWYv;`p zTFU*5sQNAVW%oH)uPc)2`u@gP@{ucS0`FF`%&cKK#iMe(X=8+7xbU!S*y$YfG} zd!*;~%s9DPl~}k|wAj%YqC~`n?CF_g;&br>rUQqLThBn~X_7ouUO~4nSB>9a(PEyR zYQ=fM82>hyYA~Vx>0tfi*&?c+Ki5RkW%Z(S<%R3+=sK-?4c_)yg9C<->6uQuAmw+P z;wM73KYb_lJxGnY^I^(JN-JdXWKvPmD@={^;Mhq_QF-2Mi*u)0MeW*Q7fLY8e88IN z^iAG|>;KtsJ~5jw^VZJ5gK<0w(h{lU`qbdX1UyJtlhZtGsk?^cL-gmUr7TrLk#9c^FourW>LL;vTauCJy%?{X4MKQ47hT0+*~|arf=qg$=ZZpIf=5s9ayg_A#PN4J0T-0M|ZS11V(s}GqPVIYIU|8(Oode6acclYO}%9{6kE$M-OZo=C-yyXY&dv9s5YCdN`?_7VMjq_Tz_D9N2jX zzNGAes%lE4CzY=jq&&-;{#(iOONt{y(Z$;lRgq|eJwDf?YF;?+-#s=ml&N7?n6uuL zpVn4EF_<;__FFG&W&dz3x&Q30liRolrQ=!!#9c2b&2z2S2nX6%6as@lfIEU1*V(9j zzpO4?`p6JhBgZU%O|S6;>{IIPs}&x4_u)R5T+^5B6oBju%(2V%8aaBvvke7TJ0MLk F^Cu<`6}$id diff --git a/tests/behat/features/files/file2.jpg b/tests/behat/features/files/file2.jpg deleted file mode 100644 index fc834a452aa216fd7c7816e71877b9d10da6f7c4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3886 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 diff --git a/tests/behat/features/login.feature b/tests/behat/features/login.feature deleted file mode 100644 index e9ba96832..000000000 --- a/tests/behat/features/login.feature +++ /dev/null @@ -1,35 +0,0 @@ -@retry -Feature: Log in - As an site owner - I want to access to the CMS to be secure - So that only my team can make content changes - - Scenario: Bad login - Given I log in with "bad@example.com" and "badpassword" - Then I should see "The provided details don't seem to be correct" - - Scenario: Valid login - Given I am logged in with "ADMIN" permissions - When I go to "/admin/" - Then I should see the CMS - - Scenario: /admin/ redirect for not logged in user - # disable automatic redirection so we can use the profiler - When I go to "/admin/" - And I should see a log-in form - - Scenario: Logout without token - Given I am logged in with "ADMIN" permissions - When I go to "/Security/logout" - Then I should see a log-out form - When I press the "Log out" button - And I go to "/admin/" - Then I should see a log-in form - - Scenario: Log in as someone else - Given I am logged in with "ADMIN" permissions - When I go to "/Security/login" - Then the response should contain "Log in as someone else" - - When I press the "Log in as someone else" button - Then I should see a log-in form diff --git a/tests/behat/features/lostpassword.feature b/tests/behat/features/lostpassword.feature deleted file mode 100644 index 3467472df..000000000 --- a/tests/behat/features/lostpassword.feature +++ /dev/null @@ -1,22 +0,0 @@ -@retry -Feature: Lost Password - As a site owner - I want to be able to reset my password - Using my email - - Background: - Given a "member" "Admin" with "Email"="admin@example.org" - - Scenario: I can request a password reset by email - Given I go to "Security/login" - When I follow "I've lost my password" - And I fill in "admin@example.org" for "Email" - And I press the "Send me the password reset link" button - Then I should see "A reset link has been sent to 'admin@example.org'" - And there should be an email to "admin@example.org" titled "Your password reset link" - When I click on the "password reset link" link in the email to "admin@example.org" - Then I should see "Please enter a new password" - When I fill in "newpassword" for "New Password" - And I fill in "newpassword" for "Confirm New Password" - And I press the "Change Password" button - Then the password for "admin@example.org" should be "newpassword" diff --git a/tests/behat/features/manage-users.feature b/tests/behat/features/manage-users.feature deleted file mode 100644 index d03fd677e..000000000 --- a/tests/behat/features/manage-users.feature +++ /dev/null @@ -1,74 +0,0 @@ -@javascript @retry -Feature: Manage users - As a site administrator - I want to create and manage user accounts on my site - So that I can control access to the CMS - - Background: - Given a "member" "ADMIN" belonging to "ADMIN group" with "Email"="admin@example.org" - And the "member" "ADMIN" belonging to "ADMIN group2" - And a "member" "Staff" belonging to "Staff group" with "Email"="staffmember@example.org" - And the "group" "ADMIN group" has permissions "Full administrative rights" - And the "group" "ADMIN group2" has permissions "Full administrative rights" - And I am logged in with "ADMIN" permissions - And I go to "/admin/security" - - - Scenario: I cannot remove my admin access, but can remove myself from an admin group - When I click the "Groups" CMS tab - And I click "ADMIN group" in the "#Root_Groups" element - And I should see the "Unlink" button in the "Members" gridfield for the "ADMIN" row - Then I click "Groups" in the ".breadcrumbs-wrapper" element - And I click the "Groups" CMS tab - And I click "ADMIN group2" in the "#Root_Groups" element - And I should see the "Unlink" button in the "Members" gridfield for the "ADMIN" row - Then I click the "Unlink" button in the "Members" gridfield for the "ADMIN" row - And I should not see the "Unlink" button in the "Members" gridfield for the "ADMIN" row - Then I click "Groups" in the ".breadcrumbs-wrapper" element - And I click the "Groups" CMS tab - And I click "ADMIN group" in the "#Root_Groups" element - And I should not see the "Unlink" button in the "Members" gridfield for the "ADMIN" row - - Scenario: I can list all users regardless of group - When I click the "Users" CMS tab - Then I should see "admin@example.org" in the "#Root_Users" element - And I should see "staffmember@example.org" in the "#Root_Users" element - - Scenario: I can list all users in a specific group - When I click the "Groups" CMS tab - # TODO Please check how performant this is - And I click "ADMIN group" in the "#Root_Groups" element - Then I should see "admin@example.org" in the "#Root_Members" element - And I should not see "staffmember@example.org" in the "#Root_Members" element - - Scenario: I can add a user to the system - When I click the "Users" CMS tab - And I press the "Add Member" button - And I fill in the following: - | First Name | John | - | Surname | Doe | - | Email | john.doe@example.org | - And I press the "Create" button - Then I should see a "Saved member" message - - When I go to "admin/security/" - Then I should see "john.doe@example.org" in the "#Root_Users" element - - Scenario: I can edit an existing user and add him to an existing group - When I click the "Users" CMS tab - And I click "staffmember@example.org" in the "#Root_Users" element - And I select "ADMIN group" from "Groups" - And I press the "Apply changes" button - Then I should see a "Saved Member" message - - When I go to "admin/security" - And I click the "Groups" CMS tab - And I click "ADMIN group" in the "#Root_Groups" element - Then I should see "staffmember@example.org" - - Scenario: I can delete an existing user - When I click the "Users" CMS tab - And I click "staffmember@example.org" in the "#Root_Users" element - And I press the "Delete" button, confirming the dialog - Then I should see "admin@example.org" - And I should not see "staffmember@example.org" diff --git a/tests/behat/features/profile.feature b/tests/behat/features/profile.feature deleted file mode 100644 index ffa28f367..000000000 --- a/tests/behat/features/profile.feature +++ /dev/null @@ -1,62 +0,0 @@ -@retry -Feature: Manage my own settings - As a CMS user - I want to be able to change personal settings - In order to streamline my CMS experience - - Background: - Given a "member" "Joe" belonging to "Admin group" with "Email"="joe@example.org" and "Password"="secret" - And the "group" "Admin group" has permissions "Full administrative rights" - And the "member" "Joe" belonging to "Admin group2" - And the "group" "Admin group2" has permissions "Full administrative rights" - And I log in with "joe@example.org" and "secret" - And I go to "admin/myprofile" - - Scenario: I cannot remove all my admin groups - When I click the "Admin group" option in the "DirectGroups" listbox - And I click the "Admin group2" option in the "DirectGroups" listbox - And I press the "Save" button - Then I should see "Cannot remove all admin groups from your profile" in the "#Form_EditForm" element - - Scenario: I can remove one of my admin groups - When I click the "Admin group" option in the "DirectGroups" listbox - And I press the "Save" button - Then I should see a "Saved" notice - And I should not see "Cannot remove all admin groups from your profile" in the "#Form_EditForm" element - - Scenario: I can edit my personal details - Given I fill in "First Name" with "Jack" - And I fill in "Surname" with "Johnson" - And I fill in "Email" with "jack@example.org" - When I press the "Save" button - Given I go to "admin/myprofile" - Then I should not see "Joe" - Then I should see "Jack" - And I should see "Johnson" - - Scenario: I can't reset the password without the original - Given I follow "Change Password" - And I fill in "Current Password" with "idontknow" - And I fill in "New Password" with "newsecret" - And I fill in "Confirm Password" with "newsecret" - And I press the "Save" button - Then I should see "The current password you have entered is not correct." - - Scenario: I can change my password - Given I follow "Change Password" - And I fill in "Current Password" with "secret" - And I fill in "New Password" with "newsecret" - And I fill in "Confirm Password" with "newsecret" - And I press the "Save" button - And I am not logged in - When I log in with "joe@example.org" and "newsecret" - And I go to "admin/myprofile" - Then I should see the CMS - - Scenario: I can change the interface language - And I select "German (Germany)" from "Interface Language" - And I press the "Save" button - Then I should see "Sprache" - - # TODO Date/time format - Difficult because its not exposed anywhere in the CMS? - # TODO Group modification as ADMIN user diff --git a/tests/behat/features/reauthenticate.feature b/tests/behat/features/reauthenticate.feature deleted file mode 100644 index 236c2d851..000000000 --- a/tests/behat/features/reauthenticate.feature +++ /dev/null @@ -1,37 +0,0 @@ -@modal @retry -Feature: Reauthenticate - As a content editor - I want to be able to log in through a CMS popup when my session expires - So that I can avoid losing unsaved work - - Background: - And I am logged in with "ADMIN" permissions - And I go to "/admin/security" - And I am not in an iframe - And I click the "Users" CMS tab - And my session expires - - Scenario: Reauthenticate with correct login - When I press the "Add Member" button - And I switch to the "login-dialog-iframe" iframe - Then I should see "Your session has timed out due to inactivity" in the ".cms-security__container" element - When I fill in "Password" with "Secret!123" - And I press the "Let me back in" button - And I am not in an iframe - And I go to "/admin/security" - When I press the "Add Member" button - Then I should see "Create" in the "#Form_ItemEditForm_action_doSave" element - - Scenario: Reauthenticate with wrong login - When I press the "Add Member" button - And I switch to the "login-dialog-iframe" iframe - Then I should see "Your session has timed out due to inactivity" in the ".cms-security__container" element - When I fill in "Password" with "wrong password" - And I press the "Let me back in" button - Then I should see "The provided details don't seem to be correct. Please try again." - When I fill in "Password" with "Secret!123" - And I press the "Let me back in" button - And I am not in an iframe - And I go to "/admin/security" - When I press the "Add Member" button - Then I should see "Create" in the "#Form_ItemEditForm_action_doSave" element diff --git a/tests/behat/features/security-permissions.feature b/tests/behat/features/security-permissions.feature deleted file mode 100644 index ba57b25e0..000000000 --- a/tests/behat/features/security-permissions.feature +++ /dev/null @@ -1,85 +0,0 @@ -@javascript @retry -Feature: Manage Security Permissions for Groups - As a site administrator - I want to control my user's security permissions in an intuitive way - So that I can easily control access to the CMS - - Background: - Given a "group" "test group" - And a "member" "ADMIN" belonging to "ADMIN group" with "Email"="admin@example.org" - And the "group" "ADMIN group" has permissions "Full administrative rights" - And I am logged in with "ADMIN" permissions - And I go to "/admin/security" - And I click the "Groups" CMS tab - And I click on "test group" in the "Groups" table - And I click the "Permissions" CMS tab - - Scenario: I can see sub-permissions being properly set and restored when using "Access to all CMS sections" - When I check "Access to all CMS sections" - Then the "Access to 'Security' section" checkbox should be checked - And the "Access to 'Security' section" field should be disabled - - When I uncheck "Access to all CMS sections" - Then the "Access to 'Security' section" checkbox should not be checked - And the "Access to 'Security' section" field should be enabled - - When I check "Access to 'Security' section" - And I check "Access to all CMS sections" - When I uncheck "Access to all CMS sections" - Then the "Access to 'Security' section" checkbox should be checked - - # Save so the driver can reset without having to deal with the popup alert. - Then I press the "Apply changes" button - - Scenario: I can see sub-permissions being properly set and restored when using "Full administrative rights" - When I check "Access to 'Security' section" - And I check "Full administrative rights" - Then the "Access to all CMS sections" checkbox should be checked - And the "Access to all CMS sections" field should be disabled - And the "Access to 'Security' section" checkbox should be checked - And the "Access to 'Security' section" field should be disabled - - And I uncheck "Full administrative rights" - Then the "Access to all CMS sections" checkbox should not be checked - And the "Access to all CMS sections" field should be enabled - And the "Access to 'Security' section" checkbox should be checked - And the "Access to 'Security' section" field should be enabled - - # Save so the driver can reset without having to deal with the popup alert. - Then I press the "Apply changes" button - - Scenario: I can see sub-permissions being handled properly between reloads when using "Full administrative rights" - When I check "Full administrative rights" - And I press the "Apply changes" button - And I click the "Permissions" CMS tab - Then the "Full administrative rights" checkbox should be checked - And the "Access to 'Security' section" checkbox should be checked - And the "Access to 'Security' section" field should be disabled - - When I uncheck "Full administrative rights" - Then the "Access to 'Security' section" checkbox should not be checked - And the "Access to 'Security' section" field should be enabled - - When I press the "Apply changes" button - And I click the "Permissions" CMS tab - Then the "Full administrative rights" checkbox should not be checked - And the "Access to 'Security' section" checkbox should not be checked - And the "Access to 'Security' section" field should be enabled - - Scenario: I can see sub-permissions being handled properly between reloads when using "Access to all CMS sections" - When I check "Access to all CMS sections" - And I press the "Apply changes" button - And I click the "Permissions" CMS tab - Then the "Access to all CMS sections" checkbox should be checked - And the "Access to 'Security' section" checkbox should be checked - And the "Access to 'Security' section" field should be disabled - - When I uncheck "Access to all CMS sections" - Then the "Access to 'Security' section" checkbox should not be checked - And the "Access to 'Security' section" field should be enabled - - When I press the "Apply changes" button - And I click the "Permissions" CMS tab - Then the "Access to all CMS sections" checkbox should not be checked - And the "Access to 'Security' section" checkbox should not be checked - And the "Access to 'Security' section" field should be enabled diff --git a/tests/behat/travis-upload-artifacts.php b/tests/behat/travis-upload-artifacts.php deleted file mode 100644 index d5d1b2569..000000000 --- a/tests/behat/travis-upload-artifacts.php +++ /dev/null @@ -1,102 +0,0 @@ -#!/usr/bin/env php - 0) { - die($returnVar); - } -} - -/** - * Check if an env variable is set - * - * @param $envs - * @return bool - */ -function checkenv($envs) -{ - if ($envs) { - foreach (explode(',', $envs) as $env) { - if (!getenv($env)) { - return false; - } - } - } - return true; -} - -$opts = getopt('', array( - 'artifacts-path:', - 'target-path:', - 'if-env:', - 'artifacts-base-url:', -)); - -// --if-env=BEHAT_TEST means that this script will only be executed if the given environment var is set -if (empty($opts['if-env'])) { - echo "--if-env option is mandatory"; - exit(0); -} -if (!checkenv($opts['if-env'])) { - echo "Apache skipped; {$opts['if-env']} wasn't set.\n"; - exit(0); -} - -if (isset($opts['artifacts-path'])) { - $artifactsPath = $opts['artifacts-path']; -} elseif (is_dir(__DIR__ . '/artifacts/')) { - $artifactsPath = __DIR__ . '/artifacts/'; -} elseif (is_dir('~/artifacts/')) { - $artifactsPath = '~/artifacts/'; -} else { - $artifactsPath = null; -} - -$targetPath = $opts['target-path']; -$baseUrl = $opts['artifacts-base-url']; - -if (!$artifactsPath || !is_dir($artifactsPath)) { - echo "No artifacts found, skipped\n"; - exit(0); -} - -echo "Installing artifacts script to ~/bin/artifacts\n"; -run("curl -sL https://raw.githubusercontent.com/travis-ci/artifacts/master/install | bash"); - -echo "Creating {$artifactsPath}index.html...\n"; - -$html = ''; - -file_put_contents("{$artifactsPath}index.html", $html); - -run("~/bin/artifacts upload --permissions public-read --target-paths $targetPath $artifactsPath"); - -$fullPath = str_replace('//', '/', "$baseUrl/$targetPath/index.html"); -$fullPath = str_replace('https:/s3', 'https://s3', $fullPath); -echo "Uploaded artifacts to $fullPath\n";