Merge pull request #61 from netzpirat/modified_files_spec
Add missing specs for file modification detection (See SHA: 0dcf13d77c
This commit is contained in:
commit
3a87a4305c
@ -37,7 +37,56 @@ describe Guard::Listener do
|
|||||||
subject.update_last_event
|
subject.update_last_event
|
||||||
subject.last_event.to_i.should >= time.to_i
|
subject.last_event.to_i.should >= time.to_i
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "#modified_files" do
|
||||||
|
subject { described_class.new }
|
||||||
|
|
||||||
|
let(:file1) { File.new(@fixture_path.join("folder1", "file1.txt")) }
|
||||||
|
let(:file2) { File.new(@fixture_path.join("folder1", "folder2", "file2.txt")) }
|
||||||
|
let(:file3) { File.new(@fixture_path.join("folder1", "deletedfile1.txt")) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
subject.update_last_event
|
||||||
|
sleep 0.6
|
||||||
|
end
|
||||||
|
|
||||||
|
context "without the :all option" do
|
||||||
|
it "finds modified files only in the directory supplied" do
|
||||||
|
FileUtils.touch([file1, file2, file3])
|
||||||
|
subject.modified_files([@fixture_path.join("folder1/")], {}).should eql ["spec/fixtures/folder1/deletedfile1.txt", "spec/fixtures/folder1/file1.txt"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with the :all options" do
|
||||||
|
it "finds modified files within subdirectories" do
|
||||||
|
FileUtils.touch([file1, file2, file3])
|
||||||
|
subject.modified_files([@fixture_path.join("folder1/")], { :all => true }).should eql ["spec/fixtures/folder1/deletedfile1.txt", "spec/fixtures/folder1/file1.txt", "spec/fixtures/folder1/folder2/file2.txt"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "without updating the content" do
|
||||||
|
it "ignores the files for the second time" do
|
||||||
|
FileUtils.touch([file1, file2, file3])
|
||||||
|
subject.modified_files([@fixture_path.join("folder1/")], {}).should eql ["spec/fixtures/folder1/deletedfile1.txt", "spec/fixtures/folder1/file1.txt"]
|
||||||
|
sleep 0.6
|
||||||
|
FileUtils.touch([file1, file2, file3])
|
||||||
|
subject.modified_files([@fixture_path.join("folder1/")], {}).should eql []
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with content that has changed" do
|
||||||
|
after { File.open(file1, "w") { |f| f.write('') } }
|
||||||
|
|
||||||
|
it "identifies the files for the second time" do
|
||||||
|
FileUtils.touch([file1, file2, file3])
|
||||||
|
subject.modified_files([@fixture_path.join("folder1/")], {}).should eql ["spec/fixtures/folder1/deletedfile1.txt", "spec/fixtures/folder1/file1.txt"]
|
||||||
|
sleep 0.6
|
||||||
|
FileUtils.touch([file2, file3])
|
||||||
|
File.open(file1, "w") { |f| f.write('changed content') }
|
||||||
|
subject.modified_files([@fixture_path.join("folder1/")], {}).should eql ["spec/fixtures/folder1/file1.txt"]
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user