summaryrefslogtreecommitdiff
path: root/.travis
diff options
context:
space:
mode:
authorThomas Graf <tgraf@noironetworks.com>2014-08-25 14:51:00 +0200
committerBen Pfaff <blp@nicira.com>2014-08-25 08:48:05 -0700
commit826bc7b61345a5d164a2551606bef1a038e39cab (patch)
tree51e82fb750332fff827cd3e3724b7c062b4b23ce /.travis
parent5c476ea3bb2557328f33720f974d8f863fe69cfc (diff)
downloadopenvswitch-826bc7b61345a5d164a2551606bef1a038e39cab.tar.gz
build: Add travis continuous integration support
This enables the use of travis-ci via github. Linking any ovs github repo to travis-ci [0] will automatically lead to a build and testsuite run being triggered for each new commit or pull requests against the repo. The introduction of any warnings will cause the build to fail as both gcc and clang are invoked with -Werror. The build matrix currently includes: * --disable-ssl * --with-linux=linux-3.14.7 * --with-dpdk=1.7.0 Each of these builds is performed with gcc+sparse and clang. The testsuite is only run for the --with-linux build to keep the total build time on an acceptable level. Build failures are reported to the author and commiter by email, through the travis-ci web UI, and in the github pull request. A full build report example can be found here [1] [0] http://travis-ci.org/ [1] https://travis-ci.org/tgraf/ovs/builds/33485228 Signed-off-by: Thomas Graf <tgraf@noironetworks.com> Signed-off-by: Ben Pfaff <blp@nicira.com>
Diffstat (limited to '.travis')
-rwxr-xr-x.travis/build.sh55
-rwxr-xr-x.travis/prepare.sh8
2 files changed, 63 insertions, 0 deletions
diff --git a/.travis/build.sh b/.travis/build.sh
new file mode 100755
index 000000000..e9bb9e26f
--- /dev/null
+++ b/.travis/build.sh
@@ -0,0 +1,55 @@
+#!/bin/bash
+
+KERNELSRC=""
+
+function install_kernel()
+{
+ wget https://www.kernel.org/pub/linux/kernel/v3.x/linux-3.14.7.tar.gz \
+ && tar xzvf linux-3.14.7.tar.gz > /dev/null \
+ && cd linux-3.14.7 \
+ && make allmodconfig \
+ && make net/openvswitch/ \
+ && KERNELSRC=$(pwd) \
+ && echo "Installed kernel source in $(pwd)" \
+ && cd ..
+
+ [ $? != 0 ] && exit 1
+}
+
+function install_dpdk()
+{
+ wget http://www.dpdk.org/browse/dpdk/snapshot/dpdk-1.7.0.tar.gz \
+ && tar xzvf dpdk-1.7.0.tar.gz > /dev/null \
+ && cd dpdk-1.7.0 \
+ && find ./ -type f | xargs sed -i 's/max-inline-insns-single=100/max-inline-insns-single=400/' \
+ && make config CC=gcc T=x86_64-native-linuxapp-gcc \
+ && make CC=gcc RTE_KERNELDIR=$KERNELSRC \
+ && sudo make install CC=gcc T=x86_64-native-linuxapp-gcc RTE_KERNELDIR=$KERNELSRC \
+ && echo "Installed DPDK source in $(pwd)" \
+ && cd ..
+
+ [ $? != 0 ] && exit 1
+}
+
+function configure_ovs()
+{
+ ./boot.sh && ./configure $*
+ [ $? != 0 ] && exit 1
+}
+
+if [ "$KERNEL" ] || [ "$DPDK" ]; then
+ install_kernel
+fi
+
+[ "$DPDK" ] && install_dpdk
+
+configure_ovs $*
+
+if [ $CC = "clang" ]; then
+ make CFLAGS="-Werror -Wno-error=unused-command-line-argument"
+else
+ make CFLAGS="-Werror" C=1 || exit 1
+ [ "$TESTSUITE" ] && make check
+fi
+
+exit 0
diff --git a/.travis/prepare.sh b/.travis/prepare.sh
new file mode 100755
index 000000000..6b5df0029
--- /dev/null
+++ b/.travis/prepare.sh
@@ -0,0 +1,8 @@
+#!/bin/bash
+
+sudo apt-get update -qq
+sudo apt-get install -qq libssl-dev llvm-dev
+
+wget https://www.kernel.org/pub/software/devel/sparse/dist/sparse-0.5.0.tar.gz
+tar -xzvf sparse-0.5.0.tar.gz
+cd sparse-0.5.0 && make && sudo make install PREFIX=/usr && cd ..