Accepting request 959841 from openSUSE:Tools

- handle -a also in same-build-result.sh
- Find rpmlint.log in more places
- fix logic error in appstream comparison
- rework exit handling in same-build-result.sh
- Fix result in case no rpmlint.log exist
- remove count of checks and packages from rpmlint.log
- remove Check time report from rpmlint.log
- ELF diffing performance improvements
- unpack packages in parallel
- Add zstd handling
- Add extra handling for KMP versions

OBS-URL: https://build.opensuse.org/request/show/959841
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/build-compare?expand=0&rev=120
This commit is contained in:
Dominique Leuenberger 2022-03-09 17:46:26 +00:00 committed by Git OBS Bridge
commit 6c858eeea4
6 changed files with 366 additions and 281 deletions

View File

@ -1,3 +1,22 @@
-------------------------------------------------------------------
Fri Mar 4 12:34:56 UTC 2022 - olaf@aepfle.de
- handle -a also in same-build-result.sh
- Find rpmlint.log in more places
- fix logic error in appstream comparison
- rework exit handling in same-build-result.sh
- Fix result in case no rpmlint.log exist
- remove count of checks and packages from rpmlint.log
- remove Check time report from rpmlint.log
- ELF diffing performance improvements
- unpack packages in parallel
- Add zstd handling
-------------------------------------------------------------------
Wed Feb 23 08:13:27 UTC 2022 - Stefan Seyfried <seife+obs@b1-systems.com>
- Add extra handling for KMP versions
------------------------------------------------------------------- -------------------------------------------------------------------
Tue Sep 21 19:19:19 UTC 2021 - Stephan Kulow <coolo@suse.de> Tue Sep 21 19:19:19 UTC 2021 - Stephan Kulow <coolo@suse.de>

View File

@ -21,7 +21,7 @@ Summary: Build Result Compare Script
License: GPL-2.0+ License: GPL-2.0+
Group: Development/Tools/Building Group: Development/Tools/Building
Url: https://github.com/openSUSE/build-compare Url: https://github.com/openSUSE/build-compare
Version: 20210921T214418.86d06d9 Version: 20220307T115648.b5abdde
Release: 0 Release: 0
Source1: COPYING Source1: COPYING
Source2: same-build-result.sh Source2: same-build-result.sh

View File

