diff options
Diffstat (limited to 'spec/unit/chef_fs/diff_spec.rb')
-rw-r--r-- | spec/unit/chef_fs/diff_spec.rb | 328 |
1 files changed, 0 insertions, 328 deletions
diff --git a/spec/unit/chef_fs/diff_spec.rb b/spec/unit/chef_fs/diff_spec.rb deleted file mode 100644 index 2133d05139..0000000000 --- a/spec/unit/chef_fs/diff_spec.rb +++ /dev/null @@ -1,328 +0,0 @@ -# -# Author:: John Keiser (<jkeiser@opscode.com>) -# Copyright:: Copyright (c) 2012 Opscode, Inc. -# License:: Apache License, Version 2.0 -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. -# - -require 'spec_helper' -require 'chef/chef_fs/file_pattern' -require 'chef/chef_fs/command_line' - -# Removes the date stamp from the diff and replaces it with ' DATE' -# example match: "/dev/null\t2012-10-16 16:15:54.000000000 +0000" -# windows match: "--- /dev/null\tTue Oct 16 18:04:34 2012" -def remove_os_differences(diff) - diff = diff.gsub(/([+-]{3}.*)\t.*/, '\1 DATE') - diff.gsub(/^@@ -\d(,\d)? \+\d(,\d)? @@/, 'CONTEXT_LINE_NUMBERS') -end - -describe 'diff', :uses_diff => true do - include FileSystemSupport - - context 'with two filesystems with all types of difference' do - let(:a) { - memory_fs('a', { - :both_dirs => { - :sub_both_dirs => { :subsub => nil }, - :sub_both_files => nil, - :sub_both_files_different => "a\n", - :sub_both_dirs_empty => {}, - :sub_dirs_empty_in_a_filled_in_b => {}, - :sub_dirs_empty_in_b_filled_in_a => { :subsub => nil }, - :sub_a_only_dir => { :subsub => nil }, - :sub_a_only_file => nil, - :sub_dir_in_a_file_in_b => {}, - :sub_file_in_a_dir_in_b => nil - }, - :both_files => nil, - :both_files_different => "a\n", - :both_dirs_empty => {}, - :dirs_empty_in_a_filled_in_b => {}, - :dirs_empty_in_b_filled_in_a => { :subsub => nil }, - :dirs_in_a_cannot_be_in_b => {}, - :file_in_a_cannot_be_in_b => nil, - :a_only_dir => { :subsub => nil }, - :a_only_file => nil, - :dir_in_a_file_in_b => {}, - :file_in_a_dir_in_b => nil - }, /cannot_be_in_a/) - } - let(:b) { - memory_fs('b', { - :both_dirs => { - :sub_both_dirs => { :subsub => nil }, - :sub_both_files => nil, - :sub_both_files_different => "b\n", - :sub_both_dirs_empty => {}, - :sub_dirs_empty_in_a_filled_in_b => { :subsub => nil }, - :sub_dirs_empty_in_b_filled_in_a => {}, - :sub_b_only_dir => { :subsub => nil }, - :sub_b_only_file => nil, - :sub_dir_in_a_file_in_b => nil, - :sub_file_in_a_dir_in_b => {} - }, - :both_files => nil, - :both_files_different => "b\n", - :both_dirs_empty => {}, - :dirs_empty_in_a_filled_in_b => { :subsub => nil }, - :dirs_empty_in_b_filled_in_a => {}, - :dirs_in_b_cannot_be_in_a => {}, - :file_in_b_cannot_be_in_a => nil, - :b_only_dir => { :subsub => nil }, - :b_only_file => nil, - :dir_in_a_file_in_b => nil, - :file_in_a_dir_in_b => {} - }, /cannot_be_in_b/) - } - it 'Chef::ChefFS::CommandLine.diff_print(/)' do - results = [] - Chef::ChefFS::CommandLine.diff_print(pattern('/'), a, b, nil, nil) do |diff| - results << remove_os_differences(diff) - end - results.should =~ [ - 'diff --knife a/both_dirs/sub_both_files_different b/both_dirs/sub_both_files_different ---- a/both_dirs/sub_both_files_different DATE -+++ b/both_dirs/sub_both_files_different DATE -CONTEXT_LINE_NUMBERS --a -+b -','diff --knife a/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub b/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub -new file ---- /dev/null DATE -+++ b/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub DATE -CONTEXT_LINE_NUMBERS -+subsub -','diff --knife a/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub b/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub -deleted file ---- a/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --subsub -','Only in a/both_dirs: sub_a_only_dir -','diff --knife a/both_dirs/sub_a_only_file b/both_dirs/sub_a_only_file -deleted file ---- a/both_dirs/sub_a_only_file DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --sub_a_only_file -','File a/both_dirs/sub_dir_in_a_file_in_b is a directory while file b/both_dirs/sub_dir_in_a_file_in_b is a regular file -','File a/both_dirs/sub_file_in_a_dir_in_b is a regular file while file b/both_dirs/sub_file_in_a_dir_in_b is a directory -','Only in b/both_dirs: sub_b_only_dir -','diff --knife a/both_dirs/sub_b_only_file b/both_dirs/sub_b_only_file -new file ---- /dev/null DATE -+++ b/both_dirs/sub_b_only_file DATE -CONTEXT_LINE_NUMBERS -+sub_b_only_file -','diff --knife a/both_files_different b/both_files_different ---- a/both_files_different DATE -+++ b/both_files_different DATE -CONTEXT_LINE_NUMBERS --a -+b -','diff --knife a/dirs_empty_in_a_filled_in_b/subsub b/dirs_empty_in_a_filled_in_b/subsub -new file ---- /dev/null DATE -+++ b/dirs_empty_in_a_filled_in_b/subsub DATE -CONTEXT_LINE_NUMBERS -+subsub -','diff --knife a/dirs_empty_in_b_filled_in_a/subsub b/dirs_empty_in_b_filled_in_a/subsub -deleted file ---- a/dirs_empty_in_b_filled_in_a/subsub DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --subsub -','Only in a: a_only_dir -','diff --knife a/a_only_file b/a_only_file -deleted file ---- a/a_only_file DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --a_only_file -','File a/dir_in_a_file_in_b is a directory while file b/dir_in_a_file_in_b is a regular file -','File a/file_in_a_dir_in_b is a regular file while file b/file_in_a_dir_in_b is a directory -','Only in b: b_only_dir -','diff --knife a/b_only_file b/b_only_file -new file ---- /dev/null DATE -+++ b/b_only_file DATE -CONTEXT_LINE_NUMBERS -+b_only_file -' ] - end - it 'Chef::ChefFS::CommandLine.diff_print(/both_dirs)' do - results = [] - Chef::ChefFS::CommandLine.diff_print(pattern('/both_dirs'), a, b, nil, nil) do |diff| - results << remove_os_differences(diff) - end - results.should =~ [ - 'diff --knife a/both_dirs/sub_both_files_different b/both_dirs/sub_both_files_different ---- a/both_dirs/sub_both_files_different DATE -+++ b/both_dirs/sub_both_files_different DATE -CONTEXT_LINE_NUMBERS --a -+b -','diff --knife a/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub b/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub -new file ---- /dev/null DATE -+++ b/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub DATE -CONTEXT_LINE_NUMBERS -+subsub -','diff --knife a/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub b/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub -deleted file ---- a/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --subsub -','Only in a/both_dirs: sub_a_only_dir -','diff --knife a/both_dirs/sub_a_only_file b/both_dirs/sub_a_only_file -deleted file ---- a/both_dirs/sub_a_only_file DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --sub_a_only_file -','File a/both_dirs/sub_dir_in_a_file_in_b is a directory while file b/both_dirs/sub_dir_in_a_file_in_b is a regular file -','File a/both_dirs/sub_file_in_a_dir_in_b is a regular file while file b/both_dirs/sub_file_in_a_dir_in_b is a directory -','Only in b/both_dirs: sub_b_only_dir -','diff --knife a/both_dirs/sub_b_only_file b/both_dirs/sub_b_only_file -new file ---- /dev/null DATE -+++ b/both_dirs/sub_b_only_file DATE -CONTEXT_LINE_NUMBERS -+sub_b_only_file -' ] - end - it 'Chef::ChefFS::CommandLine.diff_print(/) with depth 1' do - results = [] - Chef::ChefFS::CommandLine.diff_print(pattern('/'), a, b, 1, nil) do |diff| - results << remove_os_differences(diff) - end - results.should =~ [ -'Common subdirectories: b/both_dirs -','diff --knife a/both_files_different b/both_files_different ---- a/both_files_different DATE -+++ b/both_files_different DATE -CONTEXT_LINE_NUMBERS --a -+b -','Common subdirectories: b/both_dirs_empty -','Common subdirectories: b/dirs_empty_in_b_filled_in_a -','Common subdirectories: b/dirs_empty_in_a_filled_in_b -','Only in a: a_only_dir -','diff --knife a/a_only_file b/a_only_file -deleted file ---- a/a_only_file DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --a_only_file -','File a/dir_in_a_file_in_b is a directory while file b/dir_in_a_file_in_b is a regular file -','File a/file_in_a_dir_in_b is a regular file while file b/file_in_a_dir_in_b is a directory -','Only in b: b_only_dir -','diff --knife a/b_only_file b/b_only_file -new file ---- /dev/null DATE -+++ b/b_only_file DATE -CONTEXT_LINE_NUMBERS -+b_only_file -' ] - end - it 'Chef::ChefFS::CommandLine.diff_print(/*_*) with depth 0' do - results = [] - Chef::ChefFS::CommandLine.diff_print(pattern('/*_*'), a, b, 0, nil) do |diff| - results << remove_os_differences(diff) - end - results.should =~ [ -'Common subdirectories: b/both_dirs -','diff --knife a/both_files_different b/both_files_different ---- a/both_files_different DATE -+++ b/both_files_different DATE -CONTEXT_LINE_NUMBERS --a -+b -','Common subdirectories: b/both_dirs_empty -','Common subdirectories: b/dirs_empty_in_b_filled_in_a -','Common subdirectories: b/dirs_empty_in_a_filled_in_b -','Only in a: a_only_dir -','diff --knife a/a_only_file b/a_only_file -deleted file ---- a/a_only_file DATE -+++ /dev/null DATE -CONTEXT_LINE_NUMBERS --a_only_file -','File a/dir_in_a_file_in_b is a directory while file b/dir_in_a_file_in_b is a regular file -','File a/file_in_a_dir_in_b is a regular file while file b/file_in_a_dir_in_b is a directory -','Only in b: b_only_dir -','diff --knife a/b_only_file b/b_only_file -new file ---- /dev/null DATE -+++ b/b_only_file DATE -CONTEXT_LINE_NUMBERS -+b_only_file -' ] - end - it 'Chef::ChefFS::CommandLine.diff_print(/) in name-only mode' do - results = [] - Chef::ChefFS::CommandLine.diff_print(pattern('/'), a, b, nil, :name_only) do |diff| - results << remove_os_differences(diff) - end - results.should =~ [ - "b/both_dirs/sub_both_files_different\n", - "b/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub\n", - "b/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub\n", - "b/both_dirs/sub_a_only_dir\n", - "b/both_dirs/sub_a_only_file\n", - "b/both_dirs/sub_b_only_dir\n", - "b/both_dirs/sub_b_only_file\n", - "b/both_dirs/sub_dir_in_a_file_in_b\n", - "b/both_dirs/sub_file_in_a_dir_in_b\n", - "b/both_files_different\n", - "b/dirs_empty_in_b_filled_in_a/subsub\n", - "b/dirs_empty_in_a_filled_in_b/subsub\n", - "b/a_only_dir\n", - "b/a_only_file\n", - "b/b_only_dir\n", - "b/b_only_file\n", - "b/dir_in_a_file_in_b\n", - "b/file_in_a_dir_in_b\n" - ] - end - it 'Chef::ChefFS::CommandLine.diff_print(/) in name-status mode' do - results = [] - Chef::ChefFS::CommandLine.diff_print(pattern('/'), a, b, nil, :name_status) do |diff| - results << remove_os_differences(diff) - end - results.should =~ [ - "M\tb/both_dirs/sub_both_files_different\n", - "D\tb/both_dirs/sub_dirs_empty_in_b_filled_in_a/subsub\n", - "A\tb/both_dirs/sub_dirs_empty_in_a_filled_in_b/subsub\n", - "D\tb/both_dirs/sub_a_only_dir\n", - "D\tb/both_dirs/sub_a_only_file\n", - "A\tb/both_dirs/sub_b_only_dir\n", - "A\tb/both_dirs/sub_b_only_file\n", - "T\tb/both_dirs/sub_dir_in_a_file_in_b\n", - "T\tb/both_dirs/sub_file_in_a_dir_in_b\n", - "M\tb/both_files_different\n", - "D\tb/dirs_empty_in_b_filled_in_a/subsub\n", - "A\tb/dirs_empty_in_a_filled_in_b/subsub\n", - "D\tb/a_only_dir\n", - "D\tb/a_only_file\n", - "A\tb/b_only_dir\n", - "A\tb/b_only_file\n", - "T\tb/dir_in_a_file_in_b\n", - "T\tb/file_in_a_dir_in_b\n" - ] - end - end -end |