@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Feature: 0064 - Salt SSH action chain
File name: minssh_action_chain.feature
Relative path: secondary/minssh_action_chain.feature
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Pre-requisite: downgrade repositories to lower version on SSH minion
When
I enable repository "test_repo_rpm_pool" on this "ssh_minion"
00:00:00.857
And
I remove package "andromeda-dummy" from this "ssh_minion" without error control
00:00:01.594
And
I remove package "virgo-dummy" from this "ssh_minion" without error control
00:00:01.603
And
I install package "milkyway-dummy" on this "ssh_minion" without error control
00:00:01.497
And
I install old package "andromeda-dummy-1.0" on this "ssh_minion"
00:00:01.917
And
I refresh the metadata for "ssh_minion"
00:00:00.979
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Pre-requisite: refresh package list and check newly installed packages on SSH minion
When
I refresh packages list via spacecmd on "ssh_minion"
00:00:07.876
And
I wait until refresh package list on "ssh_minion" is finished
00:00:29.649
Then
spacecmd should show packages "milkyway-dummy andromeda-dummy-1.0" installed on "ssh_minion"
00:00:07.369
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Pre-requisite: wait until downgrade is finished on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.683
When
I follow "Software" in the content area
00:00:00.069
And
I follow "List / Remove" in the content area
00:00:00.066
And
I enter "andromeda-dummy" as the filtered package name
00:00:00.228
And
I click on the filter button until page does contain "andromeda-dummy-1.0" text
00:00:00.291
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Pre-requisite: ensure the errata cache is computed before testing on SSH minion
When
I follow the left menu "Admin > Task Schedules"
00:00:00.155
And
I follow "errata-cache-default"
00:00:01.236
And
I follow "errata-cache-bunch"
00:00:01.309
And
I click on "Single Run Schedule"
00:00:01.544
Then
I should see a "bunch was scheduled" text
00:00:00.276
And
I wait until the table contains "FINISHED" or "SKIPPED" followed by "FINISHED" in its first rows
00:00:00.982
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Create a custom action chain for the SSH minion
When
I create an action chain with label "minssh_action_chain" via API
00:00:01.012
And
I follow the left menu "Schedule > Action Chains"
00:00:00.139
Then
I wait until I see "minssh_action_chain" text
00:00:00.082
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a patch installation to the action chain on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.755
When
I follow "Software" in the content area
00:00:00.068
And
I follow "Patches" in the content area
00:00:00.064
And
I enter "andromeda" as the filtered synopsis
00:00:00.043
And
I click on the filter button
00:00:10.130
And
I check "andromeda-dummy-6789" in the list
00:00:00.058
And
I click on "Apply Patches"
00:00:00.696
And
I check radio button "schedule-by-action-chain"
00:00:10.069
And
I click on "Confirm"
00:00:00.759
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.077
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a package removal to the action chain on SSH minion
When
I follow "Software" in the content area
00:00:00.071
And
I follow "List / Remove" in the content area
00:00:00.063
And
I enter "milkyway-dummy" as the filtered package name
00:00:00.191
And
I click on the filter button
00:00:00.831
And
I check row with "milkyway-dummy" and arch of "ssh_minion"
00:00:00.058
And
I click on "Remove Packages"
00:00:00.601
And
I check radio button "schedule-by-action-chain"
00:00:10.055
And
I click on "Confirm"
00:00:00.687
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.068
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a package installation to an action chain on SSH minion
When
I follow "Software" in the content area
00:00:00.072
And
I follow "Install New Packages" in the content area
00:00:00.064
And
I enter "virgo-dummy" as the filtered package name
00:00:00.100
And
I click on the filter button
00:00:00.631
And
I check "virgo-dummy" in the list
00:00:00.051
And
I click on "Install Packages"
00:00:00.579
And
I check radio button "schedule-by-action-chain"
00:00:10.046
And
I click on "Confirm"
00:00:01.011
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.064
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Create a configuration channel for testing action chain on SSH minion
When
I follow the left menu "Configuration > Channels"
00:00:00.128
And
I follow "Create Config Channel"
00:00:00.268
And
I enter "Action Chain Channel" as "cofName"
00:00:00.066
And
I enter "actionchainchannel" as "cofLabel"
00:00:00.062
And
I enter "This is a test channel" as "cofDescription"
00:00:00.063
And
I click on "Create Config Channel"
00:00:00.062
Then
I should see a "Action Chain Channel" text
00:00:00.609
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a configuration file to configuration channel for testing action chain on SSH minion
When
I follow the left menu "Configuration > Channels"
00:00:00.060
And
I follow "Action Chain Channel"
00:00:00.432
And
I follow "Create Configuration File or Directory"
00:00:00.404
And
I enter "/etc/action-chain.cnf" as "cffPath"
00:00:00.069
And
I enter "Testchain=YES_PLEASE" in the editor
00:00:00.004
And
I click on "Create Configuration File"
00:00:00.064
Then
I should see a "Revision 1 of /etc/action-chain.cnf from channel Action Chain Channel" text
00:00:00.659
And
I should see a "Update Configuration File" button
00:00:00.018
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Subscribe system to configuration channel for testing action chain on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.625
When
I follow "Configuration" in the content area
00:00:00.070
And
I follow "Manage Configuration Channels" in the content area
00:00:00.063
And
I follow first "Subscribe to Channels" in the content area
00:00:00.065
And
I check "Action Chain Channel" in the list
00:00:00.058
And
I click on "Continue"
00:00:00.579
And
I click on "Update Channel Rankings"
00:00:00.716
Then
I should see a "Channel Subscriptions successfully changed for" text
00:00:00.076
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a configuration file deployment to the action chain on SSH minion
When
I follow the left menu "Configuration > Channels"
00:00:00.114
And
I follow "Action Chain Channel"
00:00:00.436
And
I follow "Deploy Files" in the content area
00:00:00.065
And
I click on "Deploy All Files"
00:00:00.625
And
I check the "ssh_minion" client
00:00:00.057
And
I click on "Confirm & Deploy to Selected Systems"
00:00:00.590
And
I check radio button "schedule-by-action-chain"
00:00:10.073
And
I click on "Deploy Files to Selected Systems"
00:00:00.677
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.069
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add apply highstate to action chain on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.630
When
I follow "States" in the content area
00:00:00.069
And
I check radio button "schedule-by-action-chain"
00:00:10.079
And
I click on "Apply Highstate"
00:00:00.059
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a reboot action to the action chain on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.615
When
I follow first "Schedule System Reboot"
00:00:00.378
And
I check radio button "schedule-by-action-chain"
00:00:10.074
And
I click on "Reboot system"
00:00:00.791
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.090
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a remote command to the action chain on SSH minion
When
I follow "Details" in the content area
00:00:00.073
When
I follow "Remote Command" in the content area
00:00:00.066
And
I enter as remote command this script in
00:00:00.065
#!/bin/bash touch /tmp/action_chain_one_system_done
And
I check radio button "schedule-by-action-chain"
00:00:10.056
And
I click on "Schedule"
00:00:00.055
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.541
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Verify the action chain list on SSH minion
When
I follow the left menu "Schedule > Action Chains"
00:00:00.134
And
I follow "minssh_action_chain"
00:00:00.321
Then
I should see a "1. Apply patch(es) andromeda-dummy-6789 on 1 system" text
00:00:00.083
And
I should see a "2. Remove milkyway-dummy from 1 system" text
00:00:00.080
And
I should see a "3. Install or update virgo-dummy on 1 system" text
00:00:00.082
And
I should see a text like "4. Deploy.*/etc/action-chain.cnf.*to 1 system"
00:00:00.083
And
I should see a "5. Apply Highstate" text
00:00:00.082
And
I should see a "6. Reboot 1 system" text
00:00:00.078
And
I should see a "7. Run a remote command on 1 system" text
00:00:00.079
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Check that a different user cannot see the action chain for SSH minion
Given
I am authorized as "testing" with password "testing"
00:00:02.125
When
I follow the left menu "Schedule > Action Chains"
00:00:00.115
Then
I should not see a "minssh_action_chain" link
00:00:00.008
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Execute the action chain from the web UI on SSH minion
Given
I am authorized for the "Admin" section
00:00:02.425
When
I follow the left menu "Schedule > Action Chains"
00:00:00.107
And
I wait until I see "minssh_action_chain" text
00:00:00.078
And
I follow "minssh_action_chain"
00:00:00.293
Then
I click on "Save and Schedule"
00:00:00.057
And
I should see a "Action Chain minssh_action_chain has been scheduled for execution." text
00:00:00.642
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Verify that the action chain was executed successfully
When
I wait for "virgo-dummy" to be installed on "ssh_minion"
00:00:54.754
And
I wait at most 300 seconds until file "/tmp/action_chain_one_system_done" exists on "ssh_minion"
00:05:01.101
+ Show Error
+ Screenshot
Timeout after 300 seconds (repeat_until_timeout) (Timeout::Error) ./features/support/commonlib.rb:107:in `block in repeat_until_timeout' ./features/support/commonlib.rb:89:in `repeat_until_timeout' ./features/step_definitions/command_steps.rb:822:in `/^I wait at most (\d+) seconds until file "([^"]*)" exists on "([^"]*)"$/' features/secondary/minssh_action_chain.feature:177:in `I wait at most 300 seconds until file "/tmp/action_chain_one_system_done" exists on "ssh_minion"'
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Create a custom action chain for the SSH minion
When
I create an action chain with label "minssh_action_chain_to_delete" via API
00:00:01.014
And
I follow the left menu "Schedule > Action Chains"
00:00:00.074
Then
I should see a "minssh_action_chain_to_delete" text
00:00:00.074
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add a remote command to the action chain on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.751
When
I follow "Remote Command"
00:00:00.498
And
I enter as remote command this script in
00:00:00.053
#!/bin/bash uptime
And
I check radio button "schedule-by-action-chain"
00:00:10.070
And
I click on "Schedule"
00:00:00.056
Then
I should see a "Action has been successfully added to the Action Chain" text
00:00:00.588
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Delete the action chain for SSH minion
When
I follow the left menu "Schedule > Action Chains"
00:00:00.121
And
I follow "minssh_action_chain_to_delete"
00:00:00.296
And
I follow "Delete Action Chains" in the content area
00:00:00.071
Then
I click on "Delete"
00:00:00.447
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Cleanup: roll back action chain effects on SSH minion
Given
I am on the Systems overview page of this "ssh_minion"
00:00:01.723
When
I run "rm /tmp/action_chain_done" on "ssh_minion" without error control
00:00:00.566
And
I enable repository "test_repo_rpm_pool" on this "ssh_minion"
00:00:00.708
And
I remove package "andromeda-dummy" from this "ssh_minion" without error control
00:00:02.436
And
I remove package "virgo-dummy" from this "ssh_minion" without error control
00:00:01.751
And
I install package "milkyway-dummy" on this "ssh_minion" without error control
00:00:02.065
And
I install old package "andromeda-dummy-1.0" on this "ssh_minion"
00:00:01.760
And
I follow "Software" in the content area
00:00:00.069
And
I click on "Update Package List"
00:00:00.588
And
I follow "Events" in the content area
00:00:00.067
And
I wait until I do not see "Package List Refresh scheduled" text, refreshing the page
00:00:24.478
And
I follow "Software" in the content area
00:00:00.086
And
I follow "List / Remove" in the content area
00:00:00.075
And
I enter "andromeda-dummy" as the filtered package name
00:00:00.203
And
I click on the filter button until page does contain "andromeda-dummy-1.0" text
00:00:00.288
When
I follow the left menu "Admin > Task Schedules"
00:00:00.151
And
I follow "errata-cache-default"
00:00:01.224
And
I follow "errata-cache-bunch"
00:00:01.312
And
I click on "Single Run Schedule"
00:00:01.260
Then
I should see a "bunch was scheduled" text
00:00:00.282
And
I wait until the table contains "FINISHED" or "SKIPPED" followed by "FINISHED" in its first rows
00:00:45.488
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Add operations to the action chain via API for SSH minions
Given
I want to operate on this "ssh_minion"
00:00:00.967
When
I create an action chain with label "minssh_api_chain" via API
00:00:00.958
And
I add a package install to the action chain via API
00:00:02.039
And
I add a package removal to the action chain via API
00:00:02.038
And
I add a package upgrade to the action chain via API
00:00:02.462
And
I add the script "exit 1;" to the action chain via API
00:00:01.214
Running actions: - Run an arbitrary script - Package Install/Upgrade - Package Removal - Package Install/Upgrade
- Removed "Run an arbitrary script" action - Removed "Package Install/Upgrade" action - Removed "Package Removal" action - Removed "Package Install/Upgrade" action
Then
the current action chain should be empty
00:00:00.965
And
I delete the action chain via API
00:00:00.962
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Run an action chain via API on SSH minion
And
I want to operate on this "ssh_minion"
00:00:00.952
When
I create an action chain with label "minssh_multiple_scripts" via API
00:00:01.010
And
I add the script "echo -n 1 >> /tmp/action_chain.log" to the action chain via API
00:00:01.090
And
I add the script "echo -n 2 >> /tmp/action_chain.log" to the action chain via API
00:00:00.975
And
I add the script "echo -n 3 >> /tmp/action_chain.log" to the action chain via API
00:00:00.966
And
I add the script "touch /tmp/action_chain_done" to the action chain via API
00:00:01.032
Running actions: - Run an arbitrary script - Run an arbitrary script - Run an arbitrary script - Run an arbitrary script
When
I schedule the action chain via API
00:00:01.132
Then
I wait until there are no more action chains listed via API
00:00:01.014
When
I wait until file "/tmp/action_chain_done" exists on "ssh_minion"
00:00:26.412
Then
file "/tmp/action_chain.log" should contain "123" on "ssh_minion"
00:00:00.927
When
I wait until there are no more scheduled actions listed via API
00:00:01.703
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Cleanup: remove SSH minion from configuration channel
When
I follow the left menu "Configuration > Channels"
00:00:00.158
And
I follow "Action Chain Channel"
00:00:01.060
And
I follow "Systems" in the content area
00:00:00.066
And
I check the "ssh_minion" client
00:00:00.063
And
I click on "Unsubscribe systems"
00:00:01.272
Then
I should see a "Successfully unsubscribed 1 system(s)." text
00:00:00.062
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Cleanup: remove configuration channel for SSH minion
When
I follow the left menu "Configuration > Channels"
00:00:00.070
And
I follow "Action Chain Channel"
00:00:00.645
And
I follow "Delete Channel"
00:00:00.456
And
I click on "Delete Config Channel"
00:00:00.057
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Cleanup: remove packages and repository used in action chain for SSH minion
When
I remove package "andromeda-dummy" from this "ssh_minion" without error control
00:00:02.165
And
I remove package "virgo-dummy" from this "ssh_minion" without error control
00:00:01.093
And
I remove package "milkyway-dummy" from this "ssh_minion" without error control
00:00:01.962
And
I disable repository "test_repo_rpm_pool" on this "ssh_minion" without error control
00:00:00.721
@skip_if_github_validation
@ssh_minion
@scope_action_chains
@scope_salt_ssh
Scenario: Cleanup: remove temporary files for testing action chains on SSH minion
When
I run "rm -f /tmp/action_chain.log" on "ssh_minion" without error control
00:00:00.512
And
I run "rm -f /tmp/action_chain_done" on "ssh_minion" without error control
00:00:00.576
And
I run "rm -f /etc/action-chain.cnf" on "ssh_minion" without error control
00:00:00.618
And
I run "rm -f /tmp/action_chain_one_system_done" on "ssh_minion" without error control
00:00:00.682