summaryrefslogtreecommitdiffstats
path: root/test/rubygems/test_gem_source_info_cache_entry.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
commit5e82c0056eee146b578f71e5dd5d65ef62557382 (patch)
tree244f0e7ae112cc7dd135e5d1ac24e6c70ba71b4a /test/rubygems/test_gem_source_info_cache_entry.rb
parente0a7803c8f5f3efca2648add1051456d70a92574 (diff)
downloadruby-5e82c0056eee146b578f71e5dd5d65ef62557382.tar.gz
ruby-5e82c0056eee146b578f71e5dd5d65ef62557382.tar.xz
ruby-5e82c0056eee146b578f71e5dd5d65ef62557382.zip
Import RubyGems trunk revision 1493.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@13862 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/rubygems/test_gem_source_info_cache_entry.rb')
-rw-r--r--test/rubygems/test_gem_source_info_cache_entry.rb46
1 files changed, 46 insertions, 0 deletions
diff --git a/test/rubygems/test_gem_source_info_cache_entry.rb b/test/rubygems/test_gem_source_info_cache_entry.rb
new file mode 100644
index 000000000..023baf948
--- /dev/null
+++ b/test/rubygems/test_gem_source_info_cache_entry.rb
@@ -0,0 +1,46 @@
+require 'test/unit'
+require File.join(File.expand_path(File.dirname(__FILE__)), 'gemutilities')
+require 'rubygems/source_info_cache_entry'
+
+class TestGemSourceInfoCacheEntry < RubyGemTestCase
+
+ def setup
+ super
+
+ util_setup_fake_fetcher
+
+ @si = Gem::SourceIndex.new @gem1.full_name => @gem1.name
+ @sic_e = Gem::SourceInfoCacheEntry.new @si, @si.dump.size
+ end
+
+ def test_refresh
+ @fetcher.data["#{@gem_repo}/Marshal.#{@marshal_version}.Z"] =
+ proc { raise Exception }
+ @fetcher.data["#{@gem_repo}/Marshal.#{@marshal_version}"] = @si.dump
+
+ assert_nothing_raised do
+ @sic_e.refresh @gem_repo
+ end
+ end
+
+ def test_refresh_bad_uri
+ assert_raise URI::BadURIError do
+ @sic_e.refresh 'gems.example.com'
+ end
+ end
+
+ def test_refresh_update
+ si = Gem::SourceIndex.new @gem1.full_name => @gem1,
+ @gem2.full_name => @gem2
+ @fetcher.data["#{@gem_repo}/Marshal.#{@marshal_version}"] = si.dump
+
+ use_ui @ui do
+ @sic_e.refresh @gem_repo
+ end
+
+ new_gem = @sic_e.source_index.specification(@gem2.full_name)
+ assert_equal @gem2.full_name, new_gem.full_name
+ end
+
+end
+