aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/test/test_pathname.rb
diff options
context:
space:
mode:
authorJack Nagel2013-04-10 15:02:45 -0500
committerJack Nagel2013-04-10 20:05:43 -0500
commitd526d2b257e0aa819b7cc90ea00a074b6dc709f6 (patch)
tree3cec59f1ff05d381528e8e0b0fd5eea39aa7bca5 /Library/Homebrew/test/test_pathname.rb
parent951b09b1c51e8aded1b4b8d7e9e2c5523dee350c (diff)
downloadbrew-d526d2b257e0aa819b7cc90ea00a074b6dc709f6.tar.bz2
More comprehensive tests for Pathname extension
Diffstat (limited to 'Library/Homebrew/test/test_pathname.rb')
-rw-r--r--Library/Homebrew/test/test_pathname.rb216
1 files changed, 216 insertions, 0 deletions
diff --git a/Library/Homebrew/test/test_pathname.rb b/Library/Homebrew/test/test_pathname.rb
new file mode 100644
index 000000000..e0e70265f
--- /dev/null
+++ b/Library/Homebrew/test/test_pathname.rb
@@ -0,0 +1,216 @@
+require 'testing_env'
+require 'tmpdir'
+require 'extend/pathname'
+
+class PathnameExtensionTests < Test::Unit::TestCase
+ include FileUtils
+
+ def setup
+ @src = Pathname.new(Dir.mktmpdir)
+ @dst = Pathname.new(Dir.mktmpdir)
+ @file = @src+'foo'
+ @dir = @src+'bar'
+ end
+
+ def teardown
+ rmtree(@src)
+ rmtree(@dst)
+ end
+
+ def test_rmdir_if_possible
+ mkdir_p @dir
+ touch @dir+'foo'
+
+ assert !@dir.rmdir_if_possible
+ assert @dir.directory?
+
+ rm_f @dir+'foo'
+ assert @dir.rmdir_if_possible
+ assert !@dir.exist?
+ end
+
+ def test_rmdir_if_possible_ignore_DS_Store
+ mkdir_p @dir
+ touch @dir+'.DS_Store'
+ assert @dir.rmdir_if_possible
+ assert !@dir.exist?
+ end
+
+ def test_write
+ @file.write('CONTENT')
+ assert_equal 'CONTENT', File.read(@file)
+ end
+
+ def test_write_does_not_overwrite
+ touch @file
+ assert_raises(RuntimeError) { @file.write('CONTENT') }
+ end
+
+ def test_chmod_R
+ perms = 0777
+ FileUtils.expects(:chmod_R).with(perms, @dir.to_s)
+ @dir.chmod_R(perms)
+ end
+
+ def test_atomic_write
+ touch @file
+ @file.atomic_write('CONTENT')
+ assert_equal 'CONTENT', File.read(@file)
+ end
+
+ def test_cp
+ touch @file
+ mkdir_p @dir
+
+ @file.cp(@dir)
+ assert @file.file?
+ assert (@dir+@file.basename).file?
+
+ @dir.cp(@dst)
+ assert @dir.directory?
+ assert (@dst+@dir.basename).directory?
+ end
+
+ def test_ensure_writable
+ touch @file
+ chmod 0555, @file
+ @file.ensure_writable { assert @file.writable? }
+ assert !@file.writable?
+ end
+
+ def test_extname
+ assert_equal '.tar.gz', Pathname('foo-0.1.tar.gz').extname
+ assert_equal '.cpio.gz', Pathname('foo-0.1.cpio.gz').extname
+ end
+
+ def test_stem
+ assert_equal 'foo-0.1', Pathname('foo-0.1.tar.gz').stem
+ assert_equal 'foo-0.1', Pathname('foo-0.1.cpio.gz').stem
+ end
+
+ def test_install_missing_file
+ assert_raises(RuntimeError) do
+ @dst.install 'non_existent_file'
+ end
+ end
+
+ def test_install_removes_original
+ orig_file = @file
+ touch @file
+
+ @file, _ = @dst.install(@file)
+
+ assert_equal orig_file.basename, @file.basename
+ assert @file.exist?
+ assert !orig_file.exist?
+ end
+
+ def setup_install_test
+ cd @src do
+ (@src+'a.txt').write 'This is sample file a.'
+ (@src+'b.txt').write 'This is sample file b.'
+ yield
+ end
+ end
+
+ def test_install
+ setup_install_test do
+ @dst.install 'a.txt'
+
+ assert((@dst+'a.txt').exist?, 'a.txt not installed.')
+ assert(!(@dst+'b.txt').exist?, 'b.txt was installed.')
+ end
+ end
+
+ def test_install_list
+ setup_install_test do
+ @dst.install %w[a.txt b.txt]
+
+ assert((@dst+'a.txt').exist?, 'a.txt not installed.')
+ assert((@dst+'b.txt').exist?, 'b.txt not installed.')
+ end
+ end
+
+ def test_install_glob
+ setup_install_test do
+ @dst.install Dir['*.txt']
+
+ assert((@dst+'a.txt').exist?, 'a.txt not installed.')
+ assert((@dst+'b.txt').exist?, 'b.txt not installed.')
+ end
+ end
+
+ def test_install_directory
+ setup_install_test do
+ mkdir_p 'bin'
+ mv Dir['*.txt'], 'bin'
+
+ @dst.install 'bin'
+
+ assert((@dst+'bin/a.txt').exist?, 'a.txt not installed.')
+ assert((@dst+'bin/b.txt').exist?, 'b.txt not installed.')
+ end
+ end
+
+ def test_install_rename
+ setup_install_test do
+ @dst.install 'a.txt' => 'c.txt'
+
+ assert((@dst+'c.txt').exist?, 'c.txt not installed.')
+ assert(!(@dst+'a.txt').exist?, 'a.txt was installed but not renamed.')
+ assert(!(@dst+'b.txt').exist?, 'b.txt was installed.')
+ end
+ end
+
+ def test_install_rename_more
+ setup_install_test do
+ @dst.install({'a.txt' => 'c.txt', 'b.txt' => 'd.txt'})
+
+ assert((@dst+'c.txt').exist?, 'c.txt not installed.')
+ assert((@dst+'d.txt').exist?, 'd.txt not installed.')
+ assert(!(@dst+'a.txt').exist?, 'a.txt was installed but not renamed.')
+ assert(!(@dst+'b.txt').exist?, 'b.txt was installed but not renamed.')
+ end
+ end
+
+ def test_install_rename_directory
+ setup_install_test do
+ mkdir_p 'bin'
+ mv Dir['*.txt'], 'bin'
+
+ @dst.install 'bin' => 'libexec'
+
+ assert(!(@dst+'bin').exist?, 'bin was installed but not renamed.')
+ assert((@dst+'libexec/a.txt').exist?, 'a.txt not installed.')
+ assert((@dst+'libexec/b.txt').exist?, 'b.txt not installed.')
+ end
+ end
+
+ def test_install_symlink
+ setup_install_test do
+ mkdir_p 'bin'
+ mv Dir['*.txt'], 'bin'
+
+ @dst.install_symlink @src+'bin'
+
+ assert((@dst+'bin').symlink?)
+ assert((@dst+'bin').directory?)
+ assert((@dst+'bin/a.txt').exist?)
+ assert((@dst+'bin/b.txt').exist?)
+ end
+ end
+
+ def test_install_returns_installed_paths
+ foo, bar = @src+'foo', @src+'bar'
+ touch [foo, bar]
+ dirs = @dst.install(foo, bar)
+ assert_equal [@dst+'foo', @dst+'bar'], dirs
+ end
+
+ def test_install_creates_intermediate_directories
+ touch @file
+ assert !@dir.directory?
+ @dir.install(@file)
+ assert @dir.directory?
+ end
+end