-
Notifications
You must be signed in to change notification settings - Fork 145
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
(PDK-997) Remove Dir.chdir call from check:test_file task
This `chdir` breaks the isolation of the rake task and affects the behaviour of other tasks that are invoked in it in the same `rake` execution. Rather than modify the task so that it changes back to the parent directory after the task has finished, we can just remove the `chdir` entirely and just change the glob to look for files in the directory. This PR also adds some basic unit tests for the `check:test_file` task.
- Loading branch information
Showing
3 changed files
with
40 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
28 changes: 28 additions & 0 deletions
28
spec/unit/puppetlabs_spec_helper/tasks/check_test_file_spec.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
require 'spec_helper' | ||
|
||
describe 'rake check:test_file', type: :task do | ||
before(:each) do | ||
test_pattern = File.join('tests', '**', '*.pp') | ||
allow(Dir).to receive(:[]).with(test_pattern).and_return(test_files) | ||
end | ||
|
||
context 'when there are .pp files under tasks/' do | ||
let(:test_files) { [File.join('tests', 'an_example.pp')] } | ||
|
||
it 'raises an error' do | ||
expected_output = test_files.join("\n") | ||
|
||
expect { task.execute } | ||
.to raise_error(%r{pp files present in tests folder}) | ||
.and output(a_string_including(expected_output)).to_stdout | ||
end | ||
end | ||
|
||
context 'when there are no .pp files under tasks/' do | ||
let(:test_files) { [] } | ||
|
||
it 'runs without raising an error' do | ||
expect { task.execute }.not_to raise_error | ||
end | ||
end | ||
end |