beaker 4.38.1 → 5.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (225) hide show
  1. checksums.yaml +4 -4
  2. data/.github/dependabot.yml +9 -0
  3. data/.github/workflows/release.yml +2 -2
  4. data/.github/workflows/test.yml +36 -11
  5. data/.rubocop.yml +75 -0
  6. data/.rubocop_todo.yml +239 -0
  7. data/CHANGELOG.md +88 -33
  8. data/Gemfile +16 -4
  9. data/HISTORY.md +103 -0
  10. data/Rakefile +101 -112
  11. data/acceptance/config/acceptance-options.rb +1 -1
  12. data/acceptance/config/base/acceptance-options.rb +2 -2
  13. data/acceptance/config/hypervisor/acceptance-options.rb +2 -2
  14. data/acceptance/config/subcommands/acceptance-options.rb +2 -2
  15. data/acceptance/fixtures/module/Gemfile +1 -1
  16. data/acceptance/fixtures/module/Rakefile +3 -3
  17. data/acceptance/fixtures/module/spec/acceptance/demo_spec.rb +16 -23
  18. data/acceptance/fixtures/module/spec/classes/init_spec.rb +1 -2
  19. data/acceptance/fixtures/module/spec/spec_helper_acceptance.rb +3 -5
  20. data/acceptance/lib/helpers/test_helper.rb +7 -6
  21. data/acceptance/pre_suite/subcommands/05_install_ruby.rb +2 -3
  22. data/acceptance/pre_suite/subcommands/08_install_beaker.rb +1 -2
  23. data/acceptance/tests/base/dsl/helpers/configuration_test.rb +4 -4
  24. data/acceptance/tests/base/dsl/helpers/hocon_helpers_test.rb +7 -8
  25. data/acceptance/tests/base/dsl/helpers/host_helpers/add_system32_hosts_entry_test.rb +0 -3
  26. data/acceptance/tests/base/dsl/helpers/host_helpers/archive_file_from_test.rb +9 -7
  27. data/acceptance/tests/base/dsl/helpers/host_helpers/backup_the_file_test.rb +15 -21
  28. data/acceptance/tests/base/dsl/helpers/host_helpers/check_for_package_test.rb +0 -4
  29. data/acceptance/tests/base/dsl/helpers/host_helpers/create_remote_file_test.rb +23 -30
  30. data/acceptance/tests/base/dsl/helpers/host_helpers/curl_on_test.rb +3 -3
  31. data/acceptance/tests/base/dsl/helpers/host_helpers/curl_with_retries_test.rb +0 -1
  32. data/acceptance/tests/base/dsl/helpers/host_helpers/on_test.rb +21 -16
  33. data/acceptance/tests/base/dsl/helpers/host_helpers/retry_on_test.rb +7 -7
  34. data/acceptance/tests/base/dsl/helpers/host_helpers/rsync_to_test.rb +30 -38
  35. data/acceptance/tests/base/dsl/helpers/host_helpers/run_cron_on_test.rb +14 -18
  36. data/acceptance/tests/base/dsl/helpers/host_helpers/run_script_on_test.rb +8 -14
  37. data/acceptance/tests/base/dsl/helpers/host_helpers/run_script_test.rb +7 -11
  38. data/acceptance/tests/base/dsl/helpers/host_helpers/scp_from_test.rb +5 -5
  39. data/acceptance/tests/base/dsl/helpers/host_helpers/scp_to_test.rb +4 -5
  40. data/acceptance/tests/base/dsl/helpers/host_helpers/shell_test.rb +8 -8
  41. data/acceptance/tests/base/dsl/helpers/host_helpers/upgrade_package_test.rb +4 -6
  42. data/acceptance/tests/base/dsl/platform_tag_confiner_test.rb +14 -17
  43. data/acceptance/tests/base/dsl/structure_test.rb +9 -21
  44. data/acceptance/tests/base/host/file_test.rb +8 -8
  45. data/acceptance/tests/base/host/group_test.rb +2 -3
  46. data/acceptance/tests/base/host/host_test.rb +69 -66
  47. data/acceptance/tests/base/host/packages.rb +27 -30
  48. data/acceptance/tests/base/host/packages_unix.rb +0 -55
  49. data/acceptance/tests/base/host/user_test.rb +2 -3
  50. data/acceptance/tests/base/host_prebuilt_steps/ssh_environment_test.rb +1 -2
  51. data/acceptance/tests/base/test_suite/export.rb +6 -9
  52. data/acceptance/tests/install/from_file.rb +3 -5
  53. data/acceptance/tests/load_path_bootstrap.rb +1 -1
  54. data/acceptance/tests/subcommands/destroy.rb +19 -21
  55. data/acceptance/tests/subcommands/exec.rb +0 -1
  56. data/acceptance/tests/subcommands/init.rb +2 -3
  57. data/acceptance/tests/subcommands/provision.rb +0 -1
  58. data/beaker.gemspec +10 -14
  59. data/docs/concepts/argument_processing_and_precedence.md +1 -10
  60. data/docs/concepts/style_guide.md +1 -1
  61. data/docs/how_to/debug_beaker_tests.md +13 -13
  62. data/docs/how_to/hosts/eos.md +2 -12
  63. data/docs/how_to/install_puppet.md +0 -18
  64. data/docs/how_to/test_arbitrary_beaker_versions.md +2 -2
  65. data/docs/how_to/the_beaker_dsl.md +0 -2
  66. data/lib/beaker/cli.rb +63 -74
  67. data/lib/beaker/command.rb +22 -30
  68. data/lib/beaker/command_factory.rb +4 -3
  69. data/lib/beaker/dsl/assertions.rb +7 -19
  70. data/lib/beaker/dsl/helpers/hocon_helpers.rb +5 -9
  71. data/lib/beaker/dsl/helpers/host_helpers.rb +72 -133
  72. data/lib/beaker/dsl/helpers/test_helpers.rb +3 -5
  73. data/lib/beaker/dsl/helpers/web_helpers.rb +20 -28
  74. data/lib/beaker/dsl/helpers.rb +2 -4
  75. data/lib/beaker/dsl/outcomes.rb +17 -19
  76. data/lib/beaker/dsl/patterns.rb +1 -3
  77. data/lib/beaker/dsl/roles.rb +18 -21
  78. data/lib/beaker/dsl/structure.rb +55 -67
  79. data/lib/beaker/dsl/test_tagging.rb +7 -10
  80. data/lib/beaker/dsl/wrappers.rb +15 -16
  81. data/lib/beaker/dsl.rb +2 -3
  82. data/lib/beaker/host/aix/exec.rb +1 -1
  83. data/lib/beaker/host/aix/file.rb +0 -1
  84. data/lib/beaker/host/aix/group.rb +3 -3
  85. data/lib/beaker/host/aix/user.rb +3 -3
  86. data/lib/beaker/host/aix.rb +3 -4
  87. data/lib/beaker/host/cisco.rb +36 -48
  88. data/lib/beaker/host/eos.rb +4 -30
  89. data/lib/beaker/host/freebsd/exec.rb +1 -1
  90. data/lib/beaker/host/freebsd/pkg.rb +3 -3
  91. data/lib/beaker/host/freebsd.rb +9 -12
  92. data/lib/beaker/host/mac/exec.rb +5 -5
  93. data/lib/beaker/host/mac/group.rb +13 -13
  94. data/lib/beaker/host/mac/pkg.rb +6 -109
  95. data/lib/beaker/host/mac/user.rb +7 -7
  96. data/lib/beaker/host/mac.rb +8 -9
  97. data/lib/beaker/host/pswindows/exec.rb +70 -74
  98. data/lib/beaker/host/pswindows/file.rb +4 -6
  99. data/lib/beaker/host/pswindows/group.rb +5 -5
  100. data/lib/beaker/host/pswindows/pkg.rb +17 -17
  101. data/lib/beaker/host/pswindows/user.rb +4 -4
  102. data/lib/beaker/host/pswindows.rb +4 -3
  103. data/lib/beaker/host/unix/exec.rb +86 -88
  104. data/lib/beaker/host/unix/file.rb +41 -47
  105. data/lib/beaker/host/unix/group.rb +3 -3
  106. data/lib/beaker/host/unix/pkg.rb +158 -421
  107. data/lib/beaker/host/unix/user.rb +4 -4
  108. data/lib/beaker/host/unix.rb +18 -20
  109. data/lib/beaker/host/windows/exec.rb +20 -20
  110. data/lib/beaker/host/windows/file.rb +5 -5
  111. data/lib/beaker/host/windows/group.rb +5 -5
  112. data/lib/beaker/host/windows/pkg.rb +6 -57
  113. data/lib/beaker/host/windows/user.rb +4 -4
  114. data/lib/beaker/host/windows.rb +13 -13
  115. data/lib/beaker/host.rb +82 -139
  116. data/lib/beaker/host_prebuilt_steps.rb +121 -233
  117. data/lib/beaker/hypervisor/noop.rb +2 -4
  118. data/lib/beaker/hypervisor.rb +46 -63
  119. data/lib/beaker/local_connection.rb +4 -6
  120. data/lib/beaker/logger.rb +71 -85
  121. data/lib/beaker/logger_junit.rb +22 -26
  122. data/lib/beaker/network_manager.rb +40 -43
  123. data/lib/beaker/options/command_line_parser.rb +12 -23
  124. data/lib/beaker/options/hosts_file_parser.rb +34 -25
  125. data/lib/beaker/options/options_file_parser.rb +3 -6
  126. data/lib/beaker/options/options_hash.rb +3 -10
  127. data/lib/beaker/options/parser.rb +89 -105
  128. data/lib/beaker/options/presets.rb +114 -123
  129. data/lib/beaker/options/subcommand_options_file_parser.rb +3 -6
  130. data/lib/beaker/options/validator.rb +26 -31
  131. data/lib/beaker/perf.rb +29 -34
  132. data/lib/beaker/platform.rb +38 -46
  133. data/lib/beaker/result.rb +7 -6
  134. data/lib/beaker/shared/error_handler.rb +8 -10
  135. data/lib/beaker/shared/fog_credentials.rb +5 -9
  136. data/lib/beaker/shared/host_manager.rb +40 -46
  137. data/lib/beaker/shared/options_resolver.rb +3 -7
  138. data/lib/beaker/shared/repetition.rb +6 -8
  139. data/lib/beaker/shared/semvar.rb +39 -43
  140. data/lib/beaker/shared/timed.rb +2 -5
  141. data/lib/beaker/shared.rb +1 -1
  142. data/lib/beaker/ssh_connection.rb +46 -55
  143. data/lib/beaker/subcommand.rb +23 -30
  144. data/lib/beaker/subcommands/subcommand_util.rb +4 -4
  145. data/lib/beaker/tasks/quick_start.rb +5 -10
  146. data/lib/beaker/tasks/rake_task.rb +26 -28
  147. data/lib/beaker/tasks/test.rb +4 -4
  148. data/lib/beaker/test_case.rb +15 -27
  149. data/lib/beaker/test_suite.rb +35 -39
  150. data/lib/beaker/test_suite_result.rb +52 -57
  151. data/lib/beaker/version.rb +1 -1
  152. data/lib/beaker.rb +5 -6
  153. data/spec/beaker/cli_spec.rb +135 -153
  154. data/spec/beaker/command_spec.rb +64 -58
  155. data/spec/beaker/dsl/assertions_spec.rb +38 -47
  156. data/spec/beaker/dsl/helpers/host_helpers_spec.rb +114 -135
  157. data/spec/beaker/dsl/helpers/test_helpers_spec.rb +9 -10
  158. data/spec/beaker/dsl/helpers/web_helpers_spec.rb +30 -36
  159. data/spec/beaker/dsl/outcomes_spec.rb +15 -14
  160. data/spec/beaker/dsl/roles_spec.rb +170 -132
  161. data/spec/beaker/dsl/structure_spec.rb +181 -163
  162. data/spec/beaker/dsl/test_tagging_spec.rb +94 -95
  163. data/spec/beaker/dsl/wrappers_spec.rb +39 -40
  164. data/spec/beaker/host/aix_spec.rb +14 -14
  165. data/spec/beaker/host/cisco_spec.rb +92 -102
  166. data/spec/beaker/host/eos_spec.rb +15 -36
  167. data/spec/beaker/host/freebsd/exec_spec.rb +5 -8
  168. data/spec/beaker/host/freebsd/pkg_spec.rb +29 -29
  169. data/spec/beaker/host/mac/exec_spec.rb +4 -5
  170. data/spec/beaker/host/mac/group_spec.rb +47 -56
  171. data/spec/beaker/host/mac/user_spec.rb +53 -62
  172. data/spec/beaker/host/pswindows/exec_spec.rb +36 -35
  173. data/spec/beaker/host/pswindows/file_spec.rb +21 -18
  174. data/spec/beaker/host/pswindows/user_spec.rb +17 -23
  175. data/spec/beaker/host/pswindows_spec.rb +14 -14
  176. data/spec/beaker/host/unix/exec_spec.rb +87 -92
  177. data/spec/beaker/host/unix/file_spec.rb +76 -82
  178. data/spec/beaker/host/unix/pkg_spec.rb +165 -407
  179. data/spec/beaker/host/unix_spec.rb +11 -207
  180. data/spec/beaker/host/windows/exec_spec.rb +32 -34
  181. data/spec/beaker/host/windows/file_spec.rb +22 -23
  182. data/spec/beaker/host/windows/group_spec.rb +17 -19
  183. data/spec/beaker/host/windows/pkg_spec.rb +10 -13
  184. data/spec/beaker/host/windows/user_spec.rb +17 -23
  185. data/spec/beaker/host/windows_spec.rb +39 -39
  186. data/spec/beaker/host_prebuilt_steps_spec.rb +193 -341
  187. data/spec/beaker/host_spec.rb +241 -312
  188. data/spec/beaker/hypervisor/hypervisor_spec.rb +38 -63
  189. data/spec/beaker/localhost_connection_spec.rb +14 -13
  190. data/spec/beaker/logger_junit_spec.rb +22 -34
  191. data/spec/beaker/logger_spec.rb +174 -155
  192. data/spec/beaker/network_manager_spec.rb +27 -27
  193. data/spec/beaker/options/command_line_parser_spec.rb +20 -23
  194. data/spec/beaker/options/data/hosts_preserved.yml +395 -0
  195. data/spec/beaker/options/hosts_file_parser_spec.rb +36 -31
  196. data/spec/beaker/options/options_file_parser_spec.rb +4 -7
  197. data/spec/beaker/options/options_hash_spec.rb +7 -9
  198. data/spec/beaker/options/parser_spec.rb +187 -187
  199. data/spec/beaker/options/presets_spec.rb +8 -10
  200. data/spec/beaker/options/subcommand_options_parser_spec.rb +15 -15
  201. data/spec/beaker/options/validator_spec.rb +27 -28
  202. data/spec/beaker/perf_spec.rb +32 -34
  203. data/spec/beaker/platform_spec.rb +27 -37
  204. data/spec/beaker/shared/error_handler_spec.rb +8 -17
  205. data/spec/beaker/shared/fog_credentials_spec.rb +30 -30
  206. data/spec/beaker/shared/host_manager_spec.rb +55 -89
  207. data/spec/beaker/shared/options_resolver_spec.rb +9 -12
  208. data/spec/beaker/shared/repetition_spec.rb +24 -31
  209. data/spec/beaker/shared/semvar_spec.rb +21 -26
  210. data/spec/beaker/ssh_connection_spec.rb +85 -90
  211. data/spec/beaker/subcommand/subcommand_util_spec.rb +40 -37
  212. data/spec/beaker/subcommand_spec.rb +89 -89
  213. data/spec/beaker/test_case_spec.rb +33 -62
  214. data/spec/beaker/test_suite_spec.rb +153 -160
  215. data/spec/helpers.rb +48 -53
  216. data/spec/matchers.rb +9 -8
  217. data/spec/mocks.rb +6 -11
  218. data/spec/spec_helper.rb +0 -4
  219. metadata +60 -85
  220. data/acceptance/tests/base/dsl/helpers/host_helpers/deploy_package_repo_test.rb +0 -142
  221. data/acceptance/tests/base/external_resources_test.rb +0 -31
  222. data/spec/beaker/host/mac_spec.rb +0 -113
  223. data/spec/mock_fission.rb +0 -60
  224. data/spec/mock_vsphere.rb +0 -314
  225. data/spec/mock_vsphere_helper.rb +0 -183
