aruba 0.14.14 → 1.0.0.pre.alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.cucumberproignore +3 -0
- data/.github/ISSUE_TEMPLATE.md +48 -0
- data/.github/PULL_REQUEST_TEMPLATE.md +39 -0
- data/.gitignore +1 -0
- data/.rspec +1 -0
- data/.rubocop.yml +1 -5
- data/.travis.yml +35 -27
- data/CONTRIBUTING.md +131 -29
- data/Dockerfile +67 -0
- data/Gemfile +33 -80
- data/History.md +602 -0
- data/README.md +24 -196
- data/Rakefile +87 -27
- data/appveyor.yml +0 -1
- data/aruba.gemspec +30 -40
- data/bin/bootstrap +34 -0
- data/bin/build +3 -0
- data/{script → bin}/console +0 -0
- data/bin/release +3 -0
- data/bin/test +9 -0
- data/cucumber.yml +1 -3
- data/docker-compose.yml +26 -0
- data/{bin → exec}/aruba +0 -0
- data/fixtures/cli-app/README.md +1 -1
- data/fixtures/cli-app/features/support/aruba.rb +1 -0
- data/fixtures/cli-app/features/support/env.rb +1 -1
- data/fixtures/cli-app/lib/cli/app.rb +1 -5
- data/fixtures/cli-app/spec/spec_helper.rb +1 -6
- data/fixtures/empty-app/lib/cli/app.rb +2 -0
- data/lib/aruba/api.rb +3 -3
- data/lib/aruba/api/{commands.rb → command.rb} +4 -30
- data/lib/aruba/api/core.rb +8 -25
- data/lib/aruba/api/deprecated.rb +150 -408
- data/lib/aruba/api/filesystem.rb +17 -2
- data/lib/aruba/api/rvm.rb +44 -0
- data/lib/aruba/aruba_path.rb +56 -32
- data/lib/aruba/basic_configuration.rb +3 -5
- data/lib/aruba/colorizer.rb +99 -10
- data/lib/aruba/command.rb +0 -2
- data/lib/aruba/config.rb +5 -5
- data/lib/aruba/config/jruby.rb +5 -15
- data/lib/aruba/console.rb +2 -0
- data/lib/aruba/console/help.rb +1 -7
- data/lib/aruba/cucumber.rb +0 -2
- data/lib/aruba/cucumber/command.rb +98 -72
- data/lib/aruba/cucumber/file.rb +15 -3
- data/lib/aruba/cucumber/hooks.rb +71 -10
- data/lib/aruba/event_bus/name_resolver.rb +2 -10
- data/lib/aruba/generators/script_file.rb +1 -1
- data/lib/aruba/in_process.rb +0 -2
- data/lib/aruba/initializer.rb +4 -14
- data/lib/aruba/matchers/base/object_formatter.rb +0 -5
- data/lib/aruba/matchers/file/have_same_file_content.rb +5 -5
- data/lib/aruba/matchers/string/output_string_eq.rb +1 -1
- data/lib/aruba/platforms/announcer.rb +11 -16
- data/lib/aruba/platforms/aruba_file_creator.rb +1 -5
- data/lib/aruba/platforms/aruba_logger.rb +1 -5
- data/lib/aruba/platforms/command_monitor.rb +10 -14
- data/lib/aruba/platforms/determine_disk_usage.rb +8 -3
- data/lib/aruba/platforms/filesystem_status.rb +1 -5
- data/lib/aruba/platforms/unix_command_string.rb +1 -8
- data/lib/aruba/platforms/unix_environment_variables.rb +6 -8
- data/lib/aruba/platforms/unix_platform.rb +9 -22
- data/lib/aruba/platforms/unix_which.rb +4 -0
- data/lib/aruba/platforms/windows_command_string.rb +6 -14
- data/lib/aruba/platforms/windows_environment_variables.rb +4 -16
- data/lib/aruba/platforms/windows_which.rb +4 -0
- data/lib/aruba/processes/basic_process.rb +22 -18
- data/lib/aruba/processes/spawn_process.rb +12 -35
- data/lib/aruba/rspec.rb +1 -0
- data/lib/aruba/runtime.rb +3 -4
- data/lib/aruba/setup.rb +9 -11
- data/lib/aruba/spawn_process.rb +1 -4
- data/lib/aruba/tasks/docker_helpers.rb +158 -0
- data/lib/aruba/version.rb +1 -1
- metadata +62 -230
- data/CHANGELOG.md +0 -991
- data/features/.nav +0 -72
- data/features/01_getting_started_with_aruba/cleanup_working_directory.feature +0 -57
- data/features/01_getting_started_with_aruba/run_commands.feature +0 -217
- data/features/01_getting_started_with_aruba/supported_testing_frameworks.feature +0 -88
- data/features/02_configure_aruba/activate_announcer_on_command_failure.feature +0 -38
- data/features/02_configure_aruba/basics.feature +0 -151
- data/features/02_configure_aruba/command_runtime_environment.feature +0 -129
- data/features/02_configure_aruba/console_history_file.feature +0 -38
- data/features/02_configure_aruba/exit_timeout.feature +0 -60
- data/features/02_configure_aruba/fixtures_directories.feature +0 -38
- data/features/02_configure_aruba/fixtures_path_prefix.feature +0 -23
- data/features/02_configure_aruba/home_directory.feature +0 -80
- data/features/02_configure_aruba/io_timeout.feature +0 -30
- data/features/02_configure_aruba/keep_ansi.feature +0 -30
- data/features/02_configure_aruba/log_level.feature +0 -38
- data/features/02_configure_aruba/physical_block_size.feature +0 -53
- data/features/02_configure_aruba/remove_ansi_escape_sequences.feature +0 -38
- data/features/02_configure_aruba/root_directory.feature +0 -30
- data/features/02_configure_aruba/startup_wait_time.feature +0 -48
- data/features/02_configure_aruba/working_directory.feature +0 -38
- data/features/03_testing_frameworks/cucumber/announce_information_for_troubleshooting.feature +0 -306
- data/features/03_testing_frameworks/cucumber/disable_bunder.feature +0 -18
- data/features/03_testing_frameworks/cucumber/steps/command/check_for_exit_statuses.feature +0 -136
- data/features/03_testing_frameworks/cucumber/steps/command/check_output_of_command.feature +0 -514
- data/features/03_testing_frameworks/cucumber/steps/command/check_stderr_of_command.feature +0 -68
- data/features/03_testing_frameworks/cucumber/steps/command/check_stdout_of_command.feature +0 -109
- data/features/03_testing_frameworks/cucumber/steps/command/debug_your_command_in_aruba.feature +0 -118
- data/features/03_testing_frameworks/cucumber/steps/command/run_a_command.feature +0 -66
- data/features/03_testing_frameworks/cucumber/steps/command/run_command_in_process.feature +0 -485
- data/features/03_testing_frameworks/cucumber/steps/command/run_command_interactively.feature +0 -90
- data/features/03_testing_frameworks/cucumber/steps/command/run_commands_which_require_a_shell.feature +0 -79
- data/features/03_testing_frameworks/cucumber/steps/command/send_signal_to_command.feature +0 -83
- data/features/03_testing_frameworks/cucumber/steps/command/stop_command.feature +0 -285
- data/features/03_testing_frameworks/cucumber/steps/environment/append_environment_variable.feature +0 -52
- data/features/03_testing_frameworks/cucumber/steps/environment/modify_home_variable_for_testing.feature +0 -62
- data/features/03_testing_frameworks/cucumber/steps/environment/prepend_environment_variable.feature +0 -52
- data/features/03_testing_frameworks/cucumber/steps/environment/set_environment_variable.feature +0 -49
- data/features/03_testing_frameworks/cucumber/steps/filesystem/append_to_file.feature +0 -45
- data/features/03_testing_frameworks/cucumber/steps/filesystem/cd_to_directory.feature +0 -33
- data/features/03_testing_frameworks/cucumber/steps/filesystem/check_existence_of_directory.feature +0 -57
- data/features/03_testing_frameworks/cucumber/steps/filesystem/check_existence_of_file.feature +0 -43
- data/features/03_testing_frameworks/cucumber/steps/filesystem/check_file_content.feature +0 -143
- data/features/03_testing_frameworks/cucumber/steps/filesystem/check_non_existence_of_directory.feature +0 -69
- data/features/03_testing_frameworks/cucumber/steps/filesystem/check_non_existence_of_file.feature +0 -80
- data/features/03_testing_frameworks/cucumber/steps/filesystem/check_permissions_of_file.feature +0 -39
- data/features/03_testing_frameworks/cucumber/steps/filesystem/compare_files.feature +0 -42
- data/features/03_testing_frameworks/cucumber/steps/filesystem/copy_file_or_directory.feature +0 -45
- data/features/03_testing_frameworks/cucumber/steps/filesystem/create_directory.feature +0 -57
- data/features/03_testing_frameworks/cucumber/steps/filesystem/create_file.feature +0 -76
- data/features/03_testing_frameworks/cucumber/steps/filesystem/move_file_or_directory.feature +0 -44
- data/features/03_testing_frameworks/cucumber/steps/filesystem/overwrite_file.feature +0 -72
- data/features/03_testing_frameworks/cucumber/steps/filesystem/remove_directory.feature +0 -38
- data/features/03_testing_frameworks/cucumber/steps/filesystem/remove_file.feature +0 -38
- data/features/03_testing_frameworks/cucumber/steps/filesystem/use_fixtures_for_setup_test.feature +0 -77
- data/features/03_testing_frameworks/rspec/hooks/define_after_hook_for_commands.feature +0 -43
- data/features/03_testing_frameworks/rspec/hooks/define_before_hook_for_commands.feature +0 -71
- data/features/03_testing_frameworks/rspec/setup_aruba_for_rspec.feature +0 -179
- data/features/04_aruba_api/command/find_a_started_command.feature +0 -83
- data/features/04_aruba_api/command/find_command_in_PATH.feature +0 -37
- data/features/04_aruba_api/command/read_stderr_of_command.feature +0 -46
- data/features/04_aruba_api/command/read_stdout_of_command.feature +0 -46
- data/features/04_aruba_api/command/run_command.feature +0 -423
- data/features/04_aruba_api/command/run_simple.feature +0 -254
- data/features/04_aruba_api/command/send_signal_to_command.feature +0 -53
- data/features/04_aruba_api/command/stop_all_commands.feature +0 -57
- data/features/04_aruba_api/command/stop_single_command.feature +0 -132
- data/features/04_aruba_api/command/terminate_all_commands.feature +0 -57
- data/features/04_aruba_api/command/use_last_command_started.feature +0 -50
- data/features/04_aruba_api/command/use_last_command_stopped.feature +0 -89
- data/features/04_aruba_api/core/expand_path.feature +0 -88
- data/features/04_aruba_api/environment/append_environment_variable.feature +0 -128
- data/features/04_aruba_api/environment/delete_environment_variable.feature +0 -63
- data/features/04_aruba_api/environment/prepend_environment_variable.feature +0 -128
- data/features/04_aruba_api/environment/set_environment_variable.feature +0 -376
- data/features/04_aruba_api/filesystem/cd_to_directory.feature +0 -184
- data/features/04_aruba_api/filesystem/check_existence_file_or_directory.feature +0 -62
- data/features/04_aruba_api/filesystem/check_if_path_is_absolute.feature +0 -48
- data/features/04_aruba_api/filesystem/check_if_path_is_directory.feature +0 -53
- data/features/04_aruba_api/filesystem/check_if_path_is_file.feature +0 -54
- data/features/04_aruba_api/filesystem/check_if_path_is_relative.feature +0 -48
- data/features/04_aruba_api/filesystem/create_directory.feature +0 -57
- data/features/04_aruba_api/filesystem/move_file_or_directory.feature +0 -119
- data/features/04_aruba_api/filesystem/report_disk_usage.feature +0 -152
- data/features/04_aruba_api/filesystem/use_fixtures.feature +0 -104
- data/features/04_aruba_api/text/extract_text.feature +0 -87
- data/features/04_aruba_api/text/replace_variables.feature +0 -45
- data/features/04_aruba_api/text/sanitize_text.feature +0 -228
- data/features/04_aruba_api/text/unescape_text.feature +0 -127
- data/features/05_use_rspec_matchers/command/check_timeouts.feature +0 -48
- data/features/05_use_rspec_matchers/directory/have_sub_directory.feature +0 -110
- data/features/05_use_rspec_matchers/file/be_a_command_found_in_path.feature +0 -115
- data/features/05_use_rspec_matchers/file/be_existing_executable.feature +0 -88
- data/features/05_use_rspec_matchers/file/be_existing_file.feature +0 -82
- data/features/05_use_rspec_matchers/file/have_file_content.feature +0 -123
- data/features/05_use_rspec_matchers/file/have_file_size.feature +0 -107
- data/features/05_use_rspec_matchers/path/be_an_absolute_path.feature +0 -74
- data/features/05_use_rspec_matchers/path/be_an_existing_path.feature +0 -97
- data/features/05_use_rspec_matchers/path/have_permissions.feature +0 -118
- data/features/06_use_aruba_cli/initialize_project_with_aruba.feature +0 -79
- data/features/06_use_aruba_cli/open_console.feature +0 -55
- data/features/08_other/improve_performance_if_using_jruby.feature +0 -37
- data/features/step_definitions/hooks.rb +0 -146
- data/features/support/aruba.rb +0 -7
- data/features/support/env.rb +0 -33
- data/features/support/simplecov_setup.rb +0 -11
- data/lib/aruba/api/bundler.rb +0 -16
- data/lib/aruba/cucumber/deprecated.rb +0 -93
- data/lib/aruba/matchers/deprecated.rb +0 -1
- data/lib/aruba/matchers/deprecated/file.rb +0 -17
- data/lib/aruba/reporting.rb +0 -126
- data/script/bootstrap +0 -24
- data/script/test +0 -3
- data/spec/aruba/api/bundler_spec.rb +0 -15
- data/spec/aruba/api/commands_spec.rb +0 -30
- data/spec/aruba/api/core_spec.rb +0 -184
- data/spec/aruba/api/deprecated_spec.rb +0 -421
- data/spec/aruba/api/filesystem_spec.rb +0 -746
- data/spec/aruba/api/runtime_spec.rb +0 -28
- data/spec/aruba/api_spec.rb +0 -73
- data/spec/aruba/aruba_path_spec.rb +0 -103
- data/spec/aruba/basic_configuration_spec.rb +0 -5
- data/spec/aruba/configuration_spec.rb +0 -5
- data/spec/aruba/hooks_spec.rb +0 -17
- data/spec/aruba/in_config_wrapper_spec.rb +0 -25
- data/spec/aruba/jruby_spec.rb +0 -73
- data/spec/aruba/matchers/command/have_output_size_spec.rb +0 -25
- data/spec/aruba/matchers/command_spec.rb +0 -174
- data/spec/aruba/matchers/deprecated_spec.rb +0 -120
- data/spec/aruba/matchers/directory_spec.rb +0 -57
- data/spec/aruba/matchers/file_spec.rb +0 -208
- data/spec/aruba/matchers/path_spec.rb +0 -58
- data/spec/aruba/platform/simple_table_spec.rb +0 -23
- data/spec/aruba/platform/windows_environment_variables_spec.rb +0 -500
- data/spec/aruba/platforms/unix_command_string_spec.rb +0 -17
- data/spec/aruba/platforms/windows_command_string_spec.rb +0 -22
- data/spec/aruba/processes/spawn_process_spec.rb +0 -112
- data/spec/aruba/rspec_spec.rb +0 -15
- data/spec/aruba/runtime_spec.rb +0 -29
- data/spec/event_bus/name_resolver_spec.rb +0 -68
- data/spec/event_bus_spec.rb +0 -158
- data/spec/spec_helper.rb +0 -22
- data/spec/support/configs/.keep +0 -0
- data/spec/support/configs/aruba.rb +0 -5
- data/spec/support/configs/pry.rb +0 -3
- data/spec/support/configs/rspec.rb +0 -15
- data/spec/support/helpers/.keep +0 -0
- data/spec/support/helpers/reporting.rb +0 -44
- data/spec/support/matchers/.keep +0 -0
- data/spec/support/matchers/option.rb +0 -35
- data/spec/support/shared_contexts/.keep +0 -0
- data/spec/support/shared_contexts/aruba.rb +0 -49
- data/spec/support/shared_examples/.keep +0 -0
- data/spec/support/shared_examples/configuration.rb +0 -116
- data/spec/support/shared_examples/directory.rb +0 -7
- data/spec/support/shared_examples/file.rb +0 -7
- data/templates/css/console.css +0 -24
- data/templates/css/filesystem.css +0 -42
- data/templates/css/pygments-autumn.css +0 -59
- data/templates/files.erb +0 -14
- data/templates/images/LICENSE +0 -22
- data/templates/images/folder.png +0 -0
- data/templates/images/page_white.png +0 -0
- data/templates/images/page_white_gherkin.png +0 -0
- data/templates/images/page_white_ruby.png +0 -0
- data/templates/index.erb +0 -20
- data/templates/js/filesystem.js +0 -5
- data/templates/js/jquery-1.11.3.min.js +0 -5
- data/templates/main.erb +0 -34
@@ -1,83 +0,0 @@
|
|
1
|
-
Feature: Find a started command
|
2
|
-
|
3
|
-
This feature is experimental and may change without further notice.
|
4
|
-
|
5
|
-
Background:
|
6
|
-
Given I use a fixture named "cli-app"
|
7
|
-
|
8
|
-
Scenario: Existing command
|
9
|
-
Given a file named "spec/run_spec.rb" with:
|
10
|
-
"""ruby
|
11
|
-
require 'spec_helper'
|
12
|
-
|
13
|
-
RSpec.describe 'Run command', :type => :aruba do
|
14
|
-
before(:each) { run_command('echo hello') }
|
15
|
-
let(:command) { find_command('echo hello') }
|
16
|
-
|
17
|
-
before(:each) { stop_all_commands }
|
18
|
-
|
19
|
-
it { expect(command).to be_successfully_executed }
|
20
|
-
it { expect(command.commandline).to eq 'echo hello' }
|
21
|
-
end
|
22
|
-
"""
|
23
|
-
When I run `rspec`
|
24
|
-
Then the specs should all pass
|
25
|
-
|
26
|
-
Scenario: Non-Existing command
|
27
|
-
Given a file named "spec/run_spec.rb" with:
|
28
|
-
"""ruby
|
29
|
-
require 'spec_helper'
|
30
|
-
|
31
|
-
RSpec.describe 'Run command', :type => :aruba do
|
32
|
-
let(:command) { find_command('echo hello') }
|
33
|
-
|
34
|
-
it { expect{ command }.to raise_error Aruba::CommandNotFoundError }
|
35
|
-
it { expect{ command.commandline }.to raise_error Aruba::CommandNotFoundError }
|
36
|
-
end
|
37
|
-
"""
|
38
|
-
When I run `rspec`
|
39
|
-
Then the specs should all pass
|
40
|
-
|
41
|
-
Scenario: Multiple commands
|
42
|
-
Given a file named "spec/run_spec.rb" with:
|
43
|
-
"""ruby
|
44
|
-
require 'spec_helper'
|
45
|
-
|
46
|
-
RSpec.describe 'Run command', :type => :aruba do
|
47
|
-
before(:each) { run_command('echo hello1') }
|
48
|
-
before(:each) { run_command('echo hello2') }
|
49
|
-
let(:command) { find_command('echo hello1') }
|
50
|
-
|
51
|
-
before(:each) { stop_all_commands }
|
52
|
-
|
53
|
-
it { expect(command).to be_successfully_executed }
|
54
|
-
it { expect(command.commandline).to eq 'echo hello1' }
|
55
|
-
end
|
56
|
-
"""
|
57
|
-
When I run `rspec`
|
58
|
-
Then the specs should all pass
|
59
|
-
|
60
|
-
Scenario: Multiple commands with same commandline
|
61
|
-
|
62
|
-
If searches in reverse. So it finds the last command started with the given commandline.
|
63
|
-
|
64
|
-
Given a file named "spec/run_spec.rb" with:
|
65
|
-
"""ruby
|
66
|
-
require 'spec_helper'
|
67
|
-
|
68
|
-
RSpec.describe 'Run command', :type => :aruba do
|
69
|
-
before(:each) { set_environment_variable 'ENV_VAR', '1' }
|
70
|
-
before(:each) { run_command('bash -c "echo -n $ENV_VAR"') }
|
71
|
-
before(:each) { set_environment_variable 'ENV_VAR', '2' }
|
72
|
-
before(:each) { run_command('bash -c "echo -n $ENV_VAR"') }
|
73
|
-
|
74
|
-
let(:command) { find_command('bash -c "echo -n $ENV_VAR"') }
|
75
|
-
|
76
|
-
before(:each) { stop_all_commands }
|
77
|
-
|
78
|
-
it { expect(command).to be_successfully_executed }
|
79
|
-
it { expect(command.stdout).to eq '2' }
|
80
|
-
end
|
81
|
-
"""
|
82
|
-
When I run `rspec`
|
83
|
-
Then the specs should all pass
|
@@ -1,37 +0,0 @@
|
|
1
|
-
Feature: Get path to command
|
2
|
-
|
3
|
-
Sometimes you only know a commands name, but not where to find it. Here comes
|
4
|
-
`which` to the rescue.
|
5
|
-
|
6
|
-
Background:
|
7
|
-
Given I use a fixture named "cli-app"
|
8
|
-
|
9
|
-
Scenario: Existing executable
|
10
|
-
Given an executable named "bin/aruba-test-cli" with:
|
11
|
-
"""bash
|
12
|
-
#!/bin/bash
|
13
|
-
exit 0
|
14
|
-
"""
|
15
|
-
And a file named "spec/which_spec.rb" with:
|
16
|
-
"""ruby
|
17
|
-
require 'spec_helper'
|
18
|
-
|
19
|
-
RSpec.describe 'Find path for command', :type => :aruba do
|
20
|
-
it { expect(which('aruba-test-cli')).to match %r{tmp/aruba/cli-app/bin/aruba-test-cli} }
|
21
|
-
end
|
22
|
-
"""
|
23
|
-
When I run `rspec`
|
24
|
-
Then the specs should all pass
|
25
|
-
|
26
|
-
Scenario: Non-existing executable
|
27
|
-
Given a file named "bin/aruba-test-cli" does not exist
|
28
|
-
And a file named "spec/which_spec.rb" with:
|
29
|
-
"""ruby
|
30
|
-
require 'spec_helper'
|
31
|
-
|
32
|
-
RSpec.describe 'Find path for command', :type => :aruba do
|
33
|
-
it { expect(which('aruba-test-cli')).to be_nil }
|
34
|
-
end
|
35
|
-
"""
|
36
|
-
When I run `rspec`
|
37
|
-
Then the specs should all pass
|
@@ -1,46 +0,0 @@
|
|
1
|
-
Feature: Access STDERR of command
|
2
|
-
|
3
|
-
You may need to `#stop_all_commands` before accessing `#stderr` of a single
|
4
|
-
command - e.g. `#last_command_started`.
|
5
|
-
|
6
|
-
Background:
|
7
|
-
Given I use a fixture named "cli-app"
|
8
|
-
And the default aruba io wait timeout is 0.1 seconds
|
9
|
-
|
10
|
-
Scenario: Existing executable
|
11
|
-
Given an executable named "bin/aruba-test-cli" with:
|
12
|
-
"""bash
|
13
|
-
#!/bin/bash
|
14
|
-
echo 'Hello, Aruba!' >&2
|
15
|
-
"""
|
16
|
-
And a file named "spec/run_spec.rb" with:
|
17
|
-
"""ruby
|
18
|
-
require 'spec_helper'
|
19
|
-
|
20
|
-
RSpec.describe 'Run command', :type => :aruba do
|
21
|
-
before(:each) { run_command('aruba-test-cli') }
|
22
|
-
before(:each) { stop_all_commands }
|
23
|
-
it { expect(last_command_started.stderr).to start_with 'Hello' }
|
24
|
-
end
|
25
|
-
"""
|
26
|
-
When I run `rspec`
|
27
|
-
Then the specs should all pass
|
28
|
-
|
29
|
-
Scenario: Waiting for output to appear
|
30
|
-
Given an executable named "bin/aruba-test-cli" with:
|
31
|
-
"""bash
|
32
|
-
#!/bin/bash
|
33
|
-
sleep 0.1
|
34
|
-
echo 'Hello, Aruba' >&2
|
35
|
-
"""
|
36
|
-
And a file named "spec/run_spec.rb" with:
|
37
|
-
"""ruby
|
38
|
-
require 'spec_helper'
|
39
|
-
|
40
|
-
RSpec.describe 'Run command', :type => :aruba, :io_wait_timeout => 0.2 do
|
41
|
-
before(:each) { run_command('aruba-test-cli') }
|
42
|
-
it { expect(last_command_started.stderr).to start_with 'Hello' }
|
43
|
-
end
|
44
|
-
"""
|
45
|
-
When I run `rspec`
|
46
|
-
Then the specs should all pass
|
@@ -1,46 +0,0 @@
|
|
1
|
-
Feature: Access STDOUT of command
|
2
|
-
|
3
|
-
You may need to `#stop_all_commands` before accessing `#stdout` of a single
|
4
|
-
command - e.g. `#last_command_started`.
|
5
|
-
|
6
|
-
Background:
|
7
|
-
Given I use a fixture named "cli-app"
|
8
|
-
And the default aruba io wait timeout is 1 seconds
|
9
|
-
|
10
|
-
Scenario: Existing executable
|
11
|
-
Given an executable named "bin/aruba-test-cli" with:
|
12
|
-
"""bash
|
13
|
-
#!/bin/bash
|
14
|
-
echo 'Hello, Aruba!'
|
15
|
-
"""
|
16
|
-
And a file named "spec/run_spec.rb" with:
|
17
|
-
"""ruby
|
18
|
-
require 'spec_helper'
|
19
|
-
|
20
|
-
RSpec.describe 'Run command', :type => :aruba do
|
21
|
-
before(:each) { run_command('aruba-test-cli') }
|
22
|
-
before(:each) { stop_all_commands }
|
23
|
-
it { expect(last_command_started.stdout).to start_with 'Hello' }
|
24
|
-
end
|
25
|
-
"""
|
26
|
-
When I run `rspec`
|
27
|
-
Then the specs should all pass
|
28
|
-
|
29
|
-
Scenario: Waiting for output to appear
|
30
|
-
Given an executable named "bin/aruba-test-cli" with:
|
31
|
-
"""bash
|
32
|
-
#!/bin/bash
|
33
|
-
sleep 0.1
|
34
|
-
echo 'Hello, Aruba'
|
35
|
-
"""
|
36
|
-
And a file named "spec/run_spec.rb" with:
|
37
|
-
"""ruby
|
38
|
-
require 'spec_helper'
|
39
|
-
|
40
|
-
RSpec.describe 'Run command', :type => :aruba, :io_wait_timeout => 0.2 do
|
41
|
-
before(:each) { run_command('aruba-test-cli') }
|
42
|
-
it { expect(last_command_started.stdout).to start_with 'Hello' }
|
43
|
-
end
|
44
|
-
"""
|
45
|
-
When I run `rspec`
|
46
|
-
Then the specs should all pass
|
@@ -1,423 +0,0 @@
|
|
1
|
-
Feature: Run command
|
2
|
-
|
3
|
-
To run a command use the `#run_command` method. There are some configuration options
|
4
|
-
which are relevant here:
|
5
|
-
|
6
|
-
- `startup_wait_time`:
|
7
|
-
|
8
|
-
Given this option `aruba` waits n seconds after it started the command.
|
9
|
-
This is most useful when using `#run_command()` and not really makes sense for
|
10
|
-
`#run_command_and_stop()`.
|
11
|
-
|
12
|
-
You can use `#run_command()` + `startup_wait_time` to start background jobs.
|
13
|
-
|
14
|
-
- `exit_timeout`:
|
15
|
-
|
16
|
-
The exit timeout is used, when `aruba` waits for a command to finished.
|
17
|
-
|
18
|
-
- `io_wait_timeout`:
|
19
|
-
|
20
|
-
The io wait timeout is used, when you access `stdout` or `stderr` of a
|
21
|
-
command.
|
22
|
-
|
23
|
-
Background:
|
24
|
-
Given I use a fixture named "cli-app"
|
25
|
-
|
26
|
-
Scenario: Existing executable
|
27
|
-
Given an executable named "bin/aruba-test-cli" with:
|
28
|
-
"""bash
|
29
|
-
#!/bin/bash
|
30
|
-
exit 0
|
31
|
-
"""
|
32
|
-
And a file named "spec/run_spec.rb" with:
|
33
|
-
"""ruby
|
34
|
-
require 'spec_helper'
|
35
|
-
|
36
|
-
RSpec.describe 'Run command', :type => :aruba do
|
37
|
-
before(:each) { run_command('aruba-test-cli') }
|
38
|
-
it { expect(last_command_started).to be_successfully_executed }
|
39
|
-
end
|
40
|
-
"""
|
41
|
-
When I run `rspec`
|
42
|
-
Then the specs should all pass
|
43
|
-
|
44
|
-
Scenario: Relative path to executable
|
45
|
-
Given an executable named "bin/aruba-test-cli" with:
|
46
|
-
"""bash
|
47
|
-
#!/bin/bash
|
48
|
-
exit 0
|
49
|
-
"""
|
50
|
-
And a file named "spec/run_spec.rb" with:
|
51
|
-
"""ruby
|
52
|
-
require 'spec_helper'
|
53
|
-
|
54
|
-
RSpec.describe 'Run command', :type => :aruba do
|
55
|
-
before(:each) { run_command('bin/aruba-test-cli') }
|
56
|
-
it { expect(last_command_started).to be_successfully_executed }
|
57
|
-
end
|
58
|
-
"""
|
59
|
-
When I run `rspec`
|
60
|
-
Then the specs should all pass
|
61
|
-
|
62
|
-
Scenario: Non-existing executable
|
63
|
-
Given a file named "bin/aruba-test-cli" does not exist
|
64
|
-
And a file named "spec/run_spec.rb" with:
|
65
|
-
"""ruby
|
66
|
-
require 'spec_helper'
|
67
|
-
|
68
|
-
RSpec.describe 'Find path for command', :type => :aruba do
|
69
|
-
it { expect { run_command('aruba-test-cli') }.to raise_error Aruba::LaunchError, /Command "aruba-test-cli" not found in PATH-variable/ }
|
70
|
-
end
|
71
|
-
"""
|
72
|
-
When I run `rspec`
|
73
|
-
Then the specs should all pass
|
74
|
-
|
75
|
-
Scenario: Command with long startup phase
|
76
|
-
|
77
|
-
If you have got a command with a long startup phase or use `ruby` together
|
78
|
-
with `bundler`, you should consider using the `startup_wait_time`-option.
|
79
|
-
Otherwise methods like `#send_signal` don't work since they require the
|
80
|
-
command to be running and have setup it's signal handler.
|
81
|
-
|
82
|
-
Given an executable named "bin/aruba-test-cli" with:
|
83
|
-
"""bash
|
84
|
-
#!/usr/bin/env bash
|
85
|
-
|
86
|
-
function initialize_script {
|
87
|
-
sleep 0.2
|
88
|
-
}
|
89
|
-
|
90
|
-
function do_some_work {
|
91
|
-
echo "Hello, Aruba is working"
|
92
|
-
}
|
93
|
-
|
94
|
-
function recurring_work {
|
95
|
-
echo "Hello, Aruba here"
|
96
|
-
}
|
97
|
-
|
98
|
-
function stop_script {
|
99
|
-
exit 0
|
100
|
-
}
|
101
|
-
|
102
|
-
trap recurring_work HUP
|
103
|
-
trap stop_script TERM
|
104
|
-
|
105
|
-
initialize_script
|
106
|
-
do_some_work
|
107
|
-
|
108
|
-
while [ true ]; do sleep 0.1; done
|
109
|
-
"""
|
110
|
-
And a file named "spec/run_spec.rb" with:
|
111
|
-
"""ruby
|
112
|
-
require 'spec_helper'
|
113
|
-
|
114
|
-
RSpec.describe 'Run command', :type => :aruba, :exit_timeout => 0.1, :startup_wait_time => 0.2 do
|
115
|
-
before do
|
116
|
-
run_command('aruba-test-cli')
|
117
|
-
last_command_started.send_signal 'HUP'
|
118
|
-
end
|
119
|
-
|
120
|
-
it 'runs the command with the expected results' do
|
121
|
-
aggregate_failures do
|
122
|
-
expect(last_command_started).to be_successfully_executed
|
123
|
-
expect(last_command_started).to have_output /Hello, Aruba is working/
|
124
|
-
expect(last_command_started).to have_output /Hello, Aruba here/
|
125
|
-
end
|
126
|
-
end
|
127
|
-
end
|
128
|
-
"""
|
129
|
-
When I run `rspec`
|
130
|
-
Then the specs should all pass
|
131
|
-
|
132
|
-
Scenario: Long running command
|
133
|
-
|
134
|
-
If you have got a "long running" command, you should consider using the
|
135
|
-
`exit_timeout`-option.
|
136
|
-
|
137
|
-
Given an executable named "bin/aruba-test-cli" with:
|
138
|
-
"""bash
|
139
|
-
#!/usr/bin/env bash
|
140
|
-
|
141
|
-
function do_some_work {
|
142
|
-
sleep 0.2
|
143
|
-
echo "Hello, Aruba here"
|
144
|
-
}
|
145
|
-
|
146
|
-
do_some_work
|
147
|
-
"""
|
148
|
-
And a file named "spec/run_spec.rb" with:
|
149
|
-
"""ruby
|
150
|
-
require 'spec_helper'
|
151
|
-
|
152
|
-
RSpec.describe 'Run command', :type => :aruba, :exit_timeout => 0.3 do
|
153
|
-
before { run_command('aruba-test-cli') }
|
154
|
-
|
155
|
-
it 'runs the command with the expected results' do
|
156
|
-
aggregate_failures do
|
157
|
-
expect(last_command_started).to be_successfully_executed
|
158
|
-
expect(last_command_started).to have_output /Hello, Aruba here/
|
159
|
-
end
|
160
|
-
end
|
161
|
-
end
|
162
|
-
"""
|
163
|
-
When I run `rspec`
|
164
|
-
Then the specs should all pass
|
165
|
-
|
166
|
-
Scenario: Mixing commands with long and short startup phase (deprecated)
|
167
|
-
|
168
|
-
If you commands with a long and short startup phases, you should consider
|
169
|
-
using the `startup_wait_time`-option local to the `#run_command`-call.
|
170
|
-
|
171
|
-
Given an executable named "bin/aruba-test-cli1" with:
|
172
|
-
"""bash
|
173
|
-
#!/usr/bin/env bash
|
174
|
-
|
175
|
-
function initialize_script {
|
176
|
-
sleep 2
|
177
|
-
}
|
178
|
-
|
179
|
-
function do_some_work {
|
180
|
-
echo "Hello, Aruba is working"
|
181
|
-
}
|
182
|
-
|
183
|
-
function recurring_work {
|
184
|
-
echo "Hello, Aruba here"
|
185
|
-
}
|
186
|
-
|
187
|
-
function stop_script {
|
188
|
-
exit 0
|
189
|
-
}
|
190
|
-
|
191
|
-
trap recurring_work HUP
|
192
|
-
trap stop_script TERM
|
193
|
-
|
194
|
-
initialize_script
|
195
|
-
do_some_work
|
196
|
-
|
197
|
-
while [ true ]; do sleep 0.2; done
|
198
|
-
"""
|
199
|
-
And an executable named "bin/aruba-test-cli2" with:
|
200
|
-
"""bash
|
201
|
-
#!/usr/bin/env bash
|
202
|
-
|
203
|
-
function initialize_script {
|
204
|
-
sleep 0
|
205
|
-
}
|
206
|
-
|
207
|
-
function do_some_work {
|
208
|
-
echo "Hello, Aruba is working"
|
209
|
-
}
|
210
|
-
|
211
|
-
function recurring_work {
|
212
|
-
echo "Hello, Aruba here"
|
213
|
-
}
|
214
|
-
|
215
|
-
function stop_script {
|
216
|
-
exit 0
|
217
|
-
}
|
218
|
-
|
219
|
-
trap recurring_work HUP
|
220
|
-
trap stop_script TERM
|
221
|
-
|
222
|
-
initialize_script
|
223
|
-
do_some_work
|
224
|
-
|
225
|
-
while [ true ]; do sleep 0.2; done
|
226
|
-
"""
|
227
|
-
And a file named "spec/run_spec.rb" with:
|
228
|
-
"""ruby
|
229
|
-
require 'spec_helper'
|
230
|
-
|
231
|
-
RSpec.describe 'Run command', :type => :aruba, :exit_timeout => 1 do
|
232
|
-
before(:each) { run_command('aruba-test-cli1', 3, 0.1, 'TERM', 2) }
|
233
|
-
before(:each) { run_command('aruba-test-cli2', 3, 0.1, 'TERM', 1) }
|
234
|
-
before(:each) { last_command_started.send_signal 'HUP' }
|
235
|
-
|
236
|
-
it { expect(last_command_started).to be_successfully_executed }
|
237
|
-
it { expect(last_command_started).to have_output /Hello, Aruba is working/ }
|
238
|
-
it { expect(last_command_started).to have_output /Hello, Aruba here/ }
|
239
|
-
|
240
|
-
end
|
241
|
-
"""
|
242
|
-
When I run `rspec`
|
243
|
-
Then the specs should all pass
|
244
|
-
|
245
|
-
Scenario: Mixing commands with long and short startup phase
|
246
|
-
|
247
|
-
If you commands with a long and short startup phases, you should consider
|
248
|
-
using the `startup_wait_time`-option local to the `#run_command`-call.
|
249
|
-
|
250
|
-
Given an executable named "bin/aruba-test-cli1" with:
|
251
|
-
"""bash
|
252
|
-
#!/usr/bin/env bash
|
253
|
-
|
254
|
-
function initialize_script {
|
255
|
-
sleep 2
|
256
|
-
}
|
257
|
-
|
258
|
-
function do_some_work {
|
259
|
-
echo "Hello, Aruba is working"
|
260
|
-
}
|
261
|
-
|
262
|
-
function recurring_work {
|
263
|
-
echo "Hello, Aruba here"
|
264
|
-
}
|
265
|
-
|
266
|
-
function stop_script {
|
267
|
-
exit 0
|
268
|
-
}
|
269
|
-
|
270
|
-
trap recurring_work HUP
|
271
|
-
trap stop_script TERM
|
272
|
-
|
273
|
-
initialize_script
|
274
|
-
do_some_work
|
275
|
-
|
276
|
-
while [ true ]; do sleep 0.2; done
|
277
|
-
"""
|
278
|
-
And an executable named "bin/aruba-test-cli2" with:
|
279
|
-
"""bash
|
280
|
-
#!/usr/bin/env bash
|
281
|
-
|
282
|
-
function initialize_script {
|
283
|
-
sleep 0
|
284
|
-
}
|
285
|
-
|
286
|
-
function do_some_work {
|
287
|
-
echo "Hello, Aruba is working"
|
288
|
-
}
|
289
|
-
|
290
|
-
function recurring_work {
|
291
|
-
echo "Hello, Aruba here"
|
292
|
-
}
|
293
|
-
|
294
|
-
function stop_script {
|
295
|
-
exit 0
|
296
|
-
}
|
297
|
-
|
298
|
-
trap recurring_work HUP
|
299
|
-
trap stop_script TERM
|
300
|
-
|
301
|
-
initialize_script
|
302
|
-
do_some_work
|
303
|
-
|
304
|
-
while [ true ]; do sleep 0.2; done
|
305
|
-
"""
|
306
|
-
And a file named "spec/run_spec.rb" with:
|
307
|
-
"""ruby
|
308
|
-
require 'spec_helper'
|
309
|
-
|
310
|
-
RSpec.describe 'Run command', :type => :aruba, :exit_timeout => 1 do
|
311
|
-
before(:each) { run_command('aruba-test-cli1', :startup_wait_time => 2) }
|
312
|
-
before(:each) { run_command('aruba-test-cli2', :startup_wait_time => 1) }
|
313
|
-
before(:each) { last_command_started.send_signal 'HUP' }
|
314
|
-
|
315
|
-
it { expect(last_command_started).to be_successfully_executed }
|
316
|
-
it { expect(last_command_started).to have_output /Hello, Aruba is working/ }
|
317
|
-
it { expect(last_command_started).to have_output /Hello, Aruba here/ }
|
318
|
-
|
319
|
-
end
|
320
|
-
"""
|
321
|
-
When I run `rspec`
|
322
|
-
Then the specs should all pass
|
323
|
-
|
324
|
-
Scenario: Mixing long and short running commands (deprecated)
|
325
|
-
|
326
|
-
If need to mix "long running" and "short running" commands, you should consider using the
|
327
|
-
`exit_timeout`-option local to the `#run_command`-method.
|
328
|
-
|
329
|
-
Given an executable named "bin/aruba-test-cli1" with:
|
330
|
-
"""bash
|
331
|
-
#!/usr/bin/env bash
|
332
|
-
|
333
|
-
function do_some_work {
|
334
|
-
sleep 2
|
335
|
-
echo "Hello, Aruba here"
|
336
|
-
}
|
337
|
-
|
338
|
-
do_some_work
|
339
|
-
"""
|
340
|
-
And an executable named "bin/aruba-test-cli2" with:
|
341
|
-
"""bash
|
342
|
-
#!/usr/bin/env bash
|
343
|
-
|
344
|
-
function do_some_work {
|
345
|
-
echo "Hello, Aruba here"
|
346
|
-
}
|
347
|
-
|
348
|
-
do_some_work
|
349
|
-
"""
|
350
|
-
And a file named "spec/run_spec.rb" with:
|
351
|
-
"""ruby
|
352
|
-
require 'spec_helper'
|
353
|
-
|
354
|
-
RSpec.describe 'Run command', :type => :aruba do
|
355
|
-
before(:each) { run_command('aruba-test-cli1', 3) }
|
356
|
-
before(:each) { run_command('aruba-test-cli2', 1) }
|
357
|
-
|
358
|
-
it { expect(last_command_started).to be_successfully_executed }
|
359
|
-
it { expect(last_command_started).to have_output /Hello, Aruba here/ }
|
360
|
-
end
|
361
|
-
"""
|
362
|
-
When I run `rspec`
|
363
|
-
Then the specs should all pass
|
364
|
-
|
365
|
-
Scenario: Mixing long and short running commands
|
366
|
-
|
367
|
-
If need to mix "long running" and "short running" commands, you should consider using the
|
368
|
-
`exit_timeout`-option local to the `#run_command`-method.
|
369
|
-
|
370
|
-
Given an executable named "bin/aruba-test-cli1" with:
|
371
|
-
"""bash
|
372
|
-
#!/usr/bin/env bash
|
373
|
-
|
374
|
-
function do_some_work {
|
375
|
-
sleep 2
|
376
|
-
echo "Hello, Aruba here"
|
377
|
-
}
|
378
|
-
|
379
|
-
do_some_work
|
380
|
-
"""
|
381
|
-
And an executable named "bin/aruba-test-cli2" with:
|
382
|
-
"""bash
|
383
|
-
#!/usr/bin/env bash
|
384
|
-
|
385
|
-
function do_some_work {
|
386
|
-
echo "Hello, Aruba here"
|
387
|
-
}
|
388
|
-
|
389
|
-
do_some_work
|
390
|
-
"""
|
391
|
-
And a file named "spec/run_spec.rb" with:
|
392
|
-
"""ruby
|
393
|
-
require 'spec_helper'
|
394
|
-
|
395
|
-
RSpec.describe 'Run command', :type => :aruba do
|
396
|
-
before(:each) { run_command('aruba-test-cli1', :exit_timeout => 3) }
|
397
|
-
before(:each) { run_command('aruba-test-cli2', :exit_timeout => 1) }
|
398
|
-
|
399
|
-
it { expect(last_command_started).to be_successfully_executed }
|
400
|
-
it { expect(last_command_started).to have_output /Hello, Aruba here/ }
|
401
|
-
end
|
402
|
-
"""
|
403
|
-
When I run `rspec`
|
404
|
-
Then the specs should all pass
|
405
|
-
|
406
|
-
Scenario: Starting command twice fails
|
407
|
-
Given an executable named "bin/aruba-test-cli" with:
|
408
|
-
"""bash
|
409
|
-
#!/bin/bash
|
410
|
-
exit 0
|
411
|
-
"""
|
412
|
-
And a file named "spec/run_spec.rb" with:
|
413
|
-
"""ruby
|
414
|
-
require 'spec_helper'
|
415
|
-
|
416
|
-
RSpec.describe 'Run command', :type => :aruba do
|
417
|
-
before(:each) { run_command('aruba-test-cli') }
|
418
|
-
let!(:found_command) { find_command('aruba-test-cli') }
|
419
|
-
it { expect { found_command.start }.to raise_error Aruba::CommandAlreadyStartedError }
|
420
|
-
end
|
421
|
-
"""
|
422
|
-
When I run `rspec`
|
423
|
-
Then the specs should all pass
|