r10k 3.14.1 → 3.15.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (177) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/docker.yml +5 -0
  3. data/.github/workflows/rspec_tests.yml +1 -0
  4. data/CHANGELOG.mkd +19 -0
  5. data/CODEOWNERS +2 -2
  6. data/README.mkd +2 -2
  7. data/doc/dynamic-environments/configuration.mkd +78 -11
  8. data/doc/dynamic-environments/usage.mkd +4 -0
  9. data/doc/dynamic-environments/workflow-guide.mkd +3 -3
  10. data/doc/faq.mkd +1 -1
  11. data/docker/Makefile +17 -10
  12. data/integration/tests/git_source/HTTP_proxy_and_git_source.rb +1 -1
  13. data/integration/tests/git_source/git_source_repeated_remote.rb +2 -2
  14. data/integration/tests/purging/content_not_purged_at_root.rb +2 -2
  15. data/integration/tests/user_scenario/basic_workflow/multi_env_custom_forge_git_module.rb +1 -1
  16. data/integration/tests/user_scenario/basic_workflow/multi_env_custom_forge_git_module_static.rb +1 -1
  17. data/integration/tests/user_scenario/basic_workflow/multi_source_custom_forge_git_module.rb +1 -1
  18. data/integration/tests/user_scenario/basic_workflow/negative/neg_bad_git_module.rb +1 -1
  19. data/integration/tests/user_scenario/basic_workflow/negative/neg_bad_git_module_ref.rb +1 -1
  20. data/integration/tests/user_scenario/basic_workflow/single_env_custom_forge_git_module.rb +1 -1
  21. data/integration/tests/user_scenario/basic_workflow/single_env_switch_forge_git_module.rb +1 -1
  22. data/lib/r10k/environment/with_modules.rb +24 -1
  23. data/lib/r10k/git/rugged/thin_repository.rb +7 -0
  24. data/lib/r10k/git/rugged/working_repository.rb +7 -3
  25. data/lib/r10k/git/shellgit/thin_repository.rb +4 -0
  26. data/lib/r10k/git/shellgit/working_repository.rb +3 -2
  27. data/lib/r10k/git/stateful_repository.rb +4 -4
  28. data/lib/r10k/module/git.rb +1 -1
  29. data/lib/r10k/module_loader/puppetfile.rb +8 -5
  30. data/lib/r10k/settings/container.rb +1 -0
  31. data/lib/r10k/version.rb +1 -1
  32. data/r10k.gemspec +5 -7
  33. metadata +16 -154
  34. data/.travis.yml +0 -42
  35. data/spec/fixtures/empty/.empty +0 -0
  36. data/spec/fixtures/integration/git/puppet-boolean-bare.tar +0 -0
  37. data/spec/fixtures/module/forge/bad_module/metadata.json +0 -1
  38. data/spec/fixtures/module/forge/eight_hundred/Modulefile +0 -8
  39. data/spec/fixtures/module/forge/eight_hundred/metadata.json +0 -19
  40. data/spec/fixtures/tarball/tarball.tar.gz +0 -0
  41. data/spec/fixtures/unit/action/r10k.yaml +0 -5
  42. data/spec/fixtures/unit/action/r10k_cachedir.yaml +0 -2
  43. data/spec/fixtures/unit/action/r10k_creds.yaml +0 -9
  44. data/spec/fixtures/unit/action/r10k_forge_auth.yaml +0 -4
  45. data/spec/fixtures/unit/action/r10k_forge_auth_no_url.yaml +0 -3
  46. data/spec/fixtures/unit/action/r10k_generate_types.yaml +0 -3
  47. data/spec/fixtures/unit/action/r10k_logging.yaml +0 -12
  48. data/spec/fixtures/unit/action/r10k_puppet_path.yaml +0 -3
  49. data/spec/fixtures/unit/puppetfile/argument-error/Puppetfile +0 -1
  50. data/spec/fixtures/unit/puppetfile/default-branch-override/Puppetfile +0 -5
  51. data/spec/fixtures/unit/puppetfile/duplicate-module-error/Puppetfile +0 -10
  52. data/spec/fixtures/unit/puppetfile/forge-override/Puppetfile +0 -8
  53. data/spec/fixtures/unit/puppetfile/invalid-syntax/Puppetfile +0 -1
  54. data/spec/fixtures/unit/puppetfile/load-error/Puppetfile +0 -1
  55. data/spec/fixtures/unit/puppetfile/name-error/Puppetfile +0 -1
  56. data/spec/fixtures/unit/puppetfile/valid-forge-with-version/Puppetfile +0 -1
  57. data/spec/fixtures/unit/puppetfile/valid-forge-without-version/Puppetfile +0 -1
  58. data/spec/fixtures/unit/puppetfile/various-modules/Puppetfile +0 -10
  59. data/spec/fixtures/unit/puppetfile/various-modules/Puppetfile.new +0 -10
  60. data/spec/fixtures/unit/util/purgeable/managed_one/expected_1 +0 -0
  61. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/managed_symlink_file +0 -1
  62. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/subdir_allowlisted_2/ignored_1 +0 -0
  63. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/subdir_expected_1 +0 -0
  64. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/subdir_unmanaged_1 +0 -0
  65. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/unmanaged_symlink_dir +0 -1
  66. data/spec/fixtures/unit/util/purgeable/managed_one/managed_symlink_dir +0 -1
  67. data/spec/fixtures/unit/util/purgeable/managed_one/unmanaged_1 +0 -0
  68. data/spec/fixtures/unit/util/purgeable/managed_one/unmanaged_symlink_file +0 -1
  69. data/spec/fixtures/unit/util/purgeable/managed_two/.hidden/unmanaged_3 +0 -0
  70. data/spec/fixtures/unit/util/purgeable/managed_two/expected_2 +0 -0
  71. data/spec/fixtures/unit/util/purgeable/managed_two/unmanaged_2 +0 -0
  72. data/spec/fixtures/unit/util/subprocess/runner/no-execute.sh +0 -3
  73. data/spec/integration/git/rugged/bare_repository_spec.rb +0 -13
  74. data/spec/integration/git/rugged/cache_spec.rb +0 -33
  75. data/spec/integration/git/rugged/thin_repository_spec.rb +0 -14
  76. data/spec/integration/git/rugged/working_repository_spec.rb +0 -48
  77. data/spec/integration/git/shellgit/bare_repository_spec.rb +0 -13
  78. data/spec/integration/git/shellgit/thin_repository_spec.rb +0 -14
  79. data/spec/integration/git/shellgit/working_repository_spec.rb +0 -13
  80. data/spec/integration/git/stateful_repository_spec.rb +0 -159
  81. data/spec/integration/util/purageable_spec.rb +0 -41
  82. data/spec/matchers/exit_with.rb +0 -28
  83. data/spec/matchers/match_realpath.rb +0 -18
  84. data/spec/r10k-mocks/mock_config.rb +0 -33
  85. data/spec/r10k-mocks/mock_env.rb +0 -18
  86. data/spec/r10k-mocks/mock_source.rb +0 -17
  87. data/spec/r10k-mocks.rb +0 -3
  88. data/spec/shared-contexts/git-fixtures.rb +0 -55
  89. data/spec/shared-contexts/tarball.rb +0 -32
  90. data/spec/shared-examples/deploy-actions.rb +0 -69
  91. data/spec/shared-examples/git/bare_repository.rb +0 -132
  92. data/spec/shared-examples/git/thin_repository.rb +0 -26
  93. data/spec/shared-examples/git/working_repository.rb +0 -207
  94. data/spec/shared-examples/git-repository.rb +0 -38
  95. data/spec/shared-examples/puppetfile-action.rb +0 -39
  96. data/spec/shared-examples/settings/ancestry.rb +0 -44
  97. data/spec/shared-examples/subprocess-runner.rb +0 -89
  98. data/spec/spec_helper.rb +0 -41
  99. data/spec/unit/action/cri_runner_spec.rb +0 -72
  100. data/spec/unit/action/deploy/deploy_helpers_spec.rb +0 -38
  101. data/spec/unit/action/deploy/display_spec.rb +0 -61
  102. data/spec/unit/action/deploy/environment_spec.rb +0 -640
  103. data/spec/unit/action/deploy/module_spec.rb +0 -476
  104. data/spec/unit/action/puppetfile/check_spec.rb +0 -53
  105. data/spec/unit/action/puppetfile/cri_runner_spec.rb +0 -47
  106. data/spec/unit/action/puppetfile/install_spec.rb +0 -112
  107. data/spec/unit/action/puppetfile/purge_spec.rb +0 -60
  108. data/spec/unit/action/runner_spec.rb +0 -407
  109. data/spec/unit/action/visitor_spec.rb +0 -39
  110. data/spec/unit/cli_spec.rb +0 -9
  111. data/spec/unit/deployment/config_spec.rb +0 -33
  112. data/spec/unit/deployment_spec.rb +0 -162
  113. data/spec/unit/environment/bare_spec.rb +0 -13
  114. data/spec/unit/environment/base_spec.rb +0 -122
  115. data/spec/unit/environment/git_spec.rb +0 -114
  116. data/spec/unit/environment/name_spec.rb +0 -181
  117. data/spec/unit/environment/plain_spec.rb +0 -8
  118. data/spec/unit/environment/svn_spec.rb +0 -146
  119. data/spec/unit/environment/tarball_spec.rb +0 -45
  120. data/spec/unit/environment/with_modules_spec.rb +0 -75
  121. data/spec/unit/errors/formatting_spec.rb +0 -84
  122. data/spec/unit/feature_spec.rb +0 -50
  123. data/spec/unit/forge/module_release_spec.rb +0 -213
  124. data/spec/unit/git/alternates_spec.rb +0 -116
  125. data/spec/unit/git/cache_spec.rb +0 -66
  126. data/spec/unit/git/rugged/cache_spec.rb +0 -48
  127. data/spec/unit/git/rugged/credentials_spec.rb +0 -215
  128. data/spec/unit/git/shellgit/cache_spec.rb +0 -27
  129. data/spec/unit/git/stateful_repository_spec.rb +0 -45
  130. data/spec/unit/git_spec.rb +0 -102
  131. data/spec/unit/initializers_spec.rb +0 -68
  132. data/spec/unit/instance_cache_spec.rb +0 -78
  133. data/spec/unit/keyed_factory_spec.rb +0 -51
  134. data/spec/unit/logging/terminaloutputter_spec.rb +0 -53
  135. data/spec/unit/logging_spec.rb +0 -68
  136. data/spec/unit/module/base_spec.rb +0 -118
  137. data/spec/unit/module/forge_spec.rb +0 -271
  138. data/spec/unit/module/git_spec.rb +0 -387
  139. data/spec/unit/module/metadata_file_spec.rb +0 -68
  140. data/spec/unit/module/svn_spec.rb +0 -208
  141. data/spec/unit/module/tarball_spec.rb +0 -70
  142. data/spec/unit/module_loader/puppetfile_spec.rb +0 -421
  143. data/spec/unit/module_spec.rb +0 -114
  144. data/spec/unit/puppetfile_spec.rb +0 -304
  145. data/spec/unit/settings/collection_spec.rb +0 -123
  146. data/spec/unit/settings/container_spec.rb +0 -92
  147. data/spec/unit/settings/definition_spec.rb +0 -79
  148. data/spec/unit/settings/enum_definition_spec.rb +0 -20
  149. data/spec/unit/settings/inheritance_spec.rb +0 -38
  150. data/spec/unit/settings/list_spec.rb +0 -88
  151. data/spec/unit/settings/loader_spec.rb +0 -110
  152. data/spec/unit/settings/uri_definition_spec.rb +0 -23
  153. data/spec/unit/settings_spec.rb +0 -303
  154. data/spec/unit/source/base_spec.rb +0 -31
  155. data/spec/unit/source/exec_spec.rb +0 -81
  156. data/spec/unit/source/git_spec.rb +0 -233
  157. data/spec/unit/source/hash_spec.rb +0 -54
  158. data/spec/unit/source/svn_spec.rb +0 -196
  159. data/spec/unit/source/yaml_spec.rb +0 -42
  160. data/spec/unit/source_spec.rb +0 -10
  161. data/spec/unit/svn/remote_spec.rb +0 -21
  162. data/spec/unit/svn/working_dir_spec.rb +0 -56
  163. data/spec/unit/tarball_spec.rb +0 -57
  164. data/spec/unit/util/attempt_spec.rb +0 -82
  165. data/spec/unit/util/cacheable_spec.rb +0 -23
  166. data/spec/unit/util/commands_spec.rb +0 -61
  167. data/spec/unit/util/downloader_spec.rb +0 -98
  168. data/spec/unit/util/exec_env_spec.rb +0 -56
  169. data/spec/unit/util/purgeable_spec.rb +0 -267
  170. data/spec/unit/util/setopts_spec.rb +0 -83
  171. data/spec/unit/util/subprocess/result_spec.rb +0 -36
  172. data/spec/unit/util/subprocess/runner/posix_spec.rb +0 -7
  173. data/spec/unit/util/subprocess/runner/pump_spec.rb +0 -79
  174. data/spec/unit/util/subprocess/runner/windows_spec.rb +0 -7
  175. data/spec/unit/util/subprocess/subprocess_error_spec.rb +0 -26
  176. data/spec/unit/util/subprocess_spec.rb +0 -65
  177. data/spec/unit/util/symbolize_keys_spec.rb +0 -67
