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.
Files changed (246) hide show
  1. checksums.yaml +5 -5
  2. data/.cucumberproignore +3 -0
  3. data/.github/ISSUE_TEMPLATE.md +48 -0
  4. data/.github/PULL_REQUEST_TEMPLATE.md +39 -0
  5. data/.gitignore +1 -0
  6. data/.rspec +1 -0
  7. data/.rubocop.yml +1 -5
  8. data/.travis.yml +35 -27
  9. data/CONTRIBUTING.md +131 -29
  10. data/Dockerfile +67 -0
  11. data/Gemfile +33 -80
  12. data/History.md +602 -0
  13. data/README.md +24 -196
  14. data/Rakefile +87 -27
  15. data/appveyor.yml +0 -1
  16. data/aruba.gemspec +30 -40
  17. data/bin/bootstrap +34 -0
  18. data/bin/build +3 -0
  19. data/{script → bin}/console +0 -0
  20. data/bin/release +3 -0
  21. data/bin/test +9 -0
  22. data/cucumber.yml +1 -3
  23. data/docker-compose.yml +26 -0
  24. data/{bin → exec}/aruba +0 -0
  25. data/fixtures/cli-app/README.md +1 -1
  26. data/fixtures/cli-app/features/support/aruba.rb +1 -0
  27. data/fixtures/cli-app/features/support/env.rb +1 -1
  28. data/fixtures/cli-app/lib/cli/app.rb +1 -5
  29. data/fixtures/cli-app/spec/spec_helper.rb +1 -6
  30. data/fixtures/empty-app/lib/cli/app.rb +2 -0
  31. data/lib/aruba/api.rb +3 -3
  32. data/lib/aruba/api/{commands.rb → command.rb} +4 -30
  33. data/lib/aruba/api/core.rb +8 -25
  34. data/lib/aruba/api/deprecated.rb +150 -408
  35. data/lib/aruba/api/filesystem.rb +17 -2
  36. data/lib/aruba/api/rvm.rb +44 -0
  37. data/lib/aruba/aruba_path.rb +56 -32
  38. data/lib/aruba/basic_configuration.rb +3 -5
  39. data/lib/aruba/colorizer.rb +99 -10
  40. data/lib/aruba/command.rb +0 -2
  41. data/lib/aruba/config.rb +5 -5
  42. data/lib/aruba/config/jruby.rb +5 -15
  43. data/lib/aruba/console.rb +2 -0
  44. data/lib/aruba/console/help.rb +1 -7
  45. data/lib/aruba/cucumber.rb +0 -2
  46. data/lib/aruba/cucumber/command.rb +98 -72
  47. data/lib/aruba/cucumber/file.rb +15 -3
  48. data/lib/aruba/cucumber/hooks.rb +71 -10
  49. data/lib/aruba/event_bus/name_resolver.rb +2 -10
  50. data/lib/aruba/generators/script_file.rb +1 -1
  51. data/lib/aruba/in_process.rb +0 -2
  52. data/lib/aruba/initializer.rb +4 -14
  53. data/lib/aruba/matchers/base/object_formatter.rb +0 -5
  54. data/lib/aruba/matchers/file/have_same_file_content.rb +5 -5
  55. data/lib/aruba/matchers/string/output_string_eq.rb +1 -1
  56. data/lib/aruba/platforms/announcer.rb +11 -16
  57. data/lib/aruba/platforms/aruba_file_creator.rb +1 -5
  58. data/lib/aruba/platforms/aruba_logger.rb +1 -5
  59. data/lib/aruba/platforms/command_monitor.rb +10 -14
  60. data/lib/aruba/platforms/determine_disk_usage.rb +8 -3
  61. data/lib/aruba/platforms/filesystem_status.rb +1 -5
  62. data/lib/aruba/platforms/unix_command_string.rb +1 -8
  63. data/lib/aruba/platforms/unix_environment_variables.rb +6 -8
  64. data/lib/aruba/platforms/unix_platform.rb +9 -22
  65. data/lib/aruba/platforms/unix_which.rb +4 -0
  66. data/lib/aruba/platforms/windows_command_string.rb +6 -14
  67. data/lib/aruba/platforms/windows_environment_variables.rb +4 -16
  68. data/lib/aruba/platforms/windows_which.rb +4 -0
  69. data/lib/aruba/processes/basic_process.rb +22 -18
  70. data/lib/aruba/processes/spawn_process.rb +12 -35
  71. data/lib/aruba/rspec.rb +1 -0
  72. data/lib/aruba/runtime.rb +3 -4
  73. data/lib/aruba/setup.rb +9 -11
  74. data/lib/aruba/spawn_process.rb +1 -4
  75. data/lib/aruba/tasks/docker_helpers.rb +158 -0
  76. data/lib/aruba/version.rb +1 -1
  77. metadata +62 -230
  78. data/CHANGELOG.md +0 -991
  79. data/features/.nav +0 -72
  80. data/features/01_getting_started_with_aruba/cleanup_working_directory.feature +0 -57
  81. data/features/01_getting_started_with_aruba/run_commands.feature +0 -217
  82. data/features/01_getting_started_with_aruba/supported_testing_frameworks.feature +0 -88
  83. data/features/02_configure_aruba/activate_announcer_on_command_failure.feature +0 -38
  84. data/features/02_configure_aruba/basics.feature +0 -151
  85. data/features/02_configure_aruba/command_runtime_environment.feature +0 -129
  86. data/features/02_configure_aruba/console_history_file.feature +0 -38
  87. data/features/02_configure_aruba/exit_timeout.feature +0 -60
  88. data/features/02_configure_aruba/fixtures_directories.feature +0 -38
  89. data/features/02_configure_aruba/fixtures_path_prefix.feature +0 -23
  90. data/features/02_configure_aruba/home_directory.feature +0 -80
  91. data/features/02_configure_aruba/io_timeout.feature +0 -30
  92. data/features/02_configure_aruba/keep_ansi.feature +0 -30
  93. data/features/02_configure_aruba/log_level.feature +0 -38
  94. data/features/02_configure_aruba/physical_block_size.feature +0 -53
  95. data/features/02_configure_aruba/remove_ansi_escape_sequences.feature +0 -38
  96. data/features/02_configure_aruba/root_directory.feature +0 -30
  97. data/features/02_configure_aruba/startup_wait_time.feature +0 -48
  98. data/features/02_configure_aruba/working_directory.feature +0 -38
  99. data/features/03_testing_frameworks/cucumber/announce_information_for_troubleshooting.feature +0 -306
  100. data/features/03_testing_frameworks/cucumber/disable_bunder.feature +0 -18
  101. data/features/03_testing_frameworks/cucumber/steps/command/check_for_exit_statuses.feature +0 -136
  102. data/features/03_testing_frameworks/cucumber/steps/command/check_output_of_command.feature +0 -514
  103. data/features/03_testing_frameworks/cucumber/steps/command/check_stderr_of_command.feature +0 -68
  104. data/features/03_testing_frameworks/cucumber/steps/command/check_stdout_of_command.feature +0 -109
  105. data/features/03_testing_frameworks/cucumber/steps/command/debug_your_command_in_aruba.feature +0 -118
  106. data/features/03_testing_frameworks/cucumber/steps/command/run_a_command.feature +0 -66
  107. data/features/03_testing_frameworks/cucumber/steps/command/run_command_in_process.feature +0 -485
  108. data/features/03_testing_frameworks/cucumber/steps/command/run_command_interactively.feature +0 -90
  109. data/features/03_testing_frameworks/cucumber/steps/command/run_commands_which_require_a_shell.feature +0 -79
  110. data/features/03_testing_frameworks/cucumber/steps/command/send_signal_to_command.feature +0 -83
  111. data/features/03_testing_frameworks/cucumber/steps/command/stop_command.feature +0 -285
  112. data/features/03_testing_frameworks/cucumber/steps/environment/append_environment_variable.feature +0 -52
  113. data/features/03_testing_frameworks/cucumber/steps/environment/modify_home_variable_for_testing.feature +0 -62
  114. data/features/03_testing_frameworks/cucumber/steps/environment/prepend_environment_variable.feature +0 -52
  115. data/features/03_testing_frameworks/cucumber/steps/environment/set_environment_variable.feature +0 -49
  116. data/features/03_testing_frameworks/cucumber/steps/filesystem/append_to_file.feature +0 -45
  117. data/features/03_testing_frameworks/cucumber/steps/filesystem/cd_to_directory.feature +0 -33
  118. data/features/03_testing_frameworks/cucumber/steps/filesystem/check_existence_of_directory.feature +0 -57
  119. data/features/03_testing_frameworks/cucumber/steps/filesystem/check_existence_of_file.feature +0 -43
  120. data/features/03_testing_frameworks/cucumber/steps/filesystem/check_file_content.feature +0 -143
  121. data/features/03_testing_frameworks/cucumber/steps/filesystem/check_non_existence_of_directory.feature +0 -69
  122. data/features/03_testing_frameworks/cucumber/steps/filesystem/check_non_existence_of_file.feature +0 -80
  123. data/features/03_testing_frameworks/cucumber/steps/filesystem/check_permissions_of_file.feature +0 -39
  124. data/features/03_testing_frameworks/cucumber/steps/filesystem/compare_files.feature +0 -42
  125. data/features/03_testing_frameworks/cucumber/steps/filesystem/copy_file_or_directory.feature +0 -45
  126. data/features/03_testing_frameworks/cucumber/steps/filesystem/create_directory.feature +0 -57
  127. data/features/03_testing_frameworks/cucumber/steps/filesystem/create_file.feature +0 -76
  128. data/features/03_testing_frameworks/cucumber/steps/filesystem/move_file_or_directory.feature +0 -44
  129. data/features/03_testing_frameworks/cucumber/steps/filesystem/overwrite_file.feature +0 -72
  130. data/features/03_testing_frameworks/cucumber/steps/filesystem/remove_directory.feature +0 -38
  131. data/features/03_testing_frameworks/cucumber/steps/filesystem/remove_file.feature +0 -38
  132. data/features/03_testing_frameworks/cucumber/steps/filesystem/use_fixtures_for_setup_test.feature +0 -77
  133. data/features/03_testing_frameworks/rspec/hooks/define_after_hook_for_commands.feature +0 -43
  134. data/features/03_testing_frameworks/rspec/hooks/define_before_hook_for_commands.feature +0 -71
  135. data/features/03_testing_frameworks/rspec/setup_aruba_for_rspec.feature +0 -179
  136. data/features/04_aruba_api/command/find_a_started_command.feature +0 -83
  137. data/features/04_aruba_api/command/find_command_in_PATH.feature +0 -37
  138. data/features/04_aruba_api/command/read_stderr_of_command.feature +0 -46
  139. data/features/04_aruba_api/command/read_stdout_of_command.feature +0 -46
  140. data/features/04_aruba_api/command/run_command.feature +0 -423
  141. data/features/04_aruba_api/command/run_simple.feature +0 -254
  142. data/features/04_aruba_api/command/send_signal_to_command.feature +0 -53
  143. data/features/04_aruba_api/command/stop_all_commands.feature +0 -57
  144. data/features/04_aruba_api/command/stop_single_command.feature +0 -132
  145. data/features/04_aruba_api/command/terminate_all_commands.feature +0 -57
  146. data/features/04_aruba_api/command/use_last_command_started.feature +0 -50
  147. data/features/04_aruba_api/command/use_last_command_stopped.feature +0 -89
  148. data/features/04_aruba_api/core/expand_path.feature +0 -88
  149. data/features/04_aruba_api/environment/append_environment_variable.feature +0 -128
  150. data/features/04_aruba_api/environment/delete_environment_variable.feature +0 -63
  151. data/features/04_aruba_api/environment/prepend_environment_variable.feature +0 -128
  152. data/features/04_aruba_api/environment/set_environment_variable.feature +0 -376
  153. data/features/04_aruba_api/filesystem/cd_to_directory.feature +0 -184
  154. data/features/04_aruba_api/filesystem/check_existence_file_or_directory.feature +0 -62
  155. data/features/04_aruba_api/filesystem/check_if_path_is_absolute.feature +0 -48
  156. data/features/04_aruba_api/filesystem/check_if_path_is_directory.feature +0 -53
  157. data/features/04_aruba_api/filesystem/check_if_path_is_file.feature +0 -54
  158. data/features/04_aruba_api/filesystem/check_if_path_is_relative.feature +0 -48
  159. data/features/04_aruba_api/filesystem/create_directory.feature +0 -57
  160. data/features/04_aruba_api/filesystem/move_file_or_directory.feature +0 -119
  161. data/features/04_aruba_api/filesystem/report_disk_usage.feature +0 -152
  162. data/features/04_aruba_api/filesystem/use_fixtures.feature +0 -104
  163. data/features/04_aruba_api/text/extract_text.feature +0 -87
  164. data/features/04_aruba_api/text/replace_variables.feature +0 -45
  165. data/features/04_aruba_api/text/sanitize_text.feature +0 -228
  166. data/features/04_aruba_api/text/unescape_text.feature +0 -127
  167. data/features/05_use_rspec_matchers/command/check_timeouts.feature +0 -48
  168. data/features/05_use_rspec_matchers/directory/have_sub_directory.feature +0 -110
  169. data/features/05_use_rspec_matchers/file/be_a_command_found_in_path.feature +0 -115
  170. data/features/05_use_rspec_matchers/file/be_existing_executable.feature +0 -88
  171. data/features/05_use_rspec_matchers/file/be_existing_file.feature +0 -82
  172. data/features/05_use_rspec_matchers/file/have_file_content.feature +0 -123
  173. data/features/05_use_rspec_matchers/file/have_file_size.feature +0 -107
  174. data/features/05_use_rspec_matchers/path/be_an_absolute_path.feature +0 -74
  175. data/features/05_use_rspec_matchers/path/be_an_existing_path.feature +0 -97
  176. data/features/05_use_rspec_matchers/path/have_permissions.feature +0 -118
  177. data/features/06_use_aruba_cli/initialize_project_with_aruba.feature +0 -79
  178. data/features/06_use_aruba_cli/open_console.feature +0 -55
  179. data/features/08_other/improve_performance_if_using_jruby.feature +0 -37
  180. data/features/step_definitions/hooks.rb +0 -146
  181. data/features/support/aruba.rb +0 -7
  182. data/features/support/env.rb +0 -33
  183. data/features/support/simplecov_setup.rb +0 -11
  184. data/lib/aruba/api/bundler.rb +0 -16
  185. data/lib/aruba/cucumber/deprecated.rb +0 -93
  186. data/lib/aruba/matchers/deprecated.rb +0 -1
  187. data/lib/aruba/matchers/deprecated/file.rb +0 -17
  188. data/lib/aruba/reporting.rb +0 -126
  189. data/script/bootstrap +0 -24
  190. data/script/test +0 -3
  191. data/spec/aruba/api/bundler_spec.rb +0 -15
  192. data/spec/aruba/api/commands_spec.rb +0 -30
  193. data/spec/aruba/api/core_spec.rb +0 -184
  194. data/spec/aruba/api/deprecated_spec.rb +0 -421
  195. data/spec/aruba/api/filesystem_spec.rb +0 -746
  196. data/spec/aruba/api/runtime_spec.rb +0 -28
  197. data/spec/aruba/api_spec.rb +0 -73
  198. data/spec/aruba/aruba_path_spec.rb +0 -103
  199. data/spec/aruba/basic_configuration_spec.rb +0 -5
  200. data/spec/aruba/configuration_spec.rb +0 -5
  201. data/spec/aruba/hooks_spec.rb +0 -17
  202. data/spec/aruba/in_config_wrapper_spec.rb +0 -25
  203. data/spec/aruba/jruby_spec.rb +0 -73
  204. data/spec/aruba/matchers/command/have_output_size_spec.rb +0 -25
  205. data/spec/aruba/matchers/command_spec.rb +0 -174
  206. data/spec/aruba/matchers/deprecated_spec.rb +0 -120
  207. data/spec/aruba/matchers/directory_spec.rb +0 -57
  208. data/spec/aruba/matchers/file_spec.rb +0 -208
  209. data/spec/aruba/matchers/path_spec.rb +0 -58
  210. data/spec/aruba/platform/simple_table_spec.rb +0 -23
  211. data/spec/aruba/platform/windows_environment_variables_spec.rb +0 -500
  212. data/spec/aruba/platforms/unix_command_string_spec.rb +0 -17
  213. data/spec/aruba/platforms/windows_command_string_spec.rb +0 -22
  214. data/spec/aruba/processes/spawn_process_spec.rb +0 -112
  215. data/spec/aruba/rspec_spec.rb +0 -15
  216. data/spec/aruba/runtime_spec.rb +0 -29
  217. data/spec/event_bus/name_resolver_spec.rb +0 -68
  218. data/spec/event_bus_spec.rb +0 -158
  219. data/spec/spec_helper.rb +0 -22
  220. data/spec/support/configs/.keep +0 -0
  221. data/spec/support/configs/aruba.rb +0 -5
  222. data/spec/support/configs/pry.rb +0 -3
  223. data/spec/support/configs/rspec.rb +0 -15
  224. data/spec/support/helpers/.keep +0 -0
  225. data/spec/support/helpers/reporting.rb +0 -44
  226. data/spec/support/matchers/.keep +0 -0
  227. data/spec/support/matchers/option.rb +0 -35
  228. data/spec/support/shared_contexts/.keep +0 -0
  229. data/spec/support/shared_contexts/aruba.rb +0 -49
  230. data/spec/support/shared_examples/.keep +0 -0
  231. data/spec/support/shared_examples/configuration.rb +0 -116
  232. data/spec/support/shared_examples/directory.rb +0 -7
  233. data/spec/support/shared_examples/file.rb +0 -7
  234. data/templates/css/console.css +0 -24
  235. data/templates/css/filesystem.css +0 -42
  236. data/templates/css/pygments-autumn.css +0 -59
  237. data/templates/files.erb +0 -14
  238. data/templates/images/LICENSE +0 -22
  239. data/templates/images/folder.png +0 -0
  240. data/templates/images/page_white.png +0 -0
  241. data/templates/images/page_white_gherkin.png +0 -0
  242. data/templates/images/page_white_ruby.png +0 -0
  243. data/templates/index.erb +0 -20
  244. data/templates/js/filesystem.js +0 -5
  245. data/templates/js/jquery-1.11.3.min.js +0 -5
  246. 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