@@ -2,63 +2,62 @@ require 'spec_helper'
2
2
 
3
3
  module Beaker
4
4
  describe Hypervisor do
5
- let( :hosts ) { make_hosts( { :platform => 'el-5' } ) }
5
+ let(:hosts) { make_hosts({ :platform => 'el-5' }) }
6
6
 
7
- context "#create" do
8
- let( :hypervisor ) { Beaker::Hypervisor }
7
+ describe "#create" do
8
+ let(:hypervisor) { described_class }
9
9
 
10
10
  it "includes custom hypervisor and call set_ssh_connection_preference" do
11
11
  allow(hypervisor).to receive(:set_ssh_connection_preference).with([], hypervisor)
12
- expect{ hypervisor.create('custom_hypervisor', [], make_opts() )}.to raise_error(LoadError, "cannot load such file -- beaker/hypervisor/custom_hypervisor")
12
+ expect { hypervisor.create('custom_hypervisor', [], make_opts) }.to raise_error(LoadError, "cannot load such file -- beaker/hypervisor/custom_hypervisor")
13
13
  end
14
14
 
15
15
  it "sets ssh connection preference if connection_preference method is not overwritten" do
16
- hypervisor.create('none', hosts, make_opts())
17
- expect(hosts[0][:ssh_connection_preference]).to eq([:ip,:vmhostname,:hostname])
16
+ hypervisor.create('none', hosts, make_opts)
17
+ expect(hosts[0][:ssh_connection_preference]).to eq(%i[ip vmhostname hostname])
18
18
  end
