# -*- sh -*- # # Copyright © 2008-2010 Diego Elio Pettenò # Copyright © 2008-2010 Zac Medico # # Permission to use, copy, modify, and distribute this software for any # purpose with or without fee is hereby granted, provided that the above # copyright notice and this permission notice appear in all copies. # # THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SOFTWARE CONSORTIUM DISCLAIMS # ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES # OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL INTERNET SOFTWARE # CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL # DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR # PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS # ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS # SOFTWARE. if [[ -n ${BTI_ACCOUNT} ]]; then dent_me() { echo "$@" | bti ${TINDERBOX_PROXY:+--proxy "${TINDERBOX_PROXY}"} --host "${BTI_HOST}" --account "${BTI_ACCOUNT}" --password "${BTI_PASSWORD}" --background } else dent_me() { :; } fi pre_pkg_setup() { dent_me "${CATEGORY}/${PF} merge starting" register_die_hook tinderbox_failed register_success_hook tinderbox_success } tinderbox_stats() { if fgrep -q 'Called src_test' "${PORTAGE_LOG_FILE}"; then echo " tests failed" fi if fgrep -q 'Detected file collision' "${PORTAGE_LOG_FILE}"; then echo " #collisions" fi } if [[ -n "${TINDERBOX_ANALYSIS_ADDR}" ]]; then tinderbox_send_log() { tar -P -cf - "${PORTAGE_LOG_FILE}" | \ nc6 --send-only --hold-timeout=0 ${TINDERBOX_ANALYSIS_ADDR} \ >/dev/null } else tinderbox_send_log() { :; } fi tinderbox_success() { dent_me "${CATEGORY}/${PF} merge #succeded$(tinderbox_stats)" tinderbox_send_log } tinderbox_failed() { [[ ${EBUILD_PHASE} == test ]] && return 0 dent_me "${CATEGORY}/${PF} merge #failed$(tinderbox_stats)" SANDBOX_ON=0 sed -i -e "\$a =${CATEGORY}/${PF}" /etc/portage/package.mask/currentrun # check if this is an automake failure and if so, get the whole log inlined if fgrep -q "/temp/automake.out" "${PORTAGE_LOG_FILE}"; then cat "${T}"/automake.out fi tinderbox_send_log } tinderbox_if_file() { if [[ -s "${T}"/$2 ]]; then eqawarn "Tinderbox QA $1! $3" cat "${T}"/$2 eqawarn "Tinderbox QA $1 (end)! $3" fi } post_src_install() { rm -f "${T}"/tinderbox-*.log # scanelf -q -F "#s%F" -R -s '-__(|l|f)xstat' "${D}" > "${T}"/tinderbox-scanelf-stat64.log # if [[ -s "${T}"/tinderbox-scanelf-stat64.log ]]; then # ewarn "Tinderbox QA Warning! Missing largefile support" # cat "${T}"/tinderbox-scanelf-stat64.log >/dev/stderr # fi for symbol in adler32 BZ2_decompress jpeg_mem_init XML_Parse avcodec_init png_get_libpng_ver lt_dlopen GC_stdout; do scanelf -qRs +$symbol "${D}" >> "${T}"/tinderbox-scanelf-bundled.log done for symbol in tmpnam tmpnam_r tempnam gets sigstack getpw getwd mktemp; do scanelf -qRs -$symbol "${D}" >> "${T}"/tinderbox-scanelf-insecure.log done for symbolre in S_IS 'G[TD]K_'; do scanelf -qRgs "-^${symbolre}*" "${D}" >> "${T}"/tinderbox-scanelf-badsymbols.log done scanelf -R "${D}"/usr/share > "${T}"/tinderbox-share-elfs.log if has binchecks ${RESTRICT}; then scanelf -R "${D}" > "${T}"/tinderbox-elfs-bincheck.log fi find "${D}" \ \( -name '._*' -fprintf "${T}"/tinderbox-osx-forkfile.log "%P\n" \) , \ \( -perm /6000 -fprintf "${T}"/tinderbox-setXid-binaries.log "%#m %u:%g %P\n" \) , \ \( \( -path "${D}"usr/man/\* -or -path "${D}"usr/info/\* -or \ -path "${D}"usr/X11R6/\* -or \ -path "${D}"usr/locale/\* -or \ -path "${D}"usr/local/\* -or \ -path "${D}"var/lock\* -or \ -path "${D}"var/run/\* -or \ -path "${D}"dev/\* \ \) -fprintf "${T}"/tinderbox-invalid-directory.log "/%P\n" \) , \ \( -path "${D}"usr/lib/perl5/site_perl/\* \ -fprintf "${T}"/tinderbox-site-perl.log "/%P\n" \) , \ \( -path "${D}"usr/doc/\* -or \ \( -path "${D}"usr/share/doc/\* -type d \ -prune -not \( -name "${PF}" -or -name 'KDE4' -or -name 'HTML' \) \ \) \ -fprintf "${T}"/tinderbox-misplaced-doc.log "/%P\n" \) , \ \( -path "${D}"usr/share/locale/\* -name '*.mo' \ -fprintf "${T}"/tinderbox-locales.log "/%P\n" \) , \ \( \( -path "${D}"usr/lib\*/python\*/site-packages/\* -or \ -path "${D}"usr/lib\*/ruby\*/site_ruby/\* -or \ -path "${D}"usr/lib\*/perl5/\* -or \ -path "${D}"lib\*/security/\* \) -name '*.la' \ -fprintf "${T}"/tinderbox-pointless-la.log "/%P\n" \) if [[ -d "${D}"/usr/share/locale ]] && ! [[ -s "${T}"/tinderbox-locales.log ]]; then eqawarn "Tinderbox QA Warning: No locales installed (bug #264114)" fi tinderbox_if_file Warning tinderbox-scanelf-badsymbols.log "Bad undefined symbol (glibc-2.12, gtk+-2.20 errors)" tinderbox_if_file Warning tinderbox-scanelf-bundled.log "Possibly bundled libraries" tinderbox_if_file Warning tinderbox-invalid-directory.log "Invalid directories in image" tinderbox_if_file Warning tinderbox-osx-forkfile.log "OSX fork files found (._*)" tinderbox_if_file Warning tinderbox-share-elfs.log "ELF files in /usr/share" tinderbox_if_file Warning tinderbox-elfs-bincheck.log "ELF files in a binchecks-restricted package" tinderbox_if_file Warning tinderbox-pointless-la.log "Pointless libtool .la files found" tinderbox_if_file Warning tinderbox-site-perl.log "Perl files installed in site_dir" tinderbox_if_file Warning tinderbox-misplaced-doc.log "Misplaced documentation" tinderbox_if_file Notice tinderbox-scanelf-insecure.log "Insecure functions used" tinderbox_if_file Notice tinderbox-setXid-binaries.log "setXid files found" } make() { if [[ "${FUNCNAME[1]}" == "einstall" ]] ; then emake -j1 "$@" else eqawarn "Tinderbox QA Notice: 'make' called by ${FUNCNAME[1]}" emake "$@" fi } preserve_old_lib() { ewarn "Preserved libs are disabled in tinderbox. Shush, go away!" }