poky/scripts/test-reexec
Richard Purdie ffae400179 meta/lib+scripts: Convert to SPDX license headers
This adds SPDX license headers in place of the wide assortment of things
currently in our script headers. We default to GPL-2.0-only except for the
oeqa code where it was clearly submitted and marked as MIT on the most part
or some scripts which had the "or later" GPL versioning.

The patch also drops other obsolete bits of file headers where they were
encoountered such as editor modelines, obsolete maintainer information or
the phrase "All rights reserved" which is now obsolete and not required in
copyright headers (in this case its actually confusing for licensing as all
rights were not reserved).

More work is needed for OE-Core but this takes care of the bulk of the scripts
and meta/lib directories.

The top level LICENSE files are tweaked to match the new structure and the
SPDX naming.

(From OE-Core rev: f8c9c511b5f1b7dbd45b77f345cb6c048ae6763e)

Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2019-05-09 16:31:55 +01:00

111 lines
3.0 KiB
Bash
Executable File

#!/bin/bash
# Test Script for task re-execution
#
# Copyright 2012 Intel Corporation
#
# SPDX-License-Identifier: GPL-2.0-or-later
#
# DESCRIPTION
# This script is intended to address issues for re-execution of
# tasks. The test results are saved in ./reexeclogs. Force build
# logs are saved with prefix "force". Build failure logs are saved with
# prefix "failed". Log files with prefix "initial" are used to save
# initial build logs for each recipe. Log files with prefix "clean" are
# used to save logs of clean task after testing for a recipe is finished.
#
targets=`bitbake -s | cut -d " " -f 1`
LOGS=./reexeclogs
mkdir -p $LOGS
# Clear sstate files for specified recipe
function clearsstate {
target=$1
sstate_dir=`bitbake $target -e | grep "^SSTATE_DIR=" | cut -d "\"" -f 2`
sstate_pkgspec=`bitbake $target -e | grep "^SSTATE_PKGSPEC=" | cut -d "\"" -f 2`
sstasks=`bitbake $target -e | grep "^SSTATETASKS=" | cut -d "\"" -f 2`
for sstask in $sstasks
do
sstask=${sstask:3}
case $sstask in
populate_sysroot) sstask="populate-sysroot"
;;
populate_lic) sstask="populate-lic"
;;
package_write_ipk) sstask="deploy-ipk"
;;
package_write_deb) sstask="deploy-deb"
;;
package_write_rpm) sstask="deploy-rpm"
;;
package) sstask="package"
;;
deploy) sstask="deploy"
;;
*)
;;
esac
echo "Removing ${sstate_dir}/${sstate_pkgspec}*_${sstask}.tgz* for $target"
rm -rf ${sstate_dir}/${sstate_pkgspec}*_${sstask}.tgz*
done
}
# Function to re-execute specified task of recipe
function testit {
target=$1
task=$2
task=`echo $task | sed 's/_setscene//'`
if [ -f $LOGS/force.$target.$task ]; then
return
fi
case $task in
clean|build|cleansstate|cleanall|package|cleansstate2|package_write|package_write_ipk|package_write_rpm|package_write_deb|fetch|populate_lic) return;;
fetchall|devshell|buildall|listtasks|checkuri|checkuriall) return;;
esac
echo "Attempting target $target, task $task"
echo "Initial build"
bitbake $target -c cleansstate > $LOGS/initial.$target.$task
bitbake $target >> $LOGS/initial.$target.$task
clearsstate $target >> $LOGS/initial.$target.$task
echo "Re-execution build"
bitbake $target -c $task -f > $LOGS/force.$target.$task
if [ "$?" != 0 ]; then
echo "FAILURE for $target $task"
cp $LOGS/force.$target.$task $LOGS/failed.$target.$task
bitbake $target -c clean > $LOGS/clean.$target.$task
else
bitbake $target >> $LOGS/force.$target.$task
if [ "$?" != 0 ]; then
echo "FAILURE2 for $target $task"
cp $LOGS/force.$target.$task $LOGS/failed.$target.$task
bitbake $target -c clean > $LOGS/clean.$target.$task
fi
fi
echo "Done"
}
# Go through the recipe list and these recipes' task list
# Then re-execute them
for target in $targets; do
# Remove log messages from bitbake output
case $target in
Summary*|WARNING*|Loading*|Loaded*|Package*|=====*) continue;;
esac
tasks=`bitbake $target -c listtasks | grep ^do_ | sed s/do_//`
for task in $tasks; do
testit $target $task
done
done