19
19
 
20
20
  it "concats overriding connection_preference array with the default connection_preference" do
21
- allow(hypervisor).to receive(:connection_preference).and_return([:my,:invalid,:method_name])
21
+ allow(hypervisor).to receive(:connection_preference).and_return(%i[my invalid method_name])
22
22
  hypervisor.set_ssh_connection_preference(hosts, hypervisor)
23
- expect(hosts[0][:ssh_connection_preference]).to eq([:my,:invalid,:method_name,:ip,:vmhostname,:hostname])
23
+ expect(hosts[0][:ssh_connection_preference]).to eq(%i[my invalid method_name ip vmhostname hostname])
24
24
  end
25
25
 
26
26
  it "removes unique elements from concated array while preserving order of overriding methods" do
27
- allow(hypervisor).to receive(:connection_preference).and_return([:my,:ip,:vmhostname,:method_name])
27
+ allow(hypervisor).to receive(:connection_preference).and_return(%i[my ip vmhostname method_name])
28
28
  hypervisor.set_ssh_connection_preference(hosts, hypervisor)
29
- expect(hosts[0][:ssh_connection_preference]).to eq([:my,:ip,:vmhostname,:method_name,:hostname])
29
+ expect(hosts[0][:ssh_connection_preference]).to eq(%i[my ip vmhostname method_name hostname])
30
30
  end