@ -141,23 +141,38 @@ check_header()
# - it is used as direntry below certain paths # - it is used as direntry below certain paths
# - it is assigned to some variable in scripts, at the end of a line # - it is assigned to some variable in scripts, at the end of a line
# - it is used in PROVIDES, at the end of a line # - it is used in PROVIDES, at the end of a line
# - special-case KMP package:
# PROVIDES version_k.*-release at end of line, trim release
# [ 23s] -acpi_call-kmp-default 8 1.2.2_k5.17.0_rc5_1.ga9b2c1d-6.110
# [ 23s] +acpi_call-kmp-default 8 1.2.2_k5.17.0_rc5_1.ga9b2c1d-6.111
# Trim name-version-release string: # Trim name-version-release string:
# - it is used in update-scripts which are called by libzypp # - it is used in update-scripts which are called by libzypp
# - special-case KMP package:
# [ 64s] PREIN
# [ 64s] /bin/sh (none) /usr/lib/module-init-tools/kernel-scriptlets/kmp-pre --name "acpi_call-kmp-default" \
# [ 64s] - --version "1.2.2_k5.17.0_rc5_1.ga9b2c1d" --release "6.112" --kernelrelease "5.17.0-rc5-1.ga9b2c1d" \
# [ 64s] + --version "1.2.2_k5.17.0_rc5_1.ga9b2c1d" --release "6.113" --kernelrelease "5.17.0-rc5-1.ga9b2c1d" \
function trim_release_old() function trim_release_old()
{ {
local rel_regex_l=${version_release_old_regex_l##*-}
sed -e " sed -e "
/\(\/boot\|\/lib\/modules\|\/lib\/firmware\|\/usr\/src\|$version_release_old_regex_l\$\|$version_release_old_regex_l)\)/{s,$version_release_old_regex_l,@VERSION@-@RELEASE_LONG@,g;s,$version_release_old_regex_s,@VERSION@-@RELEASE_SHORT@,g} /\(\/boot\|\/lib\/modules\|\/lib\/firmware\|\/usr\/src\|$version_release_old_regex_l\$\|$version_release_old_regex_l)\)/{s,$version_release_old_regex_l,@VERSION@-@RELEASE_LONG@,g;s,$version_release_old_regex_s,@VERSION@-@RELEASE_SHORT@,g}
s/\(\/var\/adm\/update-scripts\/\)${name_ver_rel_old_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g s/\(\/var\/adm\/update-scripts\/\)${name_ver_rel_old_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g
s/\(\/var\/adm\/update-messages\/\)${name_ver_rel_old_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g s/\(\/var\/adm\/update-messages\/\)${name_ver_rel_old_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g
s/\(^[^[:blank:]].*-kmp-.*[[:blank:]].*_k.*-\)${rel_regex_l}$/\1@RELEASE_LONG@/g
s/--release \"${rel_regex_l}\" --kernel/--release \"@RELEASE_LONG@\" --kernel/g
/\/usr\/lib\/\.build-id/d /\/usr\/lib\/\.build-id/d
" "
} }
function trim_release_new() function trim_release_new()
{ {
local rel_regex_l=${version_release_new_regex_l##*-}
sed -e " sed -e "
/\(\/boot\|\/lib\/modules\|\/lib\/firmware\|\/usr\/src\|$version_release_new_regex_l\$\|$version_release_new_regex_l)\)/{s,$version_release_new_regex_l,@VERSION@-@RELEASE_LONG@,g;s,$version_release_new_regex_s,@VERSION@-@RELEASE_SHORT@,g} /\(\/boot\|\/lib\/modules\|\/lib\/firmware\|\/usr\/src\|$version_release_new_regex_l\$\|$version_release_new_regex_l)\)/{s,$version_release_new_regex_l,@VERSION@-@RELEASE_LONG@,g;s,$version_release_new_regex_s,@VERSION@-@RELEASE_SHORT@,g}
s/\(\/var\/adm\/update-scripts\/\)${name_ver_rel_new_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g s/\(\/var\/adm\/update-scripts\/\)${name_ver_rel_new_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g
s/\(\/var\/adm\/update-messages\/\)${name_ver_rel_new_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g s/\(\/var\/adm\/update-messages\/\)${name_ver_rel_new_regex_l}\([^[:blank:]]\+\)/\1@NAME_VER_REL@\2/g
s/\(^[^[:blank:]].*-kmp-.*[[:blank:]].*_k.*-\)${rel_regex_l}$/\1@RELEASE_LONG@/g
s/--release \"${rel_regex_l}\" --kernel/--release \"@RELEASE_LONG@\" --kernel/g
/\/usr\/lib\/\.build-id/d /\/usr\/lib\/\.build-id/d
" "
} }
@ -280,16 +295,15 @@ function set_regex() {
function cmp_rpm_meta () function cmp_rpm_meta ()
{ {
local RES local RES
local file1 file2
local f local f
local sh=$1 local sh=$1
local oldrpm=$2 local oldrpm=$2
local newrpm=$3 local newrpm=$3
local tmpdir="$(mktemp -d)"
file1=`mktemp` local file1="$tmpdir/file1"
file2=`mktemp` local file2="$tmpdir/file2"
rpm_meta_old=`mktemp` local rpm_meta_old="$tmpdir/rpm-meta-old"
rpm_meta_new=`mktemp` local rpm_meta_new="$tmpdir/rpm-meta-new"
collect_rpm_querytags collect_rpm_querytags
set_rpm_meta_global_variables $oldrpm set_rpm_meta_global_variables $oldrpm
@ -303,6 +317,7 @@ function cmp_rpm_meta ()
else else
ls -l $rpm_meta_old $rpm_meta_new ls -l $rpm_meta_old $rpm_meta_new
echo "empty 'rpm -qp' output..." echo "empty 'rpm -qp' output..."
rm -rf "$tmpdir"
return 1 return 1
fi fi
@ -317,17 +332,20 @@ function cmp_rpm_meta ()
# Check the whole spec file at first, return 0 immediately if they # Check the whole spec file at first, return 0 immediately if they
# are the same. # are the same.
cat $rpm_meta_old | trim_release_old > $file1 trim_release_old < $rpm_meta_old > $file1
cat $rpm_meta_new | trim_release_new > $file2 trim_release_new < $rpm_meta_new > $file2
echo "comparing the rpm tags of $name_new" echo "comparing the rpm tags of $name_new"
if diff --label old-rpm-tags --label new-rpm-tags -au $file1 $file2; then if diff --speed-large-files --label old-rpm-tags --label new-rpm-tags -au0 $file1 $file2; then
rm $file1 $file2 $rpm_meta_old $rpm_meta_new rm -rf "$tmpdir"
return 0 return 0
fi fi
get_value QF_TAGS $rpm_meta_old > $file1 get_value QF_TAGS $rpm_meta_old > $file1
get_value QF_TAGS $rpm_meta_new > $file2 get_value QF_TAGS $rpm_meta_new > $file2
comp_file rpmtags $file1 $file2 $rpm_meta_old $rpm_meta_new || return 1 if ! comp_file rpmtags $file1 $file2 $rpm_meta_old $rpm_meta_new; then
rm -rf "$tmpdir"
return 1
fi
# This might happen when?! # This might happen when?!
echo "comparing RELEASE" echo "comparing RELEASE"
@ -337,6 +355,7 @@ function cmp_rpm_meta ()
# Make sure all kernel packages have the same %RELEASE # Make sure all kernel packages have the same %RELEASE
echo "release prefix mismatch" echo "release prefix mismatch"
if test -z "$check_all"; then if test -z "$check_all"; then
rm -rf "$tmpdir"
return 1 return 1
fi fi
difffound=1 difffound=1
@ -348,16 +367,25 @@ function cmp_rpm_meta ()
get_value QF_PROVIDES $rpm_meta_old | trim_release_old | sort > $file1 get_value QF_PROVIDES $rpm_meta_old | trim_release_old | sort > $file1
get_value QF_PROVIDES $rpm_meta_new | trim_release_new | sort > $file2 get_value QF_PROVIDES $rpm_meta_new | trim_release_new | sort > $file2
comp_file PROVIDES $file1 $file2 $rpm_meta_old $rpm_meta_new || return 1 if ! comp_file PROVIDES $file1 $file2 $rpm_meta_old $rpm_meta_new; then
rm -rf "$tmpdir"
return 1
fi
get_value QF_SCRIPT $rpm_meta_old | trim_release_old > $file1 get_value QF_SCRIPT $rpm_meta_old | trim_release_old > $file1
get_value QF_SCRIPT $rpm_meta_new | trim_release_new > $file2 get_value QF_SCRIPT $rpm_meta_new | trim_release_new > $file2
comp_file scripts $file1 $file2 $rpm_meta_old $rpm_meta_new || return 1 if ! comp_file scripts $file1 $file2 $rpm_meta_old $rpm_meta_new; then
rm -rf "$tmpdir"
return 1
fi
# First check the file attributes and later the md5s # First check the file attributes and later the md5s
get_value QF_FILELIST $rpm_meta_old | trim_release_old > $file1 get_value QF_FILELIST $rpm_meta_old | trim_release_old > $file1
get_value QF_FILELIST $rpm_meta_new | trim_release_new > $file2 get_value QF_FILELIST $rpm_meta_new | trim_release_new > $file2
comp_file filelist $file1 $file2 $rpm_meta_old $rpm_meta_new || return 1 if ! comp_file filelist $file1 $file2 $rpm_meta_old $rpm_meta_new; then
rm -rf "$tmpdir"
return 1
fi
# now the md5sums. if they are different, we check more detailed # now the md5sums. if they are different, we check more detailed
# if there are different filenames, we will already have aborted before # if there are different filenames, we will already have aborted before
@ -392,8 +420,8 @@ function cmp_rpm_meta ()
echo mv -v \"new/${f}\" \"new/`echo ${f} | trim_release_new`\" echo mv -v \"new/${f}\" \"new/`echo ${f} | trim_release_new`\"
done >> "${sh}" done >> "${sh}"
fi fi
#
rm $file1 $file2 rm -rf "$tmpdir"
[ "$difffound" = 1 ] && RES=1 [ "$difffound" = 1 ] && RES=1
return $RES return $RES
} }
@ -404,9 +432,9 @@ function adjust_controlfile() {
version_release_new="`sed -ne 's/^Version: \(.*\)/\1/p' $2/control`" version_release_new="`sed -ne 's/^Version: \(.*\)/\1/p' $2/control`"
name_ver_rel_new="`sed -n -e 's/^Package: \(.*\)/\1/p' $2/control`-`sed -n -e 's/^Version: \(.*\)/\1/p' $2/control`" name_ver_rel_new="`sed -n -e 's/^Package: \(.*\)/\1/p' $2/control`-`sed -n -e 's/^Version: \(.*\)/\1/p' $2/control`"
set_regex set_regex
cat $1/control | trim_release_old > $1/control.fixed trim_release_old < $1/control > $1/control.fixed
mv $1/control.fixed $1/control mv $1/control.fixed $1/control
cat $2/control | trim_release_new > $2/control.fixed trim_release_new < $2/control > $2/control.fixed
mv $2/control.fixed $2/control mv $2/control.fixed $2/control
} }

View File

@ -55,7 +55,7 @@ filter_disasm()
s/[0-9a-f]\+ </</ s/[0-9a-f]\+ </</
s/^<\(.*\)>:/\1:/ s/^<\(.*\)>:/\1:/
s/<\(.*\)+0x[0-9a-f]\+>/<\1 + ofs>/ s/<\(.*\)+0x[0-9a-f]\+>/<\1 + ofs>/
' '
} }
filter_xenefi() { filter_xenefi() {
@ -318,6 +318,13 @@ check_compressed_file()
xz -d new/$file.xz & xz -d new/$file.xz &
wait wait
;; ;;
zst)
mv old/$file{,.zst}
mv new/$file{,.zst}
zstd -d old/$file.zst &
zstd -d new/$file.zst &
wait
;;
esac esac
ftype=`/usr/bin/file old/$file | sed 's@^[^:]\+:[[:blank:]]*@@'` ftype=`/usr/bin/file old/$file | sed 's@^[^:]\+:[[:blank:]]*@@'`
case $ftype in case $ftype in
@ -414,7 +421,7 @@ normalize_file()
*.dvi) *.dvi)
filter_generic dvi filter_generic dvi
;; ;;
*png) *.png)
# Try to remove timestamps, only if convert from ImageMagick is installed # Try to remove timestamps, only if convert from ImageMagick is installed
if [[ $(type -p convert) ]]; then if [[ $(type -p convert) ]]; then
filter_generic png filter_generic png
@ -599,7 +606,7 @@ normalize_file()
*.ps) *.ps)
filter_generic ps filter_generic ps
;; ;;
*pdf) *.pdf)
filter_generic pdf filter_generic pdf
;; ;;
*/linuxrc.config) */linuxrc.config)
@ -858,7 +865,7 @@ check_single_file()
compare_archive "${file}" 'archive_squashfs' compare_archive "${file}" 'archive_squashfs'
return $? return $?
;; ;;
*.tar|*.tar.bz2|*.tar.gz|*.tgz|*.tbz2) *.tar|*.tar.bz2|*.tar.gz|*.tgz|*.tbz2|*.tar.zst)
compare_archive "${file}" 'archive_tar' compare_archive "${file}" 'archive_tar'
return $? return $?
;; ;;
@ -866,30 +873,36 @@ check_single_file()
compare_archive "${file}" 'archive_zip' compare_archive "${file}" 'archive_zip'
return $? return $?
;; ;;
*.bz2) *.bz2)
bunzip2 -c old/$file > old/${file/.bz2/} bunzip2 -c old/$file > old/${file/.bz2/}
bunzip2 -c new/$file > new/${file/.bz2/} bunzip2 -c new/$file > new/${file/.bz2/}
check_single_file ${file/.bz2/} check_single_file ${file/.bz2/}
return $? return $?
;; ;;
*.gz) *.gz)
gunzip -c old/$file > old/${file/.gz/} gunzip -c old/$file > old/${file/.gz/}
gunzip -c new/$file > new/${file/.gz/} gunzip -c new/$file > new/${file/.gz/}
check_single_file ${file/.gz/} check_single_file ${file/.gz/}
return $? return $?
;; ;;
*.rpm) *.zst)
$self_script -a old/$file new/$file zstd -dc old/$file > old/${file/.zst/}
return $? zstd -dc new/$file > new/${file/.zst/}
;; check_single_file ${file/.zst/}
return $?
;;
*.rpm)
$self_script -a old/$file new/$file
return $?
;;
esac esac
ftype=`/usr/bin/file "old/$file" | sed -e 's@^[^:]\+:[[:blank:]]*@@' -e 's@[[:blank:]]*$@@'` ftype=`/usr/bin/file "old/$file" | sed -e 's@^[^:]\+:[[:blank:]]*@@' -e 's@[[:blank:]]*$@@'`
case $ftype in case $ftype in
PE32\ executable*Mono\/\.Net\ assembly*) PE32\ executable*Mono\/\.Net\ assembly*)
wprint "PE32 Mono/.Net assembly: $file" wprint "PE32 Mono/.Net assembly: $file"
if [ -x /usr/bin/monodis ] ; then if [ -x /usr/bin/monodis ] ; then
monodis "old/$file" 2>/dev/null|sed -e 's/GUID = {.*}/GUID = { 42 }/;'> ${file1} monodis "old/$file" 2>/dev/null|sed -e 's/GUID = {.*}/GUID = { 42 }/;'> ${file1}
monodis "new/$file" 2>/dev/null|sed -e 's/GUID = {.*}/GUID = { 42 }/;'> ${file2} monodis "new/$file" 2>/dev/null|sed -e 's/GUID = {.*}/GUID = { 42 }/;'> ${file2}
if ! cmp -s "${file1}" "${file2}"; then if ! cmp -s "${file1}" "${file2}"; then
wprint "$file differs ($ftype)" wprint "$file differs ($ftype)"
@ -909,207 +922,184 @@ check_single_file()
set?id\ ELF*[LM]SB\ shared\ object*|\ set?id\ ELF*[LM]SB\ shared\ object*|\
ELF*[LM]SB\ pie\ executable*|\ ELF*[LM]SB\ pie\ executable*|\
set?id\ ELF*[LM]SB\ pie\ executable*) set?id\ ELF*[LM]SB\ pie\ executable*)
diff --speed-large-files --unified \ local sections=($(
--label "old $file (disasm)" \ $OBJDUMP -s new/$file |
--label "new $file (disasm)" \
<( $OBJDUMP -d --no-show-raw-insn old/$file |
filter_disasm |
sed -e "s,old/,," ;
echo "${PIPESTATUS[@]}" > $file1
) \
<( $OBJDUMP -d --no-show-raw-insn new/$file |
filter_disasm |
sed -e "s,new/,," ;
echo "${PIPESTATUS[@]}" > $file2
) > $dfile
ret=$?
failed=
read i < ${file1}
pipestatus=( $i )
objdump_failed="${pipestatus[0]}"
i=0
while test $i -lt ${#pipestatus[@]}
do
if test "${pipestatus[$i]}" != "0"
then
wprint "ELF: pipe command #$i failed with ${pipestatus[$i]} for old/$file"
failed='failed'
fi
: $(( i++ ))
done
read i < ${file2}
pipestatus=( $i )
objdump_failed="${objdump_failed}${pipestatus[0]}"
i=0
while test $i -lt ${#pipestatus[@]}
do
if test "${pipestatus[$i]}" != "0"
then
wprint "ELF: pipe command #$i failed with ${pipestatus[$i]} for new/$file"
failed='failed'
fi
: $(( i++ ))
done
if test "${objdump_failed}" != "00" || test -n "${failed}"
then
# objdump had no idea how to handle it
if diff_two_files; then
return 0
fi
return 1
fi
elfdiff=
if test "$ret" != "0"
then
wprint "$file differs in assembler output"
$buildcompare_head $dfile
elfdiff='elfdiff'
fi
sections="$(
$OBJDUMP -s new/$file |
sed -n --regexp-extended -e ' sed -n --regexp-extended -e '
/Contents of section .*:/ { /Contents of section .*:/ {
s,.* (.*):,\1,g s,.* (.*):,-j \1,g
/\.build-id/d /\.build-id/d
/\.gnu_debuglink/d /\.gnu_debuglink/d
/\.gnu_debugdata/d /\.gnu_debugdata/d
p p
} }
' '))
)" ($OBJDUMP -s ${sections[@]} old/$file |
for section in $sections sed -e "s,old/,," ; echo "${PIPESTATUS[@]}" > $file1 ) > old/$file.objdump &
do ($OBJDUMP -s ${sections[@]} new/$file |
diff --unified \ sed -e "s,new/,," ; echo "${PIPESTATUS[@]}" > $file2 ) > new/$file.objdump &
wait
read i < ${file1}
pipestatus=( $i )
objdump_failed="${pipestatus[0]}"
if [[ ${pipestatus[*]} =~ [1-9] ]]
then
wprint "ELF section: pipe command failed for old/$file"
elfdiff='failed'
fi
read i < ${file2}
pipestatus=( $i )
objdump_failed="${objdump_failed}${pipestatus[0]}"
if [[ ${pipestatus[*]} =~ [1-9] ]]
then
wprint "ELF section: pipe command failed for new/$file"
elfdiff='failed'
fi
if test -z "${elfdiff}"
then
diff --speed-large-files --unified \
--label "old $file (objdump)" \ --label "old $file (objdump)" \
--label "new $file (objdump)" \ --label "new $file (objdump)" \
<( $OBJDUMP -s -j $section old/$file | old/$file.objdump new/$file.objdump > $dfile
sed -e "s,^old/,," ;
echo "${PIPESTATUS[@]}" > $file1) \
<( $OBJDUMP -s -j $section new/$file |
sed -e "s,^new/,," ;
echo "${PIPESTATUS[@]}" > $file2
) > $dfile
ret=$? ret=$?
failed=
read i < ${file1}
pipestatus=( $i )
objdump_failed="${pipestatus[0]}"
i=0
while test $i -lt ${#pipestatus[@]}
do
if test "${pipestatus[$i]}" != "0"
then
wprint "ELF section: pipe command #$i failed with ${pipestatus[$i]} for old/$file"
failed='failed'
fi
: $(( i++ ))
done
read i < ${file2}
pipestatus=( $i )
objdump_failed="${objdump_failed}${pipestatus[0]}"
i=0
while test $i -lt ${#pipestatus[@]}
do
if test "${pipestatus[$i]}" != "0"
then
wprint "ELF section: pipe command #$i failed with ${pipestatus[$i]} for new/$file"
failed='failed'
fi
: $(( i++ ))
done
if test -n "${failed}"
then
elfdiff='elfdiff'
break
fi
if test "$ret" != "0" if test "$ret" != "0"
then then
wprint "$file differs in ELF section $section" wprint "$file differs in ELF sections"
$buildcompare_head $dfile $buildcompare_head $dfile
elfdiff='elfdiff' elfdiff='elfdiff'
else
watchdog_touch
fi fi
done fi
if test -n "$elfdiff"; then if test -z "$elfdiff"
then
rm old/$file.objdump new/$file.objdump &
return 0
fi
watchdog_touch
elfdiff=
($OBJDUMP -d --no-show-raw-insn old/$file | filter_disasm |
sed -e "s,^old/[^:]\+,," ; echo "${PIPESTATUS[@]}" > $file1 ) > old/$file.objdump &
($OBJDUMP -d --no-show-raw-insn new/$file | filter_disasm |
sed -e "s,^new/[^:]\+,," ; echo "${PIPESTATUS[@]}" > $file2 ) > new/$file.objdump &
wait
read i < ${file1}
pipestatus=( $i )
objdump_failed="${objdump_failed}${pipestatus[0]}"
if [[ ${pipestatus[*]} =~ [1-9] ]]
then
wprint "ELF disassembly: pipe command failed for old/$file"
elfdiff='failed'
fi
read i < ${file2}
pipestatus=( $i )
objdump_failed="${objdump_failed}${pipestatus[0]}"
if [[ ${pipestatus[*]} =~ [1-9] ]]
then
wprint "ELF disassembly: pipe command failed for new/$file"
elfdiff='failed'
fi
if test ${objdump_failed} -gt 0 || test -n "${elfdiff}"
then
# objdump had no idea how to handle it
rm old/$file.objdump new/$file.objdump &
if diff_two_files; then
return 0
fi
return 1 return 1
fi fi
elfdiff=
diff --speed-large-files --unified \
--label "old $file (disasm)" \
--label "new $file (disasm)" \
old/$file.objdump new/$file.objdump > $dfile
ret=$?
rm old/$file.objdump new/$file.objdump &
if test "$ret" != "0"
then
wprint "$file differs in assembler output"
$buildcompare_head $dfile
elfdiff='elfdiff'
else
watchdog_touch
fi
if test -n "$elfdiff"
then
return 1
fi
;;
*ASCII*|*text*)
if ! cmp -s "old/$file" "new/$file" ; then
wprint "$file differs ($ftype)"
diff -u "old/$file" "new/$file" | $buildcompare_head
return 1
fi
;;
directory|setuid\ directory|setuid,\ directory|sticky,\ directory)
# tar might package directories - ignore them here
return 0 return 0
;; ;;
*ASCII*|*text*) bzip2\ compressed\ data*)
if ! cmp -s "old/$file" "new/$file"; then if ! check_compressed_file "$file" "bz2" ; then
wprint "$file differs ($ftype)" return 1
diff -u "old/$file" "new/$file" | $buildcompare_head fi
return 1 ;;
fi gzip\ compressed\ data*)
;; if ! check_compressed_file "$file" "gzip" ; then
directory|setuid\ directory|setuid,\ directory|sticky,\ directory) return 1
# tar might package directories - ignore them here fi
return 0 ;;
;; XZ\ compressed\ data*)
bzip2\ compressed\ data*) if ! check_compressed_file "$file" "xz" ; then
if ! check_compressed_file "$file" "bz2"; then return 1
return 1 fi
fi ;;
;; Zstandard\ compressed\ data*)
gzip\ compressed\ data*) if ! check_compressed_file "$file" "zst" ; then
if ! check_compressed_file "$file" "gzip"; then return 1
return 1 fi
fi ;;
;;
XZ\ compressed\ data*)
if ! check_compressed_file "$file" "xz"; then
return 1
fi
;;
Zip\ archive\ data,*) Zip\ archive\ data,*)
if ! compare_archive "${file}" 'archive_zip' ; then if ! compare_archive "${file}" 'archive_zip' ; then
return 1 return 1
fi fi
;; ;;
POSIX\ tar\ archive) POSIX\ tar\ archive)
mv old/$file{,.tar} mv old/$file{,.tar}
mv new/$file{,.tar} mv new/$file{,.tar}
if ! check_single_file ${file}.tar; then if ! check_single_file ${file}.tar; then
return 1 return 1
fi fi
;; ;;
cpio\ archive) cpio\ archive)
mv old/$file{,.cpio} mv old/$file{,.cpio}
mv new/$file{,.cpio} mv new/$file{,.cpio}
if ! check_single_file ${file}.cpio; then if ! check_single_file ${file}.cpio; then
return 1 return 1
fi fi
;; ;;
Squashfs\ filesystem,*) Squashfs\ filesystem,*)
wprint "$file ($ftype)" wprint "$file ($ftype)"
mv old/$file{,.squashfs} mv old/$file{,.squashfs}
mv new/$file{,.squashfs} mv new/$file{,.squashfs}
if ! check_single_file ${file}.squashfs; then if ! check_single_file ${file}.squashfs; then
return 1 return 1
fi fi
;; ;;
broken\ symbolic\ link\ to\ *|symbolic\ link\ to\ *) broken\ symbolic\ link\ to\ *|symbolic\ link\ to\ *)
readlink "old/$file" > $file1 readlink "old/$file" > $file1
readlink "new/$file" > $file2 readlink "new/$file" > $file2
if ! diff -u $file1 $file2; then if ! diff -u $file1 $file2; then
wprint "symlink target for $file differs" wprint "symlink target for $file differs"
return 1 return 1
fi fi
;; ;;
block\ special\ *) block\ special\ *)
;; ;;
character\ special\ *) character\ special\ *)
;; ;;
*) *)
if ! diff_two_files; then if ! diff_two_files; then
return 1 return 1
fi fi
;; ;;
esac esac
return 0 return 0
} }
@ -1211,8 +1201,9 @@ case $oldpkg in
esac esac
wprint "Extracting packages" wprint "Extracting packages"
unpackage $oldpkg $dir/old unpackage $oldpkg $dir/old &
unpackage $newpkg $dir/new unpackage $newpkg $dir/new &
wait
case $oldpkg in case $oldpkg in
*.deb|*.ipk) *.deb|*.ipk)
@ -1241,12 +1232,12 @@ fi
# preserve cmp_rpm_meta result for check_all runs # preserve cmp_rpm_meta result for check_all runs
ret=$RES ret=$RES
for file in "${files[@]}"; do for file in "${files[@]}"; do
if ! check_single_file "$file"; then if ! check_single_file "$file"; then
ret=1 ret=1
if test -z "$check_all"; then if test -z "$check_all"; then
break break
fi fi
fi fi
done done
if [ "$PROC_MOUNTED" -eq "1" ]; then if [ "$PROC_MOUNTED" -eq "1" ]; then
@ -1255,7 +1246,7 @@ if [ "$PROC_MOUNTED" -eq "1" ]; then
fi fi
if test "$ret" = 0; then if test "$ret" = 0; then
echo "Package content is identical" echo "Package content is identical"
fi fi
exit $ret exit $ret
# vim: tw=666 ts=2 shiftwidth=2 et # vim: tw=666 ts=2 shiftwidth=2 et

