summaryrefslogtreecommitdiff
path: root/test/rubygems/test_gem_indexer.rb
diff options
context:
space:
mode:
authordrbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-11-10 07:48:56 +0000
committerdrbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-11-10 07:48:56 +0000
commitfbf59bdbea63efd34ccc144e648467d2f52e7345 (patch)
tree244f0e7ae112cc7dd135e5d1ac24e6c70ba71b4a /test/rubygems/test_gem_indexer.rb
parent7a4aad75356496559460041a6c063bdb736c7236 (diff)
Import RubyGems trunk revision 1493.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13862 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/rubygems/test_gem_indexer.rb')
-rw-r--r--test/rubygems/test_gem_indexer.rb103
1 files changed, 103 insertions, 0 deletions
diff --git a/test/rubygems/test_gem_indexer.rb b/test/rubygems/test_gem_indexer.rb
new file mode 100644
index 0000000000..de509c6b97
--- /dev/null
+++ b/test/rubygems/test_gem_indexer.rb
@@ -0,0 +1,103 @@
+#--
+# Copyright 2006 by Chad Fowler, Rich Kilmer, Jim Weirich and others.
+# All rights reserved.
+# See LICENSE.txt for permissions.
+#++
+
+require 'test/unit'
+require File.join(File.expand_path(File.dirname(__FILE__)), 'gemutilities')
+
+require 'rubygems/indexer'
+
+unless ''.respond_to? :to_xs then
+ warn "Gem::Indexer tests are being skipped. Install builder gem."
+end
+
+class TestGemIndexer < RubyGemTestCase
+
+ def setup
+ super
+
+ util_make_gems
+
+ gems = File.join(@tempdir, 'gems')
+ FileUtils.mkdir_p gems
+ cache_gems = File.join @gemhome, 'cache', '*.gem'
+ FileUtils.mv Dir[cache_gems], gems
+
+ @indexer = Gem::Indexer.new @tempdir
+ end
+
+ def test_initialize
+ assert_equal @tempdir, @indexer.dest_directory
+ assert_equal File.join(Dir.tmpdir, "gem_generate_index_#{$$}"),
+ @indexer.directory
+ end
+
+ def test_generate_index
+ use_ui @ui do
+ @indexer.generate_index
+ end
+
+ assert File.exist?(File.join(@tempdir, 'yaml'))
+ assert File.exist?(File.join(@tempdir, 'yaml.Z'))
+ assert File.exist?(File.join(@tempdir, "Marshal.#{@marshal_version}"))
+ assert File.exist?(File.join(@tempdir, "Marshal.#{@marshal_version}.Z"))
+
+ quickdir = File.join @tempdir, 'quick'
+ marshal_quickdir = File.join quickdir, "Marshal.#{@marshal_version}"
+
+ assert File.directory?(quickdir)
+ assert File.directory?(marshal_quickdir)
+ assert File.exist?(File.join(quickdir, "index"))
+ assert File.exist?(File.join(quickdir, "index.rz"))
+ assert File.exist?(File.join(quickdir, "#{@a0_0_1.full_name}.gemspec.rz"))
+ assert File.exist?(File.join(marshal_quickdir, "#{@a0_0_1.full_name}.gemspec.rz"))
+ assert File.exist?(File.join(quickdir, "#{@a0_0_2.full_name}.gemspec.rz"))
+ assert File.exist?(File.join(marshal_quickdir, "#{@a0_0_2.full_name}.gemspec.rz"))
+ assert File.exist?(File.join(quickdir, "#{@b0_0_2.full_name}.gemspec.rz"))
+ assert File.exist?(File.join(quickdir, "#{@c1_2.full_name}.gemspec.rz"))
+ assert !File.exist?(File.join(quickdir, "#{@c1_2.full_name}.gemspec"))
+ assert !File.exist?(File.join(marshal_quickdir, "#{@c1_2.full_name}.gemspec"))
+ end
+
+ def test_generate_index_ui
+ use_ui @ui do
+ @indexer.generate_index
+ end
+
+ expected = <<-EOF
+Generating index for 4 gems in #{@tempdir}
+....
+Loaded all gems
+Generating master indexes (this may take a while)
+ EOF
+
+ assert_equal expected, @ui.output
+ assert_equal '', @ui.error
+ end
+
+ def test_generate_index_contents
+ use_ui @ui do
+ @indexer.generate_index
+ end
+
+ yaml_path = File.join(@tempdir, 'yaml')
+ dump_path = File.join(@tempdir, "Marshal.#{@marshal_version}")
+
+ yaml_index = YAML.load_file(yaml_path)
+ dump_str = nil
+ File.open dump_path, 'rb' do |fp| dump_str = fp.read end
+ dump_index = Marshal.load dump_str
+
+ dump_index.each do |_,gem|
+ gem.send :remove_instance_variable, :@loaded
+ gem.send :remove_instance_variable, :@original_platform
+ end
+
+ assert_equal yaml_index, dump_index,
+ "expected YAML and Marshal to produce identical results"
+ end
+
+end if ''.respond_to? :to_xs
+