31
31
 
32
32
  it "gives highest precedence to preference specified in host file followed by hypervisor" do
33
- hosts[0].options[:ssh_preference] = [:set, :in, :hostfile]
34
- hypervisor.create('none', hosts, make_opts())
35
- allow(hypervisor).to receive(:connection_preference).and_return([:hypervisor, :pref])
33
+ hosts[0].options[:ssh_preference] = %i[set in hostfile]
34
+ hypervisor.create('none', hosts, make_opts)
35
+ allow(hypervisor).to receive(:connection_preference).and_return(%i[hypervisor pref])
36
36
  hypervisor.set_ssh_connection_preference(hosts, hypervisor)
37
- expect(hosts[0][:ssh_connection_preference]).to eq([:set, :in, :hostfile, :hypervisor, :pref, :ip, :vmhostname, :hostname])
37
+ expect(hosts[0][:ssh_connection_preference]).to eq(%i[set in hostfile hypervisor pref ip vmhostname hostname])
38
38
  end
39
-
40
39
  end
41
40
 
42
- context "#configure" do
43
- let( :options ) { make_opts.merge({ 'logger' => double().as_null_object }) }
44
- let( :hypervisor ) { Beaker::Hypervisor.new( hosts, options ) }
41
+ describe "#configure" do
42
+ let(:options) { make_opts.merge({ 'logger' => double.as_null_object }) }
43
+ let(:hypervisor) { described_class.new(hosts, options) }
45
44
 
