r10k 3.15.0 → 3.15.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (160) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.mkd +9 -0
  3. data/CODEOWNERS +2 -2
  4. data/README.mkd +11 -0
  5. data/doc/dynamic-environments/configuration.mkd +65 -1
  6. data/lib/r10k/action/puppetfile/install.rb +2 -1
  7. data/lib/r10k/cli/puppetfile.rb +1 -0
  8. data/lib/r10k/module_loader/puppetfile.rb +10 -1
  9. data/lib/r10k/version.rb +1 -1
  10. data/r10k.gemspec +1 -1
  11. metadata +2 -151
  12. data/spec/fixtures/empty/.empty +0 -0
  13. data/spec/fixtures/integration/git/puppet-boolean-bare.tar +0 -0
  14. data/spec/fixtures/module/forge/bad_module/metadata.json +0 -1
  15. data/spec/fixtures/module/forge/eight_hundred/Modulefile +0 -8
  16. data/spec/fixtures/module/forge/eight_hundred/metadata.json +0 -19
  17. data/spec/fixtures/tarball/tarball.tar.gz +0 -0
  18. data/spec/fixtures/unit/action/r10k.yaml +0 -5
  19. data/spec/fixtures/unit/action/r10k_cachedir.yaml +0 -2
  20. data/spec/fixtures/unit/action/r10k_creds.yaml +0 -9
  21. data/spec/fixtures/unit/action/r10k_forge_auth.yaml +0 -4
  22. data/spec/fixtures/unit/action/r10k_forge_auth_no_url.yaml +0 -3
  23. data/spec/fixtures/unit/action/r10k_generate_types.yaml +0 -3
  24. data/spec/fixtures/unit/action/r10k_logging.yaml +0 -12
  25. data/spec/fixtures/unit/action/r10k_puppet_path.yaml +0 -3
  26. data/spec/fixtures/unit/puppetfile/argument-error/Puppetfile +0 -1
  27. data/spec/fixtures/unit/puppetfile/default-branch-override/Puppetfile +0 -5
  28. data/spec/fixtures/unit/puppetfile/duplicate-module-error/Puppetfile +0 -10
  29. data/spec/fixtures/unit/puppetfile/forge-override/Puppetfile +0 -8
  30. data/spec/fixtures/unit/puppetfile/invalid-syntax/Puppetfile +0 -1
  31. data/spec/fixtures/unit/puppetfile/load-error/Puppetfile +0 -1
  32. data/spec/fixtures/unit/puppetfile/name-error/Puppetfile +0 -1
  33. data/spec/fixtures/unit/puppetfile/valid-forge-with-version/Puppetfile +0 -1
  34. data/spec/fixtures/unit/puppetfile/valid-forge-without-version/Puppetfile +0 -1
  35. data/spec/fixtures/unit/puppetfile/various-modules/Puppetfile +0 -10
  36. data/spec/fixtures/unit/puppetfile/various-modules/Puppetfile.new +0 -10
  37. data/spec/fixtures/unit/puppetfile/various-modules/modules/apt/.gitkeep +0 -1
  38. data/spec/fixtures/unit/puppetfile/various-modules/modules/baz/.gitkeep +0 -1
  39. data/spec/fixtures/unit/puppetfile/various-modules/modules/buzz/.gitkeep +0 -1
  40. data/spec/fixtures/unit/puppetfile/various-modules/modules/canary/.gitkeep +0 -1
  41. data/spec/fixtures/unit/puppetfile/various-modules/modules/fizz/.gitkeep +0 -1
  42. data/spec/fixtures/unit/puppetfile/various-modules/modules/rpm/.gitkeep +0 -1
  43. data/spec/fixtures/unit/util/purgeable/managed_one/expected_1 +0 -0
  44. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/managed_symlink_file +0 -1
  45. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/subdir_allowlisted_2/ignored_1 +0 -0
  46. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/subdir_expected_1 +0 -0
  47. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/subdir_unmanaged_1 +0 -0
  48. data/spec/fixtures/unit/util/purgeable/managed_one/managed_subdir_1/unmanaged_symlink_dir +0 -1
  49. data/spec/fixtures/unit/util/purgeable/managed_one/managed_symlink_dir +0 -1
  50. data/spec/fixtures/unit/util/purgeable/managed_one/unmanaged_1 +0 -0
  51. data/spec/fixtures/unit/util/purgeable/managed_one/unmanaged_symlink_file +0 -1
  52. data/spec/fixtures/unit/util/purgeable/managed_two/.hidden/unmanaged_3 +0 -0
  53. data/spec/fixtures/unit/util/purgeable/managed_two/expected_2 +0 -0
  54. data/spec/fixtures/unit/util/purgeable/managed_two/unmanaged_2 +0 -0
  55. data/spec/fixtures/unit/util/subprocess/runner/no-execute.sh +0 -3
  56. data/spec/integration/git/rugged/bare_repository_spec.rb +0 -13
  57. data/spec/integration/git/rugged/cache_spec.rb +0 -33
  58. data/spec/integration/git/rugged/thin_repository_spec.rb +0 -14
  59. data/spec/integration/git/rugged/working_repository_spec.rb +0 -48
  60. data/spec/integration/git/shellgit/bare_repository_spec.rb +0 -13
  61. data/spec/integration/git/shellgit/thin_repository_spec.rb +0 -14
  62. data/spec/integration/git/shellgit/working_repository_spec.rb +0 -13
  63. data/spec/integration/git/stateful_repository_spec.rb +0 -175
  64. data/spec/integration/util/purageable_spec.rb +0 -41
  65. data/spec/matchers/exit_with.rb +0 -28
  66. data/spec/matchers/match_realpath.rb +0 -18
  67. data/spec/r10k-mocks/mock_config.rb +0 -33
  68. data/spec/r10k-mocks/mock_env.rb +0 -18
  69. data/spec/r10k-mocks/mock_source.rb +0 -17
  70. data/spec/r10k-mocks.rb +0 -3
  71. data/spec/shared-contexts/git-fixtures.rb +0 -55
  72. data/spec/shared-contexts/tarball.rb +0 -32
  73. data/spec/shared-examples/deploy-actions.rb +0 -69
  74. data/spec/shared-examples/git/bare_repository.rb +0 -132
  75. data/spec/shared-examples/git/thin_repository.rb +0 -26
  76. data/spec/shared-examples/git/working_repository.rb +0 -207
  77. data/spec/shared-examples/git-repository.rb +0 -38
  78. data/spec/shared-examples/puppetfile-action.rb +0 -39
  79. data/spec/shared-examples/settings/ancestry.rb +0 -44
  80. data/spec/shared-examples/subprocess-runner.rb +0 -89
  81. data/spec/spec_helper.rb +0 -41
  82. data/spec/unit/action/cri_runner_spec.rb +0 -72
  83. data/spec/unit/action/deploy/deploy_helpers_spec.rb +0 -38
  84. data/spec/unit/action/deploy/display_spec.rb +0 -61
  85. data/spec/unit/action/deploy/environment_spec.rb +0 -640
  86. data/spec/unit/action/deploy/module_spec.rb +0 -476
  87. data/spec/unit/action/puppetfile/check_spec.rb +0 -53
  88. data/spec/unit/action/puppetfile/cri_runner_spec.rb +0 -47
  89. data/spec/unit/action/puppetfile/install_spec.rb +0 -112
  90. data/spec/unit/action/puppetfile/purge_spec.rb +0 -60
  91. data/spec/unit/action/runner_spec.rb +0 -407
  92. data/spec/unit/action/visitor_spec.rb +0 -39
  93. data/spec/unit/cli_spec.rb +0 -9
  94. data/spec/unit/deployment/config_spec.rb +0 -33
  95. data/spec/unit/deployment_spec.rb +0 -162
  96. data/spec/unit/environment/bare_spec.rb +0 -13
  97. data/spec/unit/environment/base_spec.rb +0 -122
  98. data/spec/unit/environment/git_spec.rb +0 -114
  99. data/spec/unit/environment/name_spec.rb +0 -181
  100. data/spec/unit/environment/plain_spec.rb +0 -8
  101. data/spec/unit/environment/svn_spec.rb +0 -146
  102. data/spec/unit/environment/tarball_spec.rb +0 -45
  103. data/spec/unit/environment/with_modules_spec.rb +0 -122
  104. data/spec/unit/errors/formatting_spec.rb +0 -84
  105. data/spec/unit/feature_spec.rb +0 -50
  106. data/spec/unit/forge/module_release_spec.rb +0 -213
  107. data/spec/unit/git/alternates_spec.rb +0 -116
  108. data/spec/unit/git/cache_spec.rb +0 -66
  109. data/spec/unit/git/rugged/cache_spec.rb +0 -48
  110. data/spec/unit/git/rugged/credentials_spec.rb +0 -215
  111. data/spec/unit/git/shellgit/cache_spec.rb +0 -27
  112. data/spec/unit/git/stateful_repository_spec.rb +0 -45
  113. data/spec/unit/git_spec.rb +0 -102
  114. data/spec/unit/initializers_spec.rb +0 -68
  115. data/spec/unit/instance_cache_spec.rb +0 -78
  116. data/spec/unit/keyed_factory_spec.rb +0 -51
  117. data/spec/unit/logging/terminaloutputter_spec.rb +0 -53
  118. data/spec/unit/logging_spec.rb +0 -68
  119. data/spec/unit/module/base_spec.rb +0 -118
  120. data/spec/unit/module/forge_spec.rb +0 -271
  121. data/spec/unit/module/git_spec.rb +0 -387
  122. data/spec/unit/module/metadata_file_spec.rb +0 -68
  123. data/spec/unit/module/svn_spec.rb +0 -208
  124. data/spec/unit/module/tarball_spec.rb +0 -70
  125. data/spec/unit/module_loader/puppetfile_spec.rb +0 -421
  126. data/spec/unit/module_spec.rb +0 -114
  127. data/spec/unit/puppetfile_spec.rb +0 -304
  128. data/spec/unit/settings/collection_spec.rb +0 -123
  129. data/spec/unit/settings/container_spec.rb +0 -92
  130. data/spec/unit/settings/definition_spec.rb +0 -79
  131. data/spec/unit/settings/enum_definition_spec.rb +0 -20
  132. data/spec/unit/settings/inheritance_spec.rb +0 -38
  133. data/spec/unit/settings/list_spec.rb +0 -88
  134. data/spec/unit/settings/loader_spec.rb +0 -110
  135. data/spec/unit/settings/uri_definition_spec.rb +0 -23
  136. data/spec/unit/settings_spec.rb +0 -303
  137. data/spec/unit/source/base_spec.rb +0 -31
  138. data/spec/unit/source/exec_spec.rb +0 -81
  139. data/spec/unit/source/git_spec.rb +0 -233
  140. data/spec/unit/source/hash_spec.rb +0 -54
  141. data/spec/unit/source/svn_spec.rb +0 -196
  142. data/spec/unit/source/yaml_spec.rb +0 -42
  143. data/spec/unit/source_spec.rb +0 -10
  144. data/spec/unit/svn/remote_spec.rb +0 -21
  145. data/spec/unit/svn/working_dir_spec.rb +0 -56
  146. data/spec/unit/tarball_spec.rb +0 -57
  147. data/spec/unit/util/attempt_spec.rb +0 -82
  148. data/spec/unit/util/cacheable_spec.rb +0 -23
  149. data/spec/unit/util/commands_spec.rb +0 -61
  150. data/spec/unit/util/downloader_spec.rb +0 -98
  151. data/spec/unit/util/exec_env_spec.rb +0 -56
  152. data/spec/unit/util/purgeable_spec.rb +0 -267
  153. data/spec/unit/util/setopts_spec.rb +0 -83
  154. data/spec/unit/util/subprocess/result_spec.rb +0 -36
  155. data/spec/unit/util/subprocess/runner/posix_spec.rb +0 -7
  156. data/spec/unit/util/subprocess/runner/pump_spec.rb +0 -79
  157. data/spec/unit/util/subprocess/runner/windows_spec.rb +0 -7
  158. data/spec/unit/util/subprocess/subprocess_error_spec.rb +0 -26
  159. data/spec/unit/util/subprocess_spec.rb +0 -65
  160. data/spec/unit/util/symbolize_keys_spec.rb +0 -67
