brew/Library/Homebrew/test/test_updater.rb

108 lines
3.5 KiB
Ruby
Raw Normal View History

2010-02-12 14:56:01 -08:00
abort if ARGV.include? "--skip-update"
require 'testing_env'
require 'formula'
require 'cmd/update'
2010-02-12 14:56:01 -08:00
class UpdaterMock < Updater
def in_repo_expect(cmd, output = '')
@outputs ||= Hash.new { |h,k| h[k] = [] }
@expected ||= []
@expected << cmd
@outputs[cmd] << output
2010-02-12 14:56:01 -08:00
end
def `(cmd, *args)
cmd = "#{cmd} #{args*' '}".strip
if @expected.include?(cmd) and !@outputs[cmd].empty?
@called ||= []
@called << cmd
@outputs[cmd].shift
2010-02-12 14:56:01 -08:00
else
raise "#<#{self.class.name} #{object_id}> unexpectedly called backticks: `#{cmd}'"
2010-02-12 14:56:01 -08:00
end
end
alias safe_system ` #`
2010-02-12 14:56:01 -08:00
def expectations_met?
@expected == @called
2010-02-12 14:56:01 -08:00
end
end
class UpdaterTests < Test::Unit::TestCase
def fixture(name)
self.class.fixture_data[name]
end
def self.fixture_data
unless @fixture_data
require 'yaml'
@fixture_data = YAML.load_file(Pathname.new(ABS__FILE__).parent.realpath + 'fixtures/updater_fixture.yaml')
end
@fixture_data
end
def test_update_homebrew_without_any_changes
HOMEBREW_REPOSITORY.cd do
updater = UpdaterMock.new
updater.in_repo_expect("git checkout -q master")
updater.in_repo_expect("git rev-parse -q --verify HEAD", "1234abcd")
updater.in_repo_expect("git config core.autocrlf false")
updater.in_repo_expect("git pull -q origin refs/heads/master:refs/remotes/origin/master")
updater.in_repo_expect("git rev-parse -q --verify HEAD", "3456cdef")
updater.in_repo_expect("git diff-tree -r --raw -M85% 1234abcd 3456cdef")
updater.pull!
report = Report.new
report.merge!(updater.report)
assert updater.expectations_met?
assert report.empty?
end
end
def test_update_homebrew_without_formulae_changes
diff_output = fixture('update_git_diff_output_without_formulae_changes')
HOMEBREW_REPOSITORY.cd do
updater = UpdaterMock.new
updater.in_repo_expect("git checkout -q master")
updater.in_repo_expect("git rev-parse -q --verify HEAD", "1234abcd")
updater.in_repo_expect("git config core.autocrlf false")
updater.in_repo_expect("git pull -q origin refs/heads/master:refs/remotes/origin/master")
updater.in_repo_expect("git rev-parse -q --verify HEAD", "3456cdef")
updater.in_repo_expect("git diff-tree -r --raw -M85% 1234abcd 3456cdef", diff_output)
updater.pull!
report = Report.new
report.merge!(updater.report)
assert updater.expectations_met?
assert report.select_formula(:M).empty?
assert report.select_formula(:A).empty?
assert report.select_formula(:R).empty?
end
end
def test_update_homebrew_with_formulae_changes
diff_output = fixture('update_git_diff_output_with_formulae_changes')
HOMEBREW_REPOSITORY.cd do
updater = UpdaterMock.new
updater.in_repo_expect("git checkout -q master")
updater.in_repo_expect("git rev-parse -q --verify HEAD", "1234abcd")
updater.in_repo_expect("git config core.autocrlf false")
updater.in_repo_expect("git pull -q origin refs/heads/master:refs/remotes/origin/master")
updater.in_repo_expect("git rev-parse -q --verify HEAD", "3456cdef")
updater.in_repo_expect("git diff-tree -r --raw -M85% 1234abcd 3456cdef", diff_output)
updater.pull!
report = Report.new
report.merge!(updater.report)
assert updater.expectations_met?
assert_equal %w{ xar yajl }, report.select_formula(:M)
assert_equal %w{ antiword bash-completion ddrescue dict lua }, report.select_formula(:A)
assert_equal %w{ shapelib }, report.select_formula(:R)
end
end
end