46
45
  context 'if :timesync option set true on host' do
47
46
  it 'does call timesync for host' do
48
47
  hosts[0].options[:timesync] = true
49
- allow( hypervisor ).to receive( :set_env )
50
- expect( hypervisor ).to receive( :timesync ).once
48
+ allow(hypervisor).to receive(:set_env)
49
+ expect(hypervisor).to receive(:timesync).once
51
50
  hypervisor.configure
52
51
  end
53
52
 
54
53
  it 'catches signal exceptions and returns stack trace' do
55
- logger = double()
54
+ logger = double
56
55
  hosts[0].options[:timesync] = true
57
- allow( logger ).to receive( :error )
58
- allow( logger ).to receive( :pretty_backtrace ).and_return("multiline\nstring")
56
+ allow(logger).to receive(:error)
57
+ allow(logger).to receive(:pretty_backtrace).and_return("multiline\nstring")
59
58
  hypervisor.instance_variable_set(:@logger, logger)
60
59
  allow(Beaker::Command).to receive(:new).and_raise(SignalException.new('SIGTERM'))
61
- expect{ hypervisor.configure }.to raise_error(SignalException)
60
+ expect { hypervisor.configure }.to raise_error(SignalException)
62
61
  end
63
62
  end
64
63
 
@@ -66,8 +65,8 @@ module Beaker
66
65
  it 'does not call timesync for host' do
67
66
  options[:timesync] = true
68
67
  hosts[0].options[:timesync] = false
69
- allow( hypervisor ).to receive( :set_env )
70
- expect( hypervisor ).to_not receive( :timesync )
68
+ allow(hypervisor).to receive(:set_env)
69
+ expect(hypervisor).not_to receive(:timesync)
71
70
  hypervisor.configure
72
71
  end
73
72
  end
@@ -81,27 +80,9 @@ module Beaker
81
80
  hosts[1].options[:timesync] = true
