2011-01-28 18:46:47 -05:00
|
|
|
require 'rubygems/test_case'
|
2007-11-10 02:48:56 -05:00
|
|
|
require 'rubygems/commands/pristine_command'
|
|
|
|
|
2011-01-28 18:46:47 -05:00
|
|
|
class TestGemCommandsPristineCommand < Gem::TestCase
|
2007-11-10 02:48:56 -05:00
|
|
|
|
|
|
|
def setup
|
|
|
|
super
|
|
|
|
@cmd = Gem::Commands::PristineCommand.new
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_execute
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s|
|
2012-11-29 01:52:18 -05:00
|
|
|
s.executables = %w[foo]
|
|
|
|
s.files = %w[bin/foo lib/a.rb]
|
|
|
|
end
|
2011-05-31 23:45:05 -04:00
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
write_file File.join(@tempdir, 'lib', 'a.rb') do |fp|
|
|
|
|
fp.puts "puts __FILE__"
|
|
|
|
end
|
2011-05-31 23:45:05 -04:00
|
|
|
write_file File.join(@tempdir, 'bin', 'foo') do |fp|
|
2007-11-10 02:48:56 -05:00
|
|
|
fp.puts "#!/usr/bin/ruby"
|
|
|
|
end
|
|
|
|
|
|
|
|
install_gem a
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
foo_path = File.join @gemhome, 'gems', a.full_name, 'bin', 'foo'
|
|
|
|
a_rb_path = File.join @gemhome, 'gems', a.full_name, 'lib', 'a.rb'
|
2008-06-17 18:04:18 -04:00
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
write_file foo_path do |io|
|
2008-06-17 18:04:18 -04:00
|
|
|
io.puts 'I changed it!'
|
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
write_file a_rb_path do |io|
|
|
|
|
io.puts 'I changed it!'
|
|
|
|
end
|
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
@cmd.options[:args] = %w[a]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
2008-06-17 18:04:18 -04:00
|
|
|
assert_equal "#!/usr/bin/ruby\n", File.read(foo_path), foo_path
|
2012-11-29 01:52:18 -05:00
|
|
|
assert_equal "puts __FILE__\n", File.read(a_rb_path), a_rb_path
|
2008-06-17 18:04:18 -04:00
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
assert_equal "Restoring gems to pristine condition...", out.shift
|
2008-06-17 18:04:18 -04:00
|
|
|
assert_equal "Restored #{a.full_name}", out.shift
|
2009-06-09 17:38:59 -04:00
|
|
|
assert_empty out, out.inspect
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_execute_all
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s| s.executables = %w[foo] end
|
2011-05-31 23:45:05 -04:00
|
|
|
write_file File.join(@tempdir, 'bin', 'foo') do |fp|
|
2007-11-10 02:48:56 -05:00
|
|
|
fp.puts "#!/usr/bin/ruby"
|
|
|
|
end
|
|
|
|
|
|
|
|
install_gem a
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
gem_bin = File.join @gemhome, 'gems', a.full_name, 'bin', 'foo'
|
|
|
|
gem_stub = File.join @gemhome, 'bin', 'foo'
|
2007-11-10 02:48:56 -05:00
|
|
|
|
|
|
|
FileUtils.rm gem_bin
|
2012-11-29 01:52:18 -05:00
|
|
|
FileUtils.rm gem_stub
|
2007-11-10 02:48:56 -05:00
|
|
|
|
|
|
|
@cmd.handle_options %w[--all]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
2008-06-17 18:04:18 -04:00
|
|
|
assert File.exist?(gem_bin)
|
2012-11-29 01:52:18 -05:00
|
|
|
assert File.exist?(gem_stub)
|
2008-06-17 18:04:18 -04:00
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
assert_equal "Restoring gems to pristine condition...", out.shift
|
2008-06-17 18:04:18 -04:00
|
|
|
assert_equal "Restored #{a.full_name}", out.shift
|
2009-06-09 17:38:59 -04:00
|
|
|
assert_empty out, out.inspect
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
2013-09-14 04:59:02 -04:00
|
|
|
def test_execute_env_shebang
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s|
|
2013-09-14 04:59:02 -04:00
|
|
|
s.executables = %w[foo]
|
|
|
|
s.files = %w[bin/foo]
|
|
|
|
end
|
|
|
|
write_file File.join(@tempdir, 'bin', 'foo') do |fp|
|
|
|
|
fp.puts "#!/usr/bin/ruby"
|
|
|
|
end
|
|
|
|
|
|
|
|
install_gem a
|
|
|
|
|
|
|
|
gem_exec = File.join @gemhome, 'bin', 'foo'
|
|
|
|
|
|
|
|
FileUtils.rm gem_exec
|
|
|
|
|
|
|
|
@cmd.handle_options %w[--all --env-shebang]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_path_exists gem_exec
|
|
|
|
|
|
|
|
if win_platform?
|
|
|
|
assert_match %r%\A#!\s*ruby%, File.read(gem_exec)
|
|
|
|
else
|
|
|
|
assert_match %r%\A#!\s*/usr/bin/env ruby%, File.read(gem_exec)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-18 17:29:41 -04:00
|
|
|
def test_execute_extensions_explicit
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s| s.extensions << 'ext/a/extconf.rb' end
|
2013-09-18 17:29:41 -04:00
|
|
|
|
|
|
|
ext_path = File.join @tempdir, 'ext', 'a', 'extconf.rb'
|
|
|
|
write_file ext_path do |io|
|
|
|
|
io.write <<-'RUBY'
|
|
|
|
File.open "Makefile", "w" do |f|
|
2013-10-15 20:14:16 -04:00
|
|
|
f.puts "clean:\n\techo cleaned\n"
|
2013-09-18 17:29:41 -04:00
|
|
|
f.puts "all:\n\techo built\n"
|
2013-10-15 20:14:16 -04:00
|
|
|
f.puts "install:\n\techo installed\n"
|
2013-09-18 17:29:41 -04:00
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
end
|
|
|
|
|
2013-11-11 19:16:41 -05:00
|
|
|
b = util_spec 'b'
|
2013-09-18 17:29:41 -04:00
|
|
|
|
|
|
|
install_gem a
|
|
|
|
install_gem b
|
|
|
|
|
|
|
|
@cmd.options[:extensions] = true
|
|
|
|
@cmd.options[:extensions_set] = true
|
|
|
|
@cmd.options[:args] = []
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
|
|
|
assert_equal 'Restoring gems to pristine condition...', out.shift
|
|
|
|
assert_equal 'Building native extensions. This could take a while...',
|
|
|
|
out.shift
|
|
|
|
assert_equal "Restored #{a.full_name}", out.shift
|
|
|
|
assert_empty out, out.inspect
|
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
def test_execute_no_extension
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s| s.extensions << 'ext/a/extconf.rb' end
|
2011-05-31 23:45:05 -04:00
|
|
|
|
|
|
|
ext_path = File.join @tempdir, 'ext', 'a', 'extconf.rb'
|
|
|
|
write_file ext_path do |io|
|
|
|
|
io.write '# extconf.rb'
|
2011-03-07 03:44:45 -05:00
|
|
|
end
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
util_build_gem a
|
2011-03-07 03:44:45 -05:00
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
@cmd.options[:args] = %w[a]
|
|
|
|
@cmd.options[:extensions] = false
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
|
|
|
assert_equal 'Restoring gems to pristine condition...', out.shift
|
|
|
|
assert_equal "Skipped #{a.full_name}, it needs to compile an extension",
|
|
|
|
out.shift
|
|
|
|
assert_empty out, out.inspect
|
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
def test_execute_with_extension_with_build_args
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s| s.extensions << 'ext/a/extconf.rb' end
|
2012-11-29 01:52:18 -05:00
|
|
|
|
|
|
|
ext_path = File.join @tempdir, 'ext', 'a', 'extconf.rb'
|
|
|
|
write_file ext_path do |io|
|
|
|
|
io.write <<-'RUBY'
|
|
|
|
File.open "Makefile", "w" do |f|
|
2013-10-15 20:14:16 -04:00
|
|
|
f.puts "clean:\n\techo cleaned\n"
|
2012-11-29 01:52:18 -05:00
|
|
|
f.puts "all:\n\techo built\n"
|
2013-10-15 20:14:16 -04:00
|
|
|
f.puts "install:\n\techo installed\n"
|
2012-11-29 01:52:18 -05:00
|
|
|
end
|
|
|
|
RUBY
|
|
|
|
end
|
|
|
|
|
|
|
|
build_args = %w!--with-awesome=true --sweet!
|
|
|
|
|
|
|
|
install_gem a, :build_args => build_args
|
|
|
|
|
|
|
|
@cmd.options[:args] = %w[a]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
|
|
|
assert_equal 'Restoring gems to pristine condition...', out.shift
|
|
|
|
assert_equal "Building native extensions with: '--with-awesome=true --sweet'", out.shift
|
|
|
|
assert_equal "This could take a while...", out.shift
|
|
|
|
assert_equal "Restored #{a.full_name}", out.shift
|
|
|
|
assert_empty out, out.inspect
|
|
|
|
end
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
def test_execute_many
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a'
|
|
|
|
b = util_spec 'b'
|
2011-05-31 23:45:05 -04:00
|
|
|
|
|
|
|
install_gem a
|
|
|
|
install_gem b
|
|
|
|
|
|
|
|
@cmd.options[:args] = %w[a b]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
|
|
|
assert_equal "Restoring gems to pristine condition...", out.shift
|
|
|
|
assert_equal "Restored #{a.full_name}", out.shift
|
|
|
|
assert_equal "Restored #{b.full_name}", out.shift
|
|
|
|
assert_empty out, out.inspect
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_execute_many_multi_repo
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a'
|
2007-11-10 02:48:56 -05:00
|
|
|
install_gem a
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
Gem.clear_paths
|
|
|
|
gemhome2 = File.join @tempdir, 'gemhome2'
|
|
|
|
Gem.paths = { "GEM_PATH" => [gemhome2, @gemhome], "GEM_HOME" => gemhome2 }
|
|
|
|
|
2013-11-11 19:16:41 -05:00
|
|
|
b = util_spec 'b'
|
2011-05-31 23:45:05 -04:00
|
|
|
install_gem b
|
|
|
|
|
|
|
|
@cmd.options[:args] = %w[a b]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
|
|
|
assert_equal "Restoring gems to pristine condition...", out.shift
|
|
|
|
assert_equal "Restored #{a.full_name}", out.shift
|
|
|
|
assert_equal "Restored #{b.full_name}", out.shift
|
|
|
|
assert_empty out, out.inspect
|
|
|
|
|
|
|
|
assert_path_exists File.join(@gemhome, "gems", 'a-2')
|
|
|
|
refute_path_exists File.join(gemhome2, "gems", 'a-2')
|
|
|
|
assert_path_exists File.join(gemhome2, "gems", 'b-2')
|
|
|
|
refute_path_exists File.join(@gemhome, "gems", 'b-2')
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_execute_missing_cache_gem
|
2013-11-11 19:16:41 -05:00
|
|
|
specs = spec_fetcher do |fetcher|
|
|
|
|
fetcher.gem 'a', 1
|
|
|
|
fetcher.gem 'a', 2
|
|
|
|
fetcher.gem 'a', 3
|
|
|
|
fetcher.gem 'a', '3.a'
|
2011-03-07 03:44:45 -05:00
|
|
|
end
|
|
|
|
|
2013-11-11 19:16:41 -05:00
|
|
|
FileUtils.rm specs['a-2'].cache_file
|
2007-11-10 02:48:56 -05:00
|
|
|
|
|
|
|
@cmd.options[:args] = %w[a]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
out = @ui.output.split "\n"
|
|
|
|
|
2011-03-07 03:44:45 -05:00
|
|
|
[
|
2011-05-31 23:45:05 -04:00
|
|
|
"Restoring gems to pristine condition...",
|
2011-03-07 03:44:45 -05:00
|
|
|
"Restored a-1",
|
|
|
|
"Cached gem for a-2 not found, attempting to fetch...",
|
|
|
|
"Restored a-2",
|
2011-05-31 23:45:05 -04:00
|
|
|
"Restored a-3.a",
|
|
|
|
"Restored a-3",
|
2011-03-07 03:44:45 -05:00
|
|
|
].each do |line|
|
|
|
|
assert_equal line, out.shift
|
|
|
|
end
|
2011-03-07 03:39:39 -05:00
|
|
|
|
2011-03-07 03:44:45 -05:00
|
|
|
assert_empty out, out.inspect
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_execute_no_gem
|
|
|
|
@cmd.options[:args] = %w[]
|
|
|
|
|
2008-10-25 18:58:43 -04:00
|
|
|
e = assert_raises Gem::CommandLineError do
|
2007-11-10 02:48:56 -05:00
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-05-31 23:45:05 -04:00
|
|
|
assert_match %r|at least one gem name|, e.message
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
def test_execute_only_executables
|
2013-11-11 19:16:41 -05:00
|
|
|
a = util_spec 'a' do |s|
|
2012-11-29 01:52:18 -05:00
|
|
|
s.executables = %w[foo]
|
|
|
|
s.files = %w[bin/foo lib/a.rb]
|
|
|
|
end
|
|
|
|
write_file File.join(@tempdir, 'lib', 'a.rb') do |fp|
|
|
|
|
fp.puts "puts __FILE__"
|
|
|
|
end
|
|
|
|
write_file File.join(@tempdir, 'bin', 'foo') do |fp|
|
|
|
|
fp.puts "#!/usr/bin/ruby"
|
|
|
|
end
|
|
|
|
|
|
|
|
install_gem a
|
|
|
|
|
|
|
|
gem_lib = File.join @gemhome, 'gems', a.full_name, 'lib', 'a.rb'
|
|
|
|
gem_exec = File.join @gemhome, 'bin', 'foo'
|
|
|
|
|
|
|
|
FileUtils.rm gem_exec
|
|
|
|
FileUtils.rm gem_lib
|
|
|
|
|
|
|
|
@cmd.handle_options %w[--all --only-executables]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
assert File.exist? gem_exec
|
|
|
|
refute File.exist? gem_lib
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_execute_default_gem
|
|
|
|
default_gem_spec = new_default_spec("default", "2.0.0.0",
|
|
|
|
nil, "default/gem.rb")
|
|
|
|
install_default_specs(default_gem_spec)
|
|
|
|
|
|
|
|
@cmd.options[:args] = %w[default]
|
|
|
|
|
|
|
|
use_ui @ui do
|
|
|
|
@cmd.execute
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal([
|
|
|
|
"Restoring gems to pristine condition...",
|
|
|
|
"Skipped default-2.0.0.0, it is a default gem",
|
|
|
|
],
|
|
|
|
@ui.output.split("\n"))
|
|
|
|
assert_empty(@ui.error)
|
|
|
|
end
|
2013-09-18 17:29:41 -04:00
|
|
|
|
|
|
|
def test_handle_options
|
|
|
|
@cmd.handle_options %w[]
|
|
|
|
|
|
|
|
refute @cmd.options[:all]
|
|
|
|
|
|
|
|
assert @cmd.options[:extensions]
|
|
|
|
refute @cmd.options[:extensions_set]
|
|
|
|
|
|
|
|
assert_equal Gem::Requirement.default, @cmd.options[:version]
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_handle_options_extensions
|
|
|
|
@cmd.handle_options %w[--extensions]
|
|
|
|
|
|
|
|
assert @cmd.options[:extensions]
|
|
|
|
assert @cmd.options[:extensions_set]
|
|
|
|
end
|
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|