@@ -1,207 +0,0 @@
1
- RSpec.shared_examples "a git working repository" do
2
- describe "cloning" do
3
- it "creates a working copy of the repo" do
4
- subject.clone(remote)
5
- expect(subject.exist?).to be_truthy
6
- end
7
-
8
- describe "using the default branch" do
9
- describe "and the remote HEAD is 'master'" do
10
- it "checks out the default branch" do
11
- subject.clone(remote)
12
- expect(subject.head).to eq "157011a4eaa27f1202a9d94335ee4876b26d377e"
13
- end
14
- end
15
-
16
- describe "and the remote HEAD is '0.9.x'" do
17
- before do
18
- File.open(File.join(remote, 'HEAD'), 'w') do |fh|
19
- fh.write('ref: refs/heads/0.9.x')
20
- end
21
- end
22
-
23
- after do
24
- clear_remote_path
25
- populate_remote_path
26
- end
27
-
28
- it "checks out the default branch" do
29
- subject.clone(remote)
30
- expect(subject.head).to eq "3084373e8d181cf2fea5b4ade2690ba22872bd67"
31
- end
32
- end
33
- end
34
-
35
- describe "using an explicit ref" do
36
- it "can check out tags" do
37
- subject.clone(remote, {:ref => '1.0.0'})
38
- expect(subject.head).to eq "14cbb45ae3a5f764320b7e63f1a54a25a1ef6c9c"
39
- end
40
-
41
- it "can check out remote branches" do
42
- subject.clone(remote, {:ref => 'origin/0.9.x'})
43
- expect(subject.head).to eq "3084373e8d181cf2fea5b4ade2690ba22872bd67"
44
- end
45
-
46
- it "can check out commits" do
47
- subject.clone(remote, {:ref => '14cbb45ae3a5f764320b7e63f1a54a25a1ef6c9c'})
48
- expect(subject.head).to eq "14cbb45ae3a5f764320b7e63f1a54a25a1ef6c9c"
49
- end
50
- end
51
-
52
- describe "with a reference repository" do
53
- it "adds the reference repository to the alternates directory" do
54
- subject.clone(remote, {:reference => remote})
55
- alternates = subject.alternates.to_a
56
- expect(alternates.size).to eq 1
57
- expect(alternates[0]).to match_realpath File.join(remote, 'objects')
58
- end
59
- end
60
-
61
- context "without a proxy" do
62
- before(:each) do
63
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return(nil)
64
- end
65
-
66
- it 'does not change proxy ENV' do
67
- expect(ENV).to_not receive(:[]=)
68
- expect(ENV).to_not receive(:update)
69
-
70
- subject.clone(remote)
71
- end
72
- end
73
-
74
- context "with a proxy" do
75
- before(:each) do
76
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return('http://proxy.example.com:3128')
77
- end
78
-
79
- it "manages proxy-related ENV vars" do
80
- # Sets proxy settings.
81
- ['HTTPS_PROXY', 'https_proxy', 'HTTP_PROXY', 'http_proxy'].each do |var|
82
- expect(ENV).to receive(:[]=).with(var, 'http://proxy.example.com:3128')
83
- end
84
-
85
- # Resets proxy settings when done.
86
- expect(ENV).to receive(:update).with(hash_including('HTTPS_PROXY' => nil))
87
-
88
- subject.clone(remote)
89
- end
90
- end
91
- end
92
-
93
- describe "updating the repo" do
94
- let(:tag_090) { subject.git_dir + 'refs' + 'tags' + '0.9.0' }
95
- let(:packed_refs) { subject.git_dir + 'packed-refs' }
96
-
97
- before do
98
- subject.clone(remote)
99
- tag_090.delete if tag_090.exist?
100
- packed_refs.delete if packed_refs.exist?
101
- end
102
-
103
- it "fetches objects from the remote" do
104
- expect(subject.tags).to_not include('0.9.0')
105
- subject.fetch
106
- expect(subject.tags).to include('0.9.0')
107
- end
108
-
109
- context "without a proxy" do
110
- before(:each) do
111
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return(nil)
112
- end
113
-
114
- it 'does not change proxy ENV' do
115
- expect(ENV).to_not receive(:[]=)
116
- expect(ENV).to_not receive(:update)
117
-
118
- subject.fetch
119
- end
120
- end
121
-
122
- context "with a proxy" do
123
- before(:each) do
124
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return('http://proxy.example.com:3128')
125
- end
126
-
127
- it "manages proxy-related ENV vars" do
128
- # Sets proxy settings.
129
- ['HTTPS_PROXY', 'https_proxy', 'HTTP_PROXY', 'http_proxy'].each do |var|
130
- expect(ENV).to receive(:[]=).with(var, 'http://proxy.example.com:3128')
131
- end
132
-
133
- # Resets proxy settings when done.
134
- expect(ENV).to receive(:update).with(hash_including('HTTPS_PROXY' => nil))
135
-
136
- subject.fetch
137
- end
138
- end
139
- end
140
-
141
- describe "listing branches" do
142
- before do
143
- subject.clone(remote)
144
- end
145
-
146
- it "lists the local branches" do
147
- expect(subject.branches).to eq(%w[master])
148
- end
149
- end
150
-
151
- describe "listing the origin" do
152
- it "is nil if the remote is not set" do
153
- expect(subject.origin).to be_nil
154
- end
155
-
156
- it "is the remote URL when set" do
157
- subject.clone(remote)
158
- expect(subject.origin).to eq remote
159
- end
160
- end
161
-
162
- describe "checking out ref" do
163
- before(:each) do
164
- subject.clone(remote)
165
- File.open(File.join(subject.path, 'README.markdown'), 'a') { |f| f.write('local modifications!') }
166
- end
167
-
168
- context "with force = true" do
169
- it "should revert changes in managed files" do
170
- subject.checkout(subject.head, {:force => true})
171
- expect(File.read(File.join(subject.path, 'README.markdown')).include?('local modifications!')).to eq false
172
- end
173
- end
174
-
175
- context "with force = false" do
176
- it "should not revert changes in managed files" do
177
- subject.checkout(subject.head, {:force => false})
178
- expect(File.read(File.join(subject.path, 'README.markdown')).include?('local modifications!')).to eq true
179
- end
180
- end
181
- end
182
-
183
- describe "checking if worktree is dirty" do
184
- before do
185
- subject.clone(remote)
186
- end
187
-
188
- context "with no local changes" do
189
- it "reports worktree as not dirty" do
190
- expect(subject.dirty?).to be false
191
- end
192
- end
193
-
194
- context "with local changes" do
195
- before(:each) do
196
- File.open(File.join(subject.path, 'README.markdown'), 'a') { |f| f.write('local modifications!') }
197
- end
198
-
199
- it "logs and reports worktree as dirty" do
200
- expect(subject.logger).to receive(:debug).with(/found local modifications in.*README\.markdown/i)
201
- expect(subject.logger).to receive(:debug1)
202
-
203
- expect(subject.dirty?).to be true
204
- end
205
- end
206
- end
207
- end
@@ -1,38 +0,0 @@
1
- shared_examples_for "a git repository" do
2
-
3
- it "does not exist if the repo is not present" do
4
- expect(subject.exist?).to be_falsey
5
- end
6
-
7
- describe "listing tags" do
8
- before do
9
- subject.clone(remote)
10
- end
11
-
12
- it "lists all tags in alphabetical order" do
13
- expect(subject.tags).to eq(%w[0.9.0 0.9.0-rc1 1.0.0 1.0.1])
14
- end
15
- end
16
-
17
- describe "resolving refs" do
18
- before do
19
- subject.clone(remote)
20
- end
21
-
22
- it "can resolve branches" do
23
- expect(subject.resolve('master')).to eq '157011a4eaa27f1202a9d94335ee4876b26d377e'
24
- end
25
-
26
- it "can resolve tags" do
27
- expect(subject.resolve('1.0.0')).to eq '14cbb45ae3a5f764320b7e63f1a54a25a1ef6c9c'
28
- end
29
-
30
- it "can resolve commits" do
31
- expect(subject.resolve('3084373e8d181cf2fea5b4ade2690ba22872bd67')).to eq '3084373e8d181cf2fea5b4ade2690ba22872bd67'
32
- end
33
-
34
- it "returns nil when the object cannot be resolved" do
35
- expect(subject.resolve('1.2.3')).to be_nil
36
- end
37
- end
38
- end
@@ -1,39 +0,0 @@
1
- require 'spec_helper'
2
-
3
- shared_examples_for "a puppetfile action" do
4
- describe "initializing" do
5
- it "accepts the :root option" do
6
- described_class.new({root: "/some/nonexistent/path"}, [], {})
7
- end
8
-
9
- it "accepts the :puppetfile option" do
10
- described_class.new({puppetfile: "/some/nonexistent/path/Puppetfile"}, [], {})
11
- end
12
-
13
- it "accepts the :moduledir option" do
14
- described_class.new({moduledir: "/some/nonexistent/path/modules"}, [], {})
15
- end
16
-
17
- end
18
- end
19
-
20
- shared_examples_for "a puppetfile install action" do
21
- describe "initializing" do
22
- it "accepts the :root option" do
23
- described_class.new({root: "/some/nonexistent/path"}, [], {})
24
- end
25
-
26
- it "accepts the :puppetfile option" do
27
- described_class.new({puppetfile: "/some/nonexistent/path/Puppetfile"}, [], {})
28
- end
29
-
30
- it "accepts the :moduledir option" do
31
- described_class.new({moduledir: "/some/nonexistent/path/modules"}, [], {})
32
- end
33
-
34
- it "accepts the :force option" do
35
- described_class.new({force: true}, [], {})
36
- end
37
-
38
- end
39
- end
@@ -1,44 +0,0 @@
1
- require 'spec_helper'
2
-
3
- require 'r10k/settings/collection'
4
- require 'r10k/settings/list'
5
-
6
- shared_examples_for "a setting with ancestors" do
7
- describe '#parent=' do
8
- it "allows assignment to a collection" do
9
- parent = R10K::Settings::Collection.new(:parent, [])
10
-
11
- subject.parent = parent
12
-
13
- expect(subject.parent).to eq parent
14
- end
15
-
16
- it "allows assignment to a list" do
17
- parent = R10K::Settings::List.new(:parent, [])
18
-
19
- subject.parent = parent
20
-
21
- expect(subject.parent).to eq parent
22
- end
23
-
24
- it "rejects assignment when argument is not a settings collection or list" do
25
- parent = Hash.new
26
-
27
- expect { subject.parent = parent }.to raise_error do |error|
28
- expect(error.message).to match /may only belong to a settings collection or list/i
29
- end
30
- end
31
-
32
- it "rejects re-assignment" do
33
- parent = R10K::Settings::Collection.new(:parent, [])
34
- step_parent = R10K::Settings::Collection.new(:step_parent, [])
35
-
36
- subject.parent = parent
37
-
38
- expect { subject.parent = step_parent }.to raise_error do |error|
39
- expect(error.message).to match /cannot be reassigned.*new parent/i
40
- end
41
- end
42
- end
43
- end
44
-
@@ -1,89 +0,0 @@
1
- shared_examples_for "a subprocess runner" do |fixture_root|
2
-
3
- describe "running 'echo test'" do
4
- subject { described_class.new(%w[echo test]) }
5
-
6
- it "sets the exit code to 0" do
7
- result = subject.run
8
- expect(result.exit_code).to eq 0
9
- end
10
-
11
- it "returns the contents of stdout" do
12
- result = subject.run
13
- expect(result.stdout).to eq 'test'
14
- end
15
-
16
- it "indicates the command succeeded" do
17
- result = subject.run
18
- expect(result).to be_success
19
- expect(result).to_not be_failed
20
- end
21
- end
22
-
23
- describe "running a command with a large amount of output" do
24
- subject do
25
- described_class.new(['ruby', '-e', 'blob = "buffalo!" * (2 << 16); puts blob'])
26
- end
27
-
28
- it "does not hang" do
29
- Timeout.timeout(5) do
30
- subject.run
31
- end
32
- end
33
- end
34
-
35
- describe "running 'ls' or 'dir' with a different working directory" do
36
- subject do
37
- if R10K::Util::Platform.windows?
38
- described_class.new(%w[cmd /c dir]).tap do |o|
39
- o.cwd = fixture_root
40
- end
41
- else
42
- described_class.new(%w[ls]).tap do |o|
43
- o.cwd = fixture_root
44
- end
45
- end
46
- end
47
-
48
- it "returns the contents of the given working directory" do
49
- result = subject.run
50
- expect(result.stdout).to match('no-execute.sh')
51
- end
52
- end
53
-
54
- describe "running 'false'" do
55
- subject { described_class.new(%w[false]) }
56
-
57
- it "sets the exit code to 1", unless: R10K::Util::Platform.windows? do
58
- result = subject.run
59
- expect(result.exit_code).to eq 1
60
- end
61
-
62
- it "indicates the command failed" do
63
- result = subject.run
64
- expect(result).to_not be_success
65
- expect(result).to be_failed
66
- end
67
- end
68
-
69
- describe "running '/this/command/will/not/exist'" do
70
- subject { described_class.new(%w[/this/command/will/not/exist]) }
71
-
72
- it "indicates the command failed" do
73
- result = subject.run
74
- expect(result).to_not be_success
75
- expect(result).to be_failed
76
- end
77
- end
78
-
79
- describe "running a non-executable file", :unless => R10K::Util::Platform.windows? do
80
- let(:fixture_file) { File.join(fixture_root, 'no-execute.sh') }
81
- subject { described_class.new([fixture_file]) }
82
-
83
- it "indicates the command failed" do
84
- result = subject.run
85
- expect(result).to_not be_success
86
- expect(result).to be_failed
87
- end
88
- end
89
- end
data/spec/spec_helper.rb DELETED
@@ -1,41 +0,0 @@
1
- PROJECT_ROOT = File.expand_path('..', File.dirname(__FILE__))
2
-
3
- if ENV['COVERAGE']
4
- require 'simplecov'
5
- SimpleCov.start do
6
- libdir = File.join(PROJECT_ROOT, 'lib')
7
- add_filter do |src|
8
- !src.filename.match(%r[\A#{libdir}])
9
- end
10
-
11
- %w[Deployment Source Environment Module Git SVN Action Util].each do |group|
12
- add_group group, "lib/r10k/#{group.downcase}"
13
- end
14
- end
15
- end
16
-
17
- require 'r10k'
18
-
19
- Dir.glob(File.expand_path('spec/shared-examples/**/*.rb', PROJECT_ROOT)).each { |file| require file }
20
-
21
- require 'shared-contexts/git-fixtures'
22
- require 'shared-contexts/tarball'
23
- require 'matchers/exit_with'
24
- require 'matchers/match_realpath'
25
- require 'r10k-mocks'
26
-
27
- # Add a negated version of the change matcher.
28
- RSpec::Matchers.define_negated_matcher :not_change, :change
29
-
30
- RSpec.configure do |config|
31
- config.before(:all) do
32
- Log4r::Logger.global.level = Log4r::OFF
33
- end
34
- end
35
-
36
- shared_context 'fail on execution' do
37
- before do
38
- allow_any_instance_of(described_class).to receive(:execute).and_raise "Tests should never invoke system calls"
39
- allow_any_instance_of(R10K::Util::Subprocess).to receive(:execute).and_raise "Tests should never invoke system calls"
40
- end
41
- end
@@ -1,72 +0,0 @@
1
- require 'spec_helper'
2
- require 'r10k/action/base'
3
- require 'r10k/action/cri_runner'
4
-
5
- describe R10K::Action::CriRunner do
6
-
7
- let(:action_class) do
8
- Class.new do
9
- attr_reader :opts
10
- attr_reader :argv
11
-
12
- def initialize(opts, argv, settings = {})
13
- @opts = opts
14
- @argv = argv
15
- @settings = {}
16
- end
17
-
18
- def call
19
- @opts[:runok]
20
- end
21
- end
22
- end
23
-
24
- subject(:cri_runner) { described_class.wrap(action_class) }
25
-
26
- let(:opts) { {:value => :yep} }
27
- let(:argv) { %w[value yes] }
28
-
29
- describe "handling options" do
30
- it "adapts the :verbose flag to :loglevel" do
31
- input = {:value => :yep, :verbose => 'DEBUG'}
32
- output = {:value => :yep, :loglevel => 'DEBUG'}
33
- expect(cri_runner.handle_opts(input)).to eq(output)
34
- end
35
- end
36
-
37
- describe "handling arguments" do
38
- it "sets the arguments as-is" do
39
- expect(cri_runner.handle_argv(%w[one two])).to eq(%w[one two])
40
- end
41
- end
42
-
43
- describe "proxying invocations to .new" do
44
- it "returns itself" do
45
- expect(cri_runner.new(opts, argv, :cri_cmd)).to eql cri_runner
46
- end
47
-
48
- it "handles options" do
49
- expect(cri_runner).to receive(:handle_opts)
50
- cri_runner.new({:value => :yep, :verbose => 'DEBUG'}, argv, :cri_cmd)
51
- end
52
-
53
- it "handles arguments" do
54
- expect(cri_runner).to receive(:handle_argv)
55
- cri_runner.new({:value => :yep, :verbose => 'DEBUG'}, argv, :cri_cmd)
56
- end
57
- end
58
-
59
- describe "calling" do
60
- it "exits with a return value of 0 if the action returned true" do
61
- expect {
62
- cri_runner.new({:runok => true}, []).call
63
- }.to exit_with(0)
64
- end
65
-
66
- it "exits with a return value of 1 if the action returned false" do
67
- expect {
68
- cri_runner.new({:runok => false}, []).call
69
- }.to exit_with(1)
70
- end
71
- end
72
- end
@@ -1,38 +0,0 @@
1
- require 'spec_helper'
2
-
3
- require 'r10k/logging'
4
- require 'r10k/action/deploy/deploy_helpers'
5
-
6
- describe R10K::Action::Deploy::DeployHelpers do
7
- subject do
8
- Object.new.tap do |o|
9
- o.extend(R10K::Logging)
10
- o.extend(described_class)
11
- end
12
- end
13
-
14
- describe "checking for a config file" do
15
- it "logs a warning and exits when no config file was set" do
16
- logger = subject.logger
17
-
18
- expect(logger).to receive(:fatal).with("No configuration file given, no config file found in current directory, and no global config present")
19
-
20
- expect {
21
- subject.expect_config!
22
- }.to exit_with(8)
23
- end
24
- end
25
-
26
- describe "checking the write lock setting" do
27
- it "logs a warning and exits when the write lock is set" do
28
- logger = subject.logger
29
-
30
- expect(logger).to receive(:fatal).with("Making changes to deployed environments has been administratively disabled.")
31
- expect(logger).to receive(:fatal).with("Reason: r10k is sleepy and wants to take a nap")
32
-
33
- expect {
34
- subject.check_write_lock!(deploy: {write_lock: "r10k is sleepy and wants to take a nap"})
35
- }.to exit_with(16)
36
- end
37
- end
38
- end
@@ -1,61 +0,0 @@
1
- require 'spec_helper'
2
-
3
- require 'r10k/action/deploy/display'
4
-
5
- describe R10K::Action::Deploy::Display do
6
- describe "initializing" do
7
- it "accepts a puppetfile option" do
8
- described_class.new({puppetfile: true}, [], {})
9
- end
10
-
11
- it "accepts a modules option" do
12
- described_class.new({modules: true}, [], {})
13
- end
14
-
15
- it "accepts a detail option" do
16
- described_class.new({detail: true}, [], {})
17
- end
18
-
19
- it "accepts a format option" do
20
- described_class.new({format: "json"}, [], {})
21
- end
22
-
23
- it "accepts a fetch option" do
24
- described_class.new({fetch: true}, [], {})
25
- end
26
- end
27
-
28
- subject { described_class.new({config: "/some/nonexistent/path"}, [], {}) }
29
-
30
- before do
31
- allow(subject).to receive(:puts)
32
- end
33
-
34
- it_behaves_like "a deploy action that requires a config file"
35
-
36
- describe "collecting info" do
37
- subject { described_class.new({config: "/some/nonexistent/path", format: 'json', puppetfile: true, detail: true}, ['first'], {}) }
38
-
39
- let(:mock_config) do
40
- R10K::Deployment::MockConfig.new(
41
- :sources => {
42
- :control => {
43
- :type => :mock,
44
- :basedir => '/some/nonexistent/path/control',
45
- :environments => %w[first second third env-that/will-be-corrected],
46
- :prefix => 'PREFIX'
47
- }
48
- }
49
- )
50
- end
51
-
52
- let(:deployment) { R10K::Deployment.new(mock_config) }
53
-
54
- it "gathers environment info" do
55
- source_info = subject.send(:source_info, deployment.sources.first, ['first'])
56
- expect(source_info[:name]).to eq(:control)
57
- expect(source_info[:environments].length).to eq(1)
58
- expect(source_info[:environments][0][:name]).to eq('first')
59
- end
60
- end
61
- end