diff options
author | José Valim <jose.valim@gmail.com> | 2011-12-12 20:26:04 +0100 |
---|---|---|
committer | José Valim <jose.valim@gmail.com> | 2011-12-12 22:54:04 +0100 |
commit | 62cda03fa824ce1e1fc92aaee0367c29ade6a504 (patch) | |
tree | a93be412814a275286cb4e707679ddf32ff1a075 /activesupport/test | |
parent | b04e2d86df388098c12d2067ac6997e11b9479ad (diff) | |
download | rails-62cda03fa824ce1e1fc92aaee0367c29ade6a504.tar.gz rails-62cda03fa824ce1e1fc92aaee0367c29ade6a504.tar.bz2 rails-62cda03fa824ce1e1fc92aaee0367c29ade6a504.zip |
Provide a dir => extension API to file update checker.
Diffstat (limited to 'activesupport/test')
-rw-r--r-- | activesupport/test/file_update_checker_test.rb | 44 |
1 files changed, 26 insertions, 18 deletions
diff --git a/activesupport/test/file_update_checker_test.rb b/activesupport/test/file_update_checker_test.rb index 71290c179c..a5a9b7a682 100644 --- a/activesupport/test/file_update_checker_test.rb +++ b/activesupport/test/file_update_checker_test.rb @@ -4,21 +4,19 @@ require 'fileutils' MTIME_FIXTURES_PATH = File.expand_path("../fixtures", __FILE__) -module FileUpdateCheckerSuite +class FileUpdateCheckerWithEnumerableTest < Test::Unit::TestCase FILES = %w(1.txt 2.txt 3.txt) def setup + FileUtils.mkdir_p("tmp_watcher") FileUtils.touch(FILES) end def teardown + FileUtils.rm_rf("tmp_watcher") FileUtils.rm(FILES) end - def args - raise NotImplementedError - end - def test_should_not_execute_the_block_if_no_paths_are_given i = 0 checker = ActiveSupport::FileUpdateChecker.new([]){ i += 1 } @@ -28,41 +26,51 @@ module FileUpdateCheckerSuite def test_should_invoke_the_block_on_first_call_if_it_does_not_calculate_last_updated_at_on_load i = 0 - checker = ActiveSupport::FileUpdateChecker.new(args){ i += 1 } + checker = ActiveSupport::FileUpdateChecker.new(FILES){ i += 1 } checker.execute_if_updated assert_equal 1, i end def test_should_not_invoke_the_block_on_first_call_if_it_calculates_last_updated_at_on_load i = 0 - checker = ActiveSupport::FileUpdateChecker.new(args, true){ i += 1 } + checker = ActiveSupport::FileUpdateChecker.new(FILES, true){ i += 1 } checker.execute_if_updated assert_equal 0, i end def test_should_not_invoke_the_block_if_no_file_has_changed i = 0 - checker = ActiveSupport::FileUpdateChecker.new(args, true){ i += 1 } + checker = ActiveSupport::FileUpdateChecker.new(FILES, true){ i += 1 } 5.times { assert !checker.execute_if_updated } assert_equal 0, i end def test_should_invoke_the_block_if_a_file_has_changed i = 0 - checker = ActiveSupport::FileUpdateChecker.new(args, true){ i += 1 } + checker = ActiveSupport::FileUpdateChecker.new(FILES, true){ i += 1 } sleep(1) FileUtils.touch(FILES) assert checker.execute_if_updated assert_equal 1, i end -end -class FileUpdateCheckerWithEnumerableTest < Test::Unit::TestCase - include FileUpdateCheckerSuite - def args; FILES; end -end + def test_should_invoke_the_block_if_a_watched_dir_changed_its_glob + i = 0 + checker = ActiveSupport::FileUpdateChecker.new([{"tmp_watcher" => [:txt]}], true){ i += 1 } + FileUtils.cd "tmp_watcher" do + FileUtils.touch(FILES) + end + assert checker.execute_if_updated + assert_equal 1, i + end -class FileUpdateCheckerWithStringTest < Test::Unit::TestCase - include FileUpdateCheckerSuite - def args; "{1,2,3}.txt"; end -end + def test_should_not_invoke_the_block_if_a_watched_dir_changed_its_glob + i = 0 + checker = ActiveSupport::FileUpdateChecker.new([{"tmp_watcher" => :rb}], true){ i += 1 } + FileUtils.cd "tmp_watcher" do + FileUtils.touch(FILES) + end + assert !checker.execute_if_updated + assert_equal 0, i + end +end
\ No newline at end of file |