82
81
  hosts[2].options[:timesync] = true
83
82
  options[:run_in_parallel] = ['configure']
84
- allow( hypervisor ).to receive( :set_env )
83
+ allow(hypervisor).to receive(:set_env)
85
84
  # This will only get hit if forking processes is supported and at least 2 items are being submitted to run in parallel
86
- expect( InParallel::InParallelExecutor ).to receive(:_execute_in_parallel).with(any_args).and_call_original.exactly(3).times
87
- hypervisor.configure
88
- end
89
- end
90
-
91
- context "if :disable_iptables option set false" do
92
- it "does not call disable_iptables" do
93
- options[:disable_iptables] = false
94
- allow( hypervisor ).to receive( :set_env )
95
- expect( hypervisor ).to receive( :disable_iptables ).never
96
- hypervisor.configure
97
- end
98
- end
99
-
100
- context "if :disable_iptables option set true" do
101
- it "calls disable_iptables once" do
102
- options[:disable_iptables] = true
103
- allow( hypervisor ).to receive( :set_env )
104
- expect( hypervisor ).to receive( :disable_iptables ).exactly( 1 ).times
85
+ expect(InParallel::InParallelExecutor).to receive(:_execute_in_parallel).with(any_args).and_call_original.exactly(3).times
105
86
  hypervisor.configure
106
87
  end
107
88
  end
@@ -109,8 +90,8 @@ module Beaker
109
90
  context "if :disable_updates option set true" do
110
91
  it "calls disable_updates" do
111
92
  options[:disable_updates] = true
112
- allow( hypervisor ).to receive( :set_env )
113
- expect( hypervisor ).to receive( :disable_updates ).once
93
+ allow(hypervisor).to receive(:set_env)
94
+ expect(hypervisor).to receive(:disable_updates).once
114
95
  hypervisor.configure
115
96
  end
116
97
  end
@@ -118,8 +99,8 @@ module Beaker
118
99
  context "if :disable_updates option set false" do
119
100
  it "does not call disable_updates_puppetlabs_com" do
120
101
  options[:disable_updates] = false
121
- allow( hypervisor ).to receive( :set_env )
122
- expect( hypervisor ).to receive( :disable_updates ).never
102
+ allow(hypervisor).to receive(:set_env)
103
+ expect(hypervisor).not_to receive(:disable_updates)
123
104
  hypervisor.configure
124
105
  end
125
106
  end
@@ -129,15 +110,11 @@ module Beaker
129
110
  options[:configure] = false
130
111
  options[:timesync] = true
131
112
  options[:root_keys] = true
132
- options[:add_el_extras] = true
133
- options[:disable_iptables] = true
134
113
  options[:host_name_prefix] = "test-"
135
- expect( hypervisor ).to_not receive( :timesync )
136
- expect( hypervisor ).to_not receive( :sync_root_keys )
137
- expect( hypervisor ).to_not receive( :add_el_extras )
138
- expect( hypervisor ).to_not receive( :disable_iptables )
139
- expect( hypervisor ).to_not receive( :set_env )
140
- expect( hypervisor ).to_not receive( :host_name_prefix )
114
+ expect(hypervisor).not_to receive(:timesync)
115
+ expect(hypervisor).not_to receive(:sync_root_keys)
116
+ expect(hypervisor).not_to receive(:set_env)
117
+ expect(hypervisor).not_to receive(:host_name_prefix)
141
118
  hypervisor.configure
142
119
  end
143
120
  end
@@ -145,7 +122,7 @@ module Beaker
145
122
  context 'if :configure option set true' do
146
123
  it 'does call set_env' do
147
124
  options[:configure] = true
148
- expect( hypervisor ).to receive( :set_env ).once
125
+ expect(hypervisor).to receive(:set_env).once
149
126
  hypervisor.configure
150
127
  end
151
128
  end
@@ -154,12 +131,10 @@ module Beaker
154
131
  it "generates hostname with prefix" do
155
132
  prefix = "testing-prefix-to-test-"
156
133
  options[:host_name_prefix] = prefix
157
- expect( hypervisor.generate_host_name().start_with?(prefix) ).to be true
158
- expect( hypervisor.generate_host_name().length - prefix.length >= 15 ).to be true
134
+ expect(hypervisor.generate_host_name.start_with?(prefix)).to be true
135
+ expect(hypervisor.generate_host_name.length - prefix.length >= 15).to be true
159
136
  end
160
137
  end
161
-
162
138
  end
163
-
164
139
  end
165
140
  end
@@ -3,18 +3,19 @@ require 'net/ssh'
3
3
 
4
4
  module Beaker