View File

@ -14,6 +14,11 @@
CMPSCRIPT=${0%/*}/pkg-diff.sh CMPSCRIPT=${0%/*}/pkg-diff.sh
SCMPSCRIPT=${0%/*}/srpm-check.sh SCMPSCRIPT=${0%/*}/srpm-check.sh
declare -a exit_code
# exit_code[0]='' # binaries_differ
# exit_code[1]='' # rpmlint_differs
# exit_code[2]='' # appdata_differs
# exit_code[3]='' # srcrpm_differs
file1=`mktemp` file1=`mktemp`
file2=`mktemp` file2=`mktemp`
_x() { _x() {
@ -21,6 +26,31 @@ _x() {
} }
trap _x EXIT trap _x EXIT
# #
remove_check_time_report() {
local f=$1
awk '
BEGIN {
ctr_seen=0;
}
/Check time report .*:$/ {
ctr_seen=1;
next;
}
/TOTAL[[:blank:]]+[0-9]/ {
if (ctr_seen == 1) {
ctr_seen=0;
next;
}
}
{
if (ctr_seen == 1) {
next;
}
print $0;
}
' < "${f}"
}
#
check_all= check_all=
if test "$1" = "-a" if test "$1" = "-a"
then then
@ -65,7 +95,13 @@ if test ! -f "$nsrpm"; then
fi fi
echo "compare $osrpm $nsrpm" echo "compare $osrpm $nsrpm"
bash $SCMPSCRIPT "$osrpm" "$nsrpm" || exit 1 if bash $SCMPSCRIPT "$osrpm" "$nsrpm"
then
: src.rpm identical
else
test -z "${check_all}" && exit 1
exit_code[3]='srcrpm_differs'
fi
# technically we should not all exclude all -32bit but filter for different archs, # technically we should not all exclude all -32bit but filter for different archs,
# like done with -x86 # like done with -x86
@ -96,7 +132,6 @@ NEWRPMS=($( sort --field-separator=/ --key=` sed -n '1s@[^/]@@gp' ${file2} | wc
ver_rel1=$(rpm -qp --nodigest --nosignature --qf "%{VERSION}-%{RELEASE}" "${OLDRPMS[0]}"|sed -e 's/\./\\./g') ver_rel1=$(rpm -qp --nodigest --nosignature --qf "%{VERSION}-%{RELEASE}" "${OLDRPMS[0]}"|sed -e 's/\./\\./g')
ver_rel2=$(rpm -qp --nodigest --nosignature --qf "%{VERSION}-%{RELEASE}" "${NEWRPMS[0]}"|sed -e 's/\./\\./g') ver_rel2=$(rpm -qp --nodigest --nosignature --qf "%{VERSION}-%{RELEASE}" "${NEWRPMS[0]}"|sed -e 's/\./\\./g')
SUCCESS=1
rpmqp='rpm -qp --qf %{NAME} --nodigest --nosignature ' rpmqp='rpm -qp --qf %{NAME} --nodigest --nosignature '
for opac in ${OLDRPMS[*]}; do for opac in ${OLDRPMS[*]}; do
npac=${NEWRPMS[0]} npac=${NEWRPMS[0]}
@ -113,7 +148,7 @@ for opac in ${OLDRPMS[*]}; do
echo "skipping -debuginfo package" echo "skipping -debuginfo package"
;; ;;
*) *)
bash $CMPSCRIPT $check_all "$opac" "$npac" || SUCCESS=0 bash $CMPSCRIPT $check_all "$opac" "$npac" || exit_code[0]='binaries_differ'
;; ;;
esac esac
done done
@ -123,28 +158,38 @@ if [ -n "${NEWRPMS[0]}" ]; then
exit 1 exit 1
fi fi
OTHERDIR=
# Compare rpmlint.log files # Compare rpmlint.log files
if test -d /home/abuild/rpmbuild/OTHER; then if test -d /home/abuild/rpmbuild/OTHER; then
OTHERDIR=/home/abuild/rpmbuild/OTHER OTHERDIR=/home/abuild/rpmbuild/OTHER
elif test -d /usr/src/packages/OTHER; then elif test -d /usr/src/packages/OTHER; then
OTHERDIR=/usr/src/packages/OTHER OTHERDIR=/usr/src/packages/OTHER
else else
echo "no OTHERDIR" for newdir in $NEWDIRS
OTHERDIR= do
test -f "${newdir}/rpmlint.log" || continue
OTHERDIR="${newdir}"
break
done
test -n "$OTHERDIR" || echo "no OTHERDIR"
fi fi
if test -n "$OTHERDIR"; then if test -n "$OTHERDIR"; then
if test -e $OLDDIR/rpmlint.log -a -e $OTHERDIR/rpmlint.log; then old_log=$OLDDIR/rpmlint.log
echo "comparing $OLDDIR/rpmlint.log and $OTHERDIR/rpmlint.log" new_log=$OTHERDIR/rpmlint.log
if test -e ${old_log} && test -e ${new_log} ; then
echo "comparing ${old_log} and ${new_log}"
# Remove --time-report from rpmlint
# Sort the files first since the order of messages is not deterministic # Sort the files first since the order of messages is not deterministic
# Remove release from files # Remove release from files
sort -u $OLDDIR/rpmlint.log|sed -e "s,$ver_rel1,@VERSION@-@RELEASE@,g" -e "s|/tmp/rpmlint\..*spec|.spec|g" > $file1 remove_check_time_report ${old_log}|sort -u|sed -e "s,$ver_rel1,@VERSION@-@RELEASE@,g" -e "s|/tmp/rpmlint\..*spec|.spec|g" > $file1
sort -u $OTHERDIR/rpmlint.log|sed -e "s,$ver_rel2,@VERSION@-@RELEASE@,g" -e "s|/tmp/rpmlint\..*spec|.spec|g" > $file2 remove_check_time_report ${new_log}|sort -u|sed -e "s,$ver_rel2,@VERSION@-@RELEASE@,g" -e "s|/tmp/rpmlint\..*spec|.spec|g" > $file2
# Remove odd warning about not-hardlinked files # Remove odd warning about not-hardlinked files
# Remove odd warning about data and time, it comes and goes # Remove odd warning about data and time, it comes and goes
# Remove warning about python mtime mismatch, a republish will not help # Remove warning about python mtime mismatch, a republish will not help
# Remove odd warning about filenames, they contain VERSION-RELEASE # Remove odd warning about filenames, they contain VERSION-RELEASE
# Remove durations from progress reports # Remove durations from progress reports
# Remove odd output about number of checks and packages
sed -i -e " sed -i -e "
/: W: files-duplicate /d /: W: files-duplicate /d
/: W: file-contains-date-and-time /d /: W: file-contains-date-and-time /d
@ -152,37 +197,46 @@ if test -n "$OTHERDIR"; then
/: W: filename-too-long-for-joliet /d /: W: filename-too-long-for-joliet /d
/: I: \(filelist-initialization\|check-completed\) /s| [0-9]\+\.[0-9] s| x.x s| /: I: \(filelist-initialization\|check-completed\) /s| [0-9]\+\.[0-9] s| x.x s|
s/; has taken [0-9]\+\.[0-9] s/; has taken x.x s/ s/; has taken [0-9]\+\.[0-9] s/; has taken x.x s/
/^checks: [0-9]\+, packages: [0-9]\+/d
" $file1 $file2 " $file1 $file2
if ! cmp -s $file1 $file2; then if ! cmp -s $file1 $file2; then
echo "rpmlint.log files differ:" echo "rpmlint.log files differ:"
diff -u $file1 $file2 |head -n 20 diff -u $file1 $file2 |head -n 20
SUCCESS=0 exit_code[1]='rpmlint_differs'
fi fi
rm $file1 $file2 rm $file1 $file2
elif test -e $OTHERDIR/rpmlint.log; then else
echo "rpmlint.log is new" if test -e "${new_log}"
SUCCESS=0 then
exit_code[1]='rpmlint_new'
echo "rpmlint.log is new"
elif test -e "${old_log}"
then
exit_code[1]='rpmlint_old'
echo "rpmlint.log disappeared"
else
echo "No rpmlint.log available"
fi
fi fi
appdatas=$(cd $OTHERDIR && find . -name "*-appdata.xml") appdatas=$(cd $OTHERDIR && find . -name "*-appdata.xml")
for xml in $appdatas; do for xml in $appdatas; do
# compare appstream data # compare appstream data
if test -e $OLDDIR/$xml -a -e $OTHERDIR/$xml; then if test -e $OLDDIR/$xml && test -e $OTHERDIR/$xml; then
file1=$OLDDIR/$xml file1=$OLDDIR/$xml
file2=$OTHERDIR/$xml file2=$OTHERDIR/$xml
if ! cmp -s $file1 $file2; then if ! cmp -s $file1 $file2; then
echo "$xml files differ:" echo "$xml files differ:"
diff -u0 $file1 $file2 |head -n 20 diff -u0 $file1 $file2 |head -n 20
SUCCESS=0 exit_code[2]='appdata_differs'
fi fi
elif test -e $OTHERDIR/$xml; then elif test -e $OTHERDIR/$xml; then
echo "$xml is new" echo "$xml is new"
SUCCESS=0 exit_code[2]='appdata_new'
fi fi
done done
fi fi
if test -n "${exit_code[*]}"; then
if test $SUCCESS -eq 0; then
exit 1 exit 1
fi fi
echo 'compare validated build as identical !' echo 'compare validated build as identical !'

View File

@ -1,10 +1,11 @@
#!/bin/bash #!/bin/bash
# #
# Copyright (c) 2009, 2010 SUSE Linux Product GmbH, Germany. # Copyright (c) 2009, 2010 SUSE Linux Product GmbH, Germany.
# Copyright (c) 2022 SUSE LLC
# Licensed under GPL v2, see COPYING file for details. # Licensed under GPL v2, see COPYING file for details.
# #
# Written by Michael Matz and Stephan Coolo # Written by Michael Matz and Stephan Kulow
# Enhanced by Andreas Jaeger # Enhanced by Andreas Jaeger and Dirk Müller
# Compare two source RPMs # Compare two source RPMs
@ -18,21 +19,16 @@ case $1 in
esac esac
if test "$#" != 2; then if test "$#" != 2; then
echo "usage: $0 [-a|--check-all] old.rpm new.rpm" echo "usage: $0 [-a|--check-all] old.rpm new.rpm"
exit 1 exit 1
fi fi
source $FUNCTIONS source $FUNCTIONS
oldrpm=`readlink -f $1` oldrpm=$(readlink -f $1)
newrpm=`readlink -f $2` newrpm=$(readlink -f $2)
rename_script= rename_script=
# Get version-release from first RPM and keep for rpmlint check
# Remember to quote the "." for future regexes
ver_rel_old=$(rpm -qp --nodigest --nosignature --qf "%{RELEASE}" "${oldrpm}"|sed -e 's/\./\\./g')
ver_rel_new=$(rpm -qp --nodigest --nosignature --qf "%{RELEASE}" "${newrpm}"|sed -e 's/\./\\./g')
# For source RPMs, we can just check the metadata in the spec file # For source RPMs, we can just check the metadata in the spec file
# if those are not the same, the source RPM has changed and therefore # if those are not the same, the source RPM has changed and therefore
# the resulting files are needed. # the resulting files are needed.
@ -59,41 +55,38 @@ esac
# Now check that only the spec file has a changed release number and # Now check that only the spec file has a changed release number and
# nothing else # nothing else
dir=`mktemp -d` dir=$(mktemp -d)
unpackage $oldrpm $dir/old unpackage $oldrpm $dir/old &
unpackage $newrpm $dir/new unpackage $newrpm $dir/new &
cd $dir cd $dir
wait
check_single_file() check_single_file()
{ {
local file=$1 local file=$1
case $file in case $file in
*.spec) *.spec)
sed -i -e 's,^Release:.*$,Release: @RELEASE@,' old/$file sed -i -e 's,^Release:.*$,Release: @RELEASE@,' old/$file
sed -i -e 's,^Release:.*$,Release: @RELEASE@,' new/$file sed -i -e 's,^Release:.*$,Release: @RELEASE@,' new/$file
if ! cmp -s old/$file new/$file; then diff --speed-large-files -su0 old/$file new/$file | head -n 20
echo "$file differs (spec file)" return "${PIPESTATUS[0]}"
diff -u old/$file new/$file | head -n 20 ;;
return 1
fi
return 0
;;
*) *)
echo "$file differs" echo "$file differs"
# Nothing else should be changed # Nothing else should be changed
;; ;;
esac esac
return 1 return 1
} }
ret=0 ret=0
for file in "${files[@]}"; do for file in "${files[@]}"; do
if ! check_single_file $file; then if ! check_single_file $file; then
ret=1 ret=1
if test -z "$check_all"; then if test -z "$check_all"; then
break break
fi fi
fi fi
done done
rm -rf $dir rm -rf $dir