HBASE-19229 Nightly script to check source artifact should not do a destructive git operation without opt-in

Signed-off-by: Apekshit Sharma <appy@apache.org>
(cherry picked from commit 20ed78e6a4)
This commit is contained in:
Sean Busbey 2017-11-09 13:22:09 -06:00
parent 817d341474
commit 3702e7f3de
1 changed files with 13 additions and 2 deletions

View File

@ -28,6 +28,10 @@ function usage {
echo " component-dir." echo " component-dir."
echo " --maven-m2-src-build /path/to/use Path for maven artifacts while building from the" echo " --maven-m2-src-build /path/to/use Path for maven artifacts while building from the"
echo " unpacked source tarball." echo " unpacked source tarball."
echo " --clean-source-checkout Destructively clean component checkout before"
echo " comparing to source tarball. N.B. will delete"
echo " anything in the checkout dir that isn't from"
echo " a git checkout, including ignored files."
exit 1 exit 1
} }
# if no args specified, show usage # if no args specified, show usage
@ -41,6 +45,7 @@ declare unpack_dir
declare m2_initial declare m2_initial
declare m2_tarbuild declare m2_tarbuild
declare working_dir declare working_dir
declare source_clean
while [ $# -gt 0 ] while [ $# -gt 0 ]
do do
case "$1" in case "$1" in
@ -48,6 +53,7 @@ do
--maven-m2-initial) shift; m2_initial=$1; shift;; --maven-m2-initial) shift; m2_initial=$1; shift;;
--maven-m2-src-build) shift; m2_tarbuild=$1; shift;; --maven-m2-src-build) shift; m2_tarbuild=$1; shift;;
--intermediate-file-dir) shift; working_dir=$1; shift;; --intermediate-file-dir) shift; working_dir=$1; shift;;
--clean-source-checkout) shift; source_clean="true";;
--) shift; break;; --) shift; break;;
-*) usage ;; -*) usage ;;
*) break;; # terminate while loop *) break;; # terminate while loop
@ -123,8 +129,10 @@ mvn --version --offline | tee "${working_dir}/maven_version"
echo "Do a clean building of the source artifact using code in ${component_dir}" echo "Do a clean building of the source artifact using code in ${component_dir}"
cd "${component_dir}" cd "${component_dir}"
echo "Clean..." if [ -n "${source_clean}" ]; then
git clean -xdfff >"${working_dir}/component_git_clean.log" 2>&1 echo "Clean..."
git clean -xdfff >"${working_dir}/component_git_clean.log" 2>&1
fi
echo "Follow the ref guide section on making a RC: Step 6 Build the source tarball" echo "Follow the ref guide section on making a RC: Step 6 Build the source tarball"
git archive --format=tar.gz --output="${working_dir}/hbase-src.tar.gz" \ git archive --format=tar.gz --output="${working_dir}/hbase-src.tar.gz" \
--prefix="hbase-SOMEVERSION/" HEAD \ --prefix="hbase-SOMEVERSION/" HEAD \
@ -152,6 +160,9 @@ Only in .: .git
END END
if ! diff known_excluded diff_output >"${working_dir}/unexpected.diff" ; then if ! diff known_excluded diff_output >"${working_dir}/unexpected.diff" ; then
echo "Any output here are unexpected differences between the source artifact we'd make for an RC and the current branch." echo "Any output here are unexpected differences between the source artifact we'd make for an RC and the current branch."
echo "One potential source of differences is if you have an unclean working directory; you should expect to see"
echo "such extraneous files below."
echo ""
echo "The expected differences are on the < side and the current differences are on the > side." echo "The expected differences are on the < side and the current differences are on the > side."
echo "In a given set of differences, '.' refers to the branch in the repo and 'unpacked_src_tarball' refers to what we pulled out of the tarball." echo "In a given set of differences, '.' refers to the branch in the repo and 'unpacked_src_tarball' refers to what we pulled out of the tarball."
diff known_excluded diff_output diff known_excluded diff_output