5
5
  describe LocalConnection do
6
- let( :options ) { { :logger => double('logger').as_null_object, :ssh_env_file => '/path/to/ssh/file'} }
7
- subject(:connection) { LocalConnection.new(options) }
6
+ subject(:connection) { described_class.new(options) }
8
7
 
9
- before :each do
10
- allow( subject ).to receive(:sleep)
8
+ let(:options) { { :logger => double('logger').as_null_object, :ssh_env_file => '/path/to/ssh/file' } }
9
+
10
+ before do
11
+ allow(subject).to receive(:sleep)
11
12
  end
12
13
 
13
14
  describe '#self.connect' do
14
15
  it 'loggs message' do
15
16
  expect(options[:logger]).to receive(:debug).with('Local connection, no connection to start')
16
- connection_constructor = LocalConnection.connect(options)
17
- expect( connection_constructor ).to be_a_kind_of LocalConnection
17
+ connection_constructor = described_class.connect(options)
18
+ expect(connection_constructor).to be_a described_class
18
19
  end
19
20
  end
20
21
 
@@ -28,22 +29,22 @@ module Beaker
28
29
  describe '#with_env' do
29
30
  it 'sets envs temporarily' do
30
31
  connection.connect
31
- connection.with_env({'my_env' => 'my_env_value'}) do
32
- expect(ENV.to_hash).to include({'my_env' => 'my_env_value'})
32
+ connection.with_env({ 'my_env' => 'my_env_value' }) do
33
+ expect(ENV.to_hash).to include({ 'my_env' => 'my_env_value' })
33
34
  end
34
- expect(ENV.to_hash).not_to include({'my_env' => 'my_env_value'})
35
+ expect(ENV.to_hash).not_to include({ 'my_env' => 'my_env_value' })
35
36
  end
36
37
  end
37
38
 
38
39
  describe '#execute' do
39
40
  it 'calls open3' do
40
- expect( Open3 ).to receive( :capture3 ).with({}, 'my_command')
41
+ expect(Open3).to receive(:capture3).with({}, 'my_command')
41
42
  connection.connect
42
- expect(connection.execute('my_command')).to be_a_kind_of Result
43
+ expect(connection.execute('my_command')).to be_a Result
43
44
  end
44
45
 
45
46
  it 'sets stdout, stderr and exitcode' do
46
- allow(Open3).to receive(:capture3).and_return(['stdout', 'stderr', double({exitstatus: 0})])
47
+ allow(Open3).to receive(:capture3).and_return(['stdout', 'stderr', double({ exitstatus: 0 })])
47
48
  connection.connect
48
49
  result = connection.execute('my_command')
49
50
  expect(result.exit_code).to eq(0)
@@ -52,7 +53,7 @@ module Beaker
52
53
  end
53
54
 
54
55
  it 'sets logger last_result' do
55
- allow(Open3).to receive(:capture3).and_return(['stdout', 'stderr', double({exitstatus: 0})])
56
+ allow(Open3).to receive(:capture3).and_return(['stdout', 'stderr', double({ exitstatus: 0 })])
56
57
  expect(options[:logger]).to receive(:last_result=).with(an_instance_of(Result))
57
58
  connection.connect
58
59
  connection.execute('my_command')
@@ -1,91 +1,79 @@
1
- # encoding: UTF-8
2
1
  require 'spec_helper'
3
2
 
4
3
  module Beaker
5
4
  describe LoggerJunit do
6
- let( :xml_file ) { '/fake/file/location1' }
7
- let( :stylesheet ) { '/fake/file/location2' }
5
+ let(:xml_file) { '/fake/file/location1' }
6
+ let(:stylesheet) { '/fake/file/location2' }
8
7
 
9
8
  describe '#is_valid_xml' do
10
-
11
9
  it 'rejects all invalid values' do
12
10
  invalid_values = [0x8, 0x10, 0xB, 0x0019, 0xD800, 0xDFFF, 0xFFFE, 0x99999, 0x110000]
13
11
  invalid_values.each do |value|
14
- expect( LoggerJunit.is_valid_xml(value) ).to be === false
12
+ expect(described_class.is_valid_xml(value)).to be === false
15
13
  end
16
14
  end
17
15
 
18
16
  it 'accepts valid values' do
19
17
  valid_values = [0x9, 0xA, 0x0020, 0xD7FF, 0xE000, 0xFFFD, 0x100000, 0x10FFFF]
20
18
  valid_values.each do |value|
21
- expect( LoggerJunit.is_valid_xml(value) ).to be === true
19
+ expect(described_class.is_valid_xml(value)).to be === true
22
20
  end
