summaryrefslogtreecommitdiffstats
path: root/buildtest.sh
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2024-11-09 14:26:35 +0100
committerDaniel Baumann <daniel@debian.org>2024-11-09 14:26:35 +0100
commit47e4d7c791a050deb06e6c0fdfcac94a782a7cb9 (patch)
tree19edcac0f5dbda32bc329fa68773254fb2c488c3 /buildtest.sh
parentInitial commit. (diff)
downloadfrr-47e4d7c791a050deb06e6c0fdfcac94a782a7cb9.tar.xz
frr-47e4d7c791a050deb06e6c0fdfcac94a782a7cb9.zip
Adding upstream version 10.1.1.upstream/10.1.1
Signed-off-by: Daniel Baumann <daniel@debian.org>
Diffstat (limited to 'buildtest.sh')
-rwxr-xr-xbuildtest.sh89
1 files changed, 89 insertions, 0 deletions
diff --git a/buildtest.sh b/buildtest.sh
new file mode 100755
index 00000000..90ef60ee
--- /dev/null
+++ b/buildtest.sh
@@ -0,0 +1,89 @@
+#!/bin/bash
+# SPDX-License-Identifier: NONE
+# written 2012-2013 by David Lamparter, placed in Public Domain.
+#
+# builds some git commit of FRR in some different configurations
+# usage: buildtest.sh [commit [configurations...]]
+
+basecfg="--prefix=/usr --enable-user=frr --enable-group=frr --enable-vty-group=frr --enable-configfile-mask=0660 --enable-logfile-mask=0640 --enable-vtysh --sysconfdir=/etc --localstatedir=/var --libdir=/usr/lib64/frr --enable-rtadv --disable-static --enable-isisd --enable-multipath=0 --enable-pimd --enable-werror"
+
+configs_base="gcc|$basecfg"
+
+configs_ext="gcc|$basecfg --enable-opaque-lsa --enable-ospf-te --enable-ospfclient --enable-isis-topology"
+configs_snmp="gcc|$basecfg --enable-opaque-lsa --enable-ospf-te --enable-ospfclient --enable-isis-topology --enable-snmp"
+configs_clang="clang|$basecfg --enable-opaque-lsa --enable-ospf-te --enable-ospfclient --enable-isis-topology"
+configs_icc="icc|$basecfg --enable-opaque-lsa --enable-ospf-te --enable-ospfclient --enable-isis-topology"
+
+defconfigs="base ext"
+net-snmp-config --version &> /dev/null && defconfigs="$defconfigs snmp"
+clang --version &> /dev/null && defconfigs="$defconfigs clang"
+icc --version &> /dev/null && defconfigs="$defconfigs icc"
+
+echo "enabled configurations: $defconfigs"
+
+cc_gcc="CC=gcc; export CC"
+cc_clang="CC=clang; export CC"
+cc_icc="CC=icc; export CC"
+
+###############################
+
+errfunc() {
+ echo "something went wrong! check $TEMP"
+ exit 1
+}
+
+set -e
+trap errfunc ERR
+
+COMMITREF="$1"
+COMMITISH="`git rev-list --max-count=1 ${COMMITREF:-HEAD}`"
+TEMP="`mktemp -d -t frrbuild.XXXXXX`"
+BASE="`pwd`"
+CONFIGS="$2"
+MAKE="${MAKE:-make}"
+
+echo using temporary directory: $TEMP
+echo git commit used:
+git --no-pager log -n 1 --pretty=oneline "$COMMITISH"
+
+cd "$TEMP"
+git clone "$BASE" "source"
+cd "source"
+git checkout -b build "$COMMITISH"
+git clean -d -f -x
+sh bootstrap.sh
+
+cd ..
+
+echo -e "\n\n\n\n\033[33;1mmaking dist tarball\033[m"
+
+mkdir build_dist
+cd build_dist
+../source/configure
+${MAKE} distdir=sdist dist-gzip
+cd ..
+tar zxvf build_dist/sdist.tar.gz
+
+for cfg in ${CONFIGS:-$defconfigs}; do
+ echo -e "\n\n\n\n\033[33;1mbuilding configuration $cfg\033[m"
+ config="\${configs_$cfg}"
+ eval "config=$config"
+
+ cc="${config%%|*}"
+ args="${config#*|}"
+
+ ccset="\${cc_$cc}"
+ eval "ccset=$ccset"
+ eval "$ccset"
+
+ bdir="build_$cfg"
+ mkdir "$bdir"
+ cd "$bdir"
+ ../sdist/configure $args
+ ${MAKE} -j5
+ ${MAKE} check
+ ${MAKE} DESTDIR="$TEMP/inst_$cfg" install
+ cd ..
+done
+
+echo -e "\n\n\n\neverything seems ok. you may now\n\trm -rf $TEMP"