fix update-test
Previously, `brew update-test` is run against master branch of local repo. However, we test PR using a detached branch in `brew test-bot`. The result is `brew update-test` will always be up-to-date in `test-bot`. To fix it, we create two local copies of git repo, and set master branch to start and end sha1 correspondingly. After that, `brew update` will be run to simulate the change between start and end sha1. Closes Homebrew/homebrew#43902. Signed-off-by: Xu Cheng <xucheng@me.com>
This commit is contained in:
parent
71198041c6
commit
6792847fc1
@ -2,26 +2,33 @@ require "extend/ENV"
|
|||||||
|
|
||||||
module Homebrew
|
module Homebrew
|
||||||
def update_test
|
def update_test
|
||||||
homebrew_repository_git = HOMEBREW_REPOSITORY/".git"
|
|
||||||
|
|
||||||
mktemp do
|
mktemp do
|
||||||
curdir = Pathname.new(Dir.pwd)
|
curdir = Pathname.new(Dir.pwd)
|
||||||
|
|
||||||
ohai "Setup test environment..."
|
oh1 "Setup test environment..."
|
||||||
# copy Homebrew installation
|
# copy Homebrew installation
|
||||||
cp_r homebrew_repository_git, curdir/".git"
|
cp_r HOMEBREW_REPOSITORY/".git", curdir/".git"
|
||||||
safe_system "git", "checkout", "--force", "master"
|
start_sha1 = Utils.popen_read("git", "rev-parse", "origin/master").chomp
|
||||||
safe_system "git", "reset", "--hard", "origin/master"
|
end_sha1 = Utils.popen_read("git", "rev-parse", "HEAD").chomp
|
||||||
|
|
||||||
# set git origin
|
# set git origin to another copy
|
||||||
safe_system "git", "config", "remote.origin.url", "file://#{homebrew_repository_git}"
|
cp_r HOMEBREW_REPOSITORY/".git", curdir/"remote.git"
|
||||||
|
safe_system "git", "config", "remote.origin.url", "file://#{curdir}/remote.git"
|
||||||
|
|
||||||
|
# force push origin to end_sha1
|
||||||
|
safe_system "git", "checkout", "--force", "master"
|
||||||
|
safe_system "git", "reset", "--hard", end_sha1
|
||||||
|
safe_system "git", "push", "--force", "origin", "master"
|
||||||
|
|
||||||
|
# set test copy to start_sha1
|
||||||
|
safe_system "git", "reset", "--hard", start_sha1
|
||||||
|
|
||||||
# update ENV["PATH"]
|
# update ENV["PATH"]
|
||||||
ENV.extend(Stdenv)
|
ENV.extend(Stdenv)
|
||||||
ENV.prepend_path "PATH", "#{curdir}/bin"
|
ENV.prepend_path "PATH", "#{curdir}/bin"
|
||||||
|
|
||||||
# run brew update
|
# run brew update
|
||||||
ohai "Running brew update..."
|
oh1 "Running brew update..."
|
||||||
safe_system "brew", "update", "--verbose"
|
safe_system "brew", "update", "--verbose"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user