23
21
  end
24
-
25
22
  end
26
23
 
27
24
  describe '#escape_invalid_xml_chars' do
28
-
29
25
  it 'escapes invalid xml characters correctly' do
30
26
  testing_string = 'pants'
31
27
  testing_string << 0x8
32
- expect( LoggerJunit.escape_invalid_xml_chars(testing_string) ).to be === 'pants\8'
28
+ expect(described_class.escape_invalid_xml_chars(testing_string)).to be === 'pants\8'
33
29
  end
34
30
 
35
31
  it 'leaves a string of all valid xml characters alone' do
36
32
  testing_string = 'pants man, pants!'
37
- expect( LoggerJunit.escape_invalid_xml_chars(testing_string) ).to be === testing_string
33
+ expect(described_class.escape_invalid_xml_chars(testing_string)).to be === testing_string
38
34
  end
39
-
40
35
  end
41
36
 
42
37
  describe '#copy_stylesheet_into_xml_dir' do
43
-
44
38
  it 'copies the stylesheet into the correct location' do
45
- allow( File ).to receive( :file? ) { false }
39
+ allow(File).to receive(:file?).and_return(false)
46
40
  correct_location = File.join(File.dirname(xml_file), File.basename(stylesheet))
47
- expect( FileUtils ).to receive( :copy ).with( stylesheet, correct_location )
48
- LoggerJunit.copy_stylesheet_into_xml_dir(stylesheet, xml_file)
41
+ expect(FileUtils).to receive(:copy).with(stylesheet, correct_location)
42
+ described_class.copy_stylesheet_into_xml_dir(stylesheet, xml_file)
49
43
  end
50
44
 
51
45
  it 'skips action if the file doesn\'t exist' do
52
- allow( File ).to receive( :file? ) { true }
53
- expect( FileUtils ).not_to receive( :copy )
54
- LoggerJunit.copy_stylesheet_into_xml_dir(stylesheet, xml_file)
46
+ allow(File).to receive(:file?).and_return(true)
47
+ expect(FileUtils).not_to receive(:copy)
48
+ described_class.copy_stylesheet_into_xml_dir(stylesheet, xml_file)
55
49
  end
56
-
57
50
  end
58
51
 
59
52
  describe '#finish' do
60
-
61
53
  it 'opens the given file for writing, and writes the doc to it' do
62
54
  mock_doc = Object.new
63
- doc_xml = 'flibbity-floo'
64
- allow( mock_doc ).to receive( :write ).with(File, 2)
65
- expect( File ).to receive( :open ).with( xml_file, 'w' )
66
- LoggerJunit.finish(mock_doc, xml_file)
55
+ allow(mock_doc).to receive(:write).with(File, 2)
56
+ expect(File).to receive(:open).with(xml_file, 'w')
57
+ described_class.finish(mock_doc, xml_file)
67
58
  end
68
-
69
59
  end
70
60
 
71
61
  describe '#write_xml' do
72
-
73
62
  it 'throws an error with 1-arity in the given block' do
74
- allow( LoggerJunit ).to receive( :get_xml_contents )
75
- expect{ LoggerJunit.write_xml(xml_file, stylesheet) do |hey| end }.to raise_error(ArgumentError)
63
+ allow(described_class).to receive(:get_xml_contents)
64
+ expect { described_class.write_xml(xml_file, stylesheet) { |hey| } }.to raise_error(ArgumentError)
76
65
  end
77
66
 
78
67
  it 'doesn\'t throw an error with 2-arity in the given block' do
79
- allow( LoggerJunit ).to receive( :get_xml_contents )
80
- allow( LoggerJunit ).to receive( :finish )
81
- expect{ LoggerJunit.write_xml(xml_file, stylesheet) do |hey1, hey2| end }.not_to raise_error
68
+ allow(described_class).to receive(:get_xml_contents)
69
+ allow(described_class).to receive(:finish)
70
+ expect { described_class.write_xml(xml_file, stylesheet) { |hey1, hey2| } }.not_to raise_error
82
71
  end
83
72
 
84
73
  it 'throws an error with 3-arity in the given block' do
85
- allow( LoggerJunit ).to receive( :get_xml_contents )
86
- expect{ LoggerJunit.write_xml(xml_file, stylesheet) do |hey1, hey2, hey3| end }.to raise_error(ArgumentError)
74
+ allow(described_class).to receive(:get_xml_contents)
75
+ expect { described_class.write_xml(xml_file, stylesheet) { |hey1, hey2, hey3| } }.to raise_error(ArgumentError)
87
76
  end
88
-
89
77
  end
90
78
  end
91
79
  end