@@ -1,132 +0,0 @@
1
- RSpec.shared_examples "a git bare repository" do
2
-
3
- describe "checking for the presence of the repo" do
4
- it "exists if the repo is present" do
5
- subject.clone(remote)
6
- expect(subject.exist?).to be_truthy
7
- end
8
-
9
- it "doesn't exist if the repo is not present" do
10
- expect(subject.exist?).to be_falsey
11
- end
12
- end
13
-
14
- describe "cloning the repo" do
15
- it "creates the repo at the expected location" do
16
- subject.clone(remote)
17
- config = File.read(File.join(basedir, dirname, 'config'))
18
- expect(config).to match(remote)
19
- end
20
-
21
- context "without a proxy" do
22
- before(:each) do
23
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return(nil)
24
- end
25
-
26
- it 'does not change proxy ENV' do
27
- expect(ENV).to_not receive(:[]=)
28
- expect(ENV).to_not receive(:update)
29
-
30
- subject.clone(remote)
31
- end
32
- end
33
-
34
- context "with a proxy" do
35
- before(:each) do
36
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return('http://proxy.example.com:3128')
37
- end
38
-
39
- it "manages proxy-related ENV vars" do
40
- # Sets proxy settings.
41
- ['HTTPS_PROXY', 'https_proxy', 'HTTP_PROXY', 'http_proxy'].each do |var|
42
- expect(ENV).to receive(:[]=).with(var, 'http://proxy.example.com:3128')
43
- end
44
-
45
- # Resets proxy settings when done.
46
- expect(ENV).to receive(:update).with(hash_including('HTTPS_PROXY' => nil))
47
-
48
- subject.clone(remote)
49
- end
50
- end
51
- end
52
-
53
- describe "updating the repo" do
54
- let(:tag_090) { subject.git_dir + 'refs' + 'tags' + '0.9.0' }
55
- let(:packed_refs) { subject.git_dir + 'packed-refs' }
56
-
57
- before do
58
- subject.clone(remote)
59
- tag_090.delete if tag_090.exist?
60
- packed_refs.delete if packed_refs.exist?
61
- end
62
-
63
- it "fetches objects from the remote" do
64
- expect(subject.tags).to_not include('0.9.0')
65
- subject.fetch
66
- expect(subject.tags).to include('0.9.0')
67
- end
68
-
69
- context "without a proxy" do
70
- before(:each) do
71
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return(nil)
72
- end
73
-
74
- it 'does not change proxy ENV' do
75
- expect(ENV).to_not receive(:[]=)
76
- expect(ENV).to_not receive(:update)
77
-
78
- subject.fetch
79
- end
80
- end
81
-
82
- context "with a proxy" do
83
- before(:each) do
84
- allow(R10K::Git).to receive(:get_proxy_for_remote).with(remote).and_return('http://proxy.example.com:3128')
85
- end
86
-
87
- it "manages proxy-related ENV vars" do
88
- # Sets proxy settings.
89
- ['HTTPS_PROXY', 'https_proxy', 'HTTP_PROXY', 'http_proxy'].each do |var|
90
- expect(ENV).to receive(:[]=).with(var, 'http://proxy.example.com:3128')
91
- end
92
-
93
- # Resets proxy settings when done.
94
- expect(ENV).to receive(:update).with(hash_including('HTTPS_PROXY' => nil))
95
-
96
- subject.fetch
97
- end
98
- end
99
- end
100
-
101
- describe "listing branches" do
102
- before do
103
- subject.clone(remote)
104
- end
105
-
106
- it "lists all branches in alphabetical order" do
107
- expect(subject.branches).to eq(%w[0.9.x master])
108
- end
109
- end
110
-
111
- describe "determining ref type" do
112
- before do
113
- subject.clone(remote)
114
- end
115
-
116
- it "can infer the type of a branch ref" do
117
- expect(subject.ref_type('master')).to eq :branch
118
- end
119
-
120
- it "can infer the type of a tag ref" do
121
- expect(subject.ref_type('1.0.0')).to eq :tag
122
- end
123
-
124
- it "can infer the type of a commit" do
125
- expect(subject.ref_type('3084373e8d181cf2fea5b4ade2690ba22872bd67')).to eq :commit
126
- end
127
-
128
- it "returns :unknown when the type cannot be inferred" do
129
- expect(subject.ref_type('1.2.3')).to eq :unknown
130
- end
131
- end
132
- end
@@ -1,26 +0,0 @@
1
- RSpec.shared_examples "a git thin 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
- it "sets the remote origin url to the provided url" do
9
- subject.clone(remote)
10
- expect(subject.origin).to eq remote
11
- end
12
-
13
- it "sets the remote cache url to the path to the cache repo" do
14
- subject.clone(remote)
15
- expect(subject.cache).to eq cacherepo.git_dir.to_s
16
- end
17
-
18
- it "adds the cache repo to the alternates file" do
19
- subject.clone(remote)
20
- objectpath = cacherepo.git_dir + 'objects'
21
- alternates = subject.alternates.to_a
22
- expect(alternates.size).to eq 1
23
- expect(alternates[0]).to match_realpath objectpath
24
- end
25
- end
26
- end
@@ -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