diff options
author | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-10 07:48:56 +0000 |
---|---|---|
committer | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-10 07:48:56 +0000 |
commit | fbf59bdbea63efd34ccc144e648467d2f52e7345 (patch) | |
tree | 244f0e7ae112cc7dd135e5d1ac24e6c70ba71b4a /test/rubygems/test_gem_indexer.rb | |
parent | 7a4aad75356496559460041a6c063bdb736c7236 (diff) | |
download | ruby-fbf59bdbea63efd34ccc144e648467d2f52e7345.tar.gz |
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.rb | 103 |
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 + |