From f40ea986e9cb04985213488a91a69e2236ba2fd2 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Tue, 26 May 2009 19:12:00 +0000 Subject: [PATCH] add a somewhat hackish script for automatic dependency testing SVN-Revision: 16097 --- scripts/deptest.sh | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100755 scripts/deptest.sh diff --git a/scripts/deptest.sh b/scripts/deptest.sh new file mode 100755 index 0000000000..43757026cc --- /dev/null +++ b/scripts/deptest.sh @@ -0,0 +1,43 @@ +DIR="$PWD/tmp/deptest" +STAMP_DIR="$DIR/stamp" +BUILD_DIR="$DIR/build" +STAGING_DIR="$DIR/staging" +STAGING_DIR_HOST="$DIR/staging_host" +STAGING_DIR_HOST_TMPL="$DIR/staging_host_tmpl" +LOG_DIR="$DIR/logs" + +mkdir -p "$STAMP_DIR" "$BUILD_DIR" "$LOG_DIR" + +[ -d "$STAGING_DIR_HOST_TMPL" ] || { + rm -rf staging_dir/host + make tools/install || { + echo "make tools/install failed, please check" + exit 1 + } + cp -al staging_dir/host "$STAGING_DIR_HOST_TMPL" +} + +for pkg in `cat tmp/.packagedeps | grep CONFIG_PACKAGE | grep -v curdir | sed -e 's,.*[/=]\s*,,' | sort -u`; do + SELECTED= + for conf in `grep CONFIG_PACKAGE tmp/.packagedeps | grep " $pkg\$" | sed -e 's,package-$(\(CONFIG_PACKAGE_.*\)).*,\1,'`; do + grep "$conf=" .config > /dev/null && SELECTED=1 + done + [ -f "$STAMP_DIR/$pkg-done" ] && continue + [ -n "$SELECTED" ] || { + echo "Package $pkg is not selected" + continue + } + echo "Testing package $pkg..." + rm -rf "$STAGING_DIR" + mkdir -p "$STAGING_DIR" + rm -rf "$STAGING_DIR_HOST" + cp -al "$STAGING_DIR_HOST_TMPL" "$STAGING_DIR_HOST" + make package/$pkg/compile \ + BUILD_DIR="$BUILD_DIR" \ + STAGING_DIR="$STAGING_DIR" \ + STAGING_DIR_HOST="$STAGING_DIR_HOST" \ + V=99 >"$LOG_DIR/$(basename $pkg).log" 2>&1 \ + && touch "$STAMP_DIR/$pkg-done" || { + echo "Building package $pkg failed!" + } +done -- 2.30.2