diff options
author | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-03-31 22:40:06 +0000 |
---|---|---|
committer | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-03-31 22:40:06 +0000 |
commit | 8cc45aae947d453acca029e13eb64f3f5f0bf942 (patch) | |
tree | f9485a20c99defe1aae3f32555a41d23c2298ad8 /test/rubygems/test_gem_commands_sources_command.rb | |
parent | dc8359969ec71ece10357ba9396430db7f029e45 (diff) | |
download | ruby-8cc45aae947d453acca029e13eb64f3f5f0bf942.tar.gz |
Import RubyGems 1.1.0
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15873 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/rubygems/test_gem_commands_sources_command.rb')
-rw-r--r-- | test/rubygems/test_gem_commands_sources_command.rb | 74 |
1 files changed, 65 insertions, 9 deletions
diff --git a/test/rubygems/test_gem_commands_sources_command.rb b/test/rubygems/test_gem_commands_sources_command.rb index 3d1ab801b1..7ba88fad98 100644 --- a/test/rubygems/test_gem_commands_sources_command.rb +++ b/test/rubygems/test_gem_commands_sources_command.rb @@ -31,10 +31,11 @@ class TestGemCommandsSourcesCommand < RubyGemTestCase def test_execute_add util_setup_fake_fetcher - @si = Gem::SourceIndex.new @gem1.full_name => @gem1.name + si = Gem::SourceIndex.new + si.add_spec @a1 @fetcher.data["http://beta-gems.example.com/Marshal.#{@marshal_version}"] = - @si.dump + si.dump @cmd.handle_options %w[--add http://beta-gems.example.com] @@ -45,7 +46,7 @@ class TestGemCommandsSourcesCommand < RubyGemTestCase end expected = <<-EOF -Bulk updating Gem source index for: http://beta-gems.example.com +Bulk updating Gem source index for: http://beta-gems.example.com/ http://beta-gems.example.com added to sources EOF @@ -60,14 +61,11 @@ http://beta-gems.example.com added to sources def test_execute_add_nonexistent_source util_setup_fake_fetcher - @si = Gem::SourceIndex.new @gem1.full_name => @gem1.name - @fetcher.data["http://beta-gems.example.com/Marshal.#{@marshal_version}"] = proc do raise Gem::RemoteFetcher::FetchError, 'it died' end - Gem::RemoteFetcher.instance_variable_set :@fetcher, @fetcher @cmd.handle_options %w[--add http://beta-gems.example.com] @@ -104,6 +102,41 @@ beta-gems.example.com is not a URI assert_equal '', @ui.error end + def test_execute_clear_all + @cmd.handle_options %w[--clear-all] + + util_setup_source_info_cache + + cache = Gem::SourceInfoCache.cache + cache.update + cache.write_cache + + assert File.exist?(cache.system_cache_file), + 'system cache file' + assert File.exist?(cache.latest_system_cache_file), + 'latest system cache file' + + use_ui @ui do + @cmd.execute + end + + expected = <<-EOF +*** Removed user source cache *** +*** Removed latest user source cache *** +*** Removed system source cache *** +*** Removed latest system source cache *** + EOF + + assert_equal expected, @ui.output + assert_equal '', @ui.error + + assert !File.exist?(cache.system_cache_file), + 'system cache file' + assert !File.exist?(cache.latest_system_cache_file), + 'latest system cache file' + + end + def test_execute_remove @cmd.handle_options %W[--remove #{@gem_repo}] @@ -122,20 +155,43 @@ beta-gems.example.com is not a URI assert_equal [], Gem::SourceInfoCache.cache_data.keys end + def test_execute_remove_no_network + @cmd.handle_options %W[--remove #{@gem_repo}] + + util_setup_fake_fetcher + + @fetcher.data["#{@gem_repo}/Marshal.#{Gem.marshal_version}"] = proc do + raise Gem::RemoteFetcher::FetchError + end + + use_ui @ui do + @cmd.execute + end + + expected = "#{@gem_repo} removed from sources\n" + + assert_equal expected, @ui.output + assert_equal '', @ui.error + + Gem::SourceInfoCache.cache.flush + assert_equal [], Gem::SourceInfoCache.cache_data.keys + end + def test_execute_update @cmd.handle_options %w[--update] util_setup_source_info_cache util_setup_fake_fetcher - @si = Gem::SourceIndex.new @gem1.full_name => @gem1.name - @fetcher.data["#{@gem_repo}/Marshal.#{@marshal_version}"] = @si.dump + si = Gem::SourceIndex.new + si.add_spec @a1 + @fetcher.data["#{@gem_repo}/Marshal.#{@marshal_version}"] = si.dump use_ui @ui do @cmd.execute end expected = <<-EOF -Bulk updating Gem source index for: #{@gem_repo} +Bulk updating Gem source index for: #{@gem_repo}/ source cache successfully updated EOF |