From 957e7d7130b616b0e77d01cefcd6acca10914a4e Mon Sep 17 00:00:00 2001 From: Niels de Vos Date: Thu, 15 Nov 2018 13:31:40 +0100 Subject: Add job for running glusterfs regressions with TSAN This is a copy of the job+script that are used for ASAN testing. Currently combining ASAN+TSAN in a single test-run is not an option, both libraries conflict with each other. Change-Id: Ie649a8f88be3e2aae949824903c490a64ea93e6e See-also: https://review.gluster.org/21641 # --enable-tsan option Updates: #543 --- build-gluster-org/jobs/tsan.yml | 41 +++++++++++++++++++++++++++++++++++++++ build-gluster-org/scripts/tsan.sh | 30 ++++++++++++++++++++++++++++ 2 files changed, 71 insertions(+) create mode 100644 build-gluster-org/jobs/tsan.yml create mode 100644 build-gluster-org/scripts/tsan.sh diff --git a/build-gluster-org/jobs/tsan.yml b/build-gluster-org/jobs/tsan.yml new file mode 100644 index 0000000..2125f79 --- /dev/null +++ b/build-gluster-org/jobs/tsan.yml @@ -0,0 +1,41 @@ +- job: + name: tsan + node: fedora + description: Threaded data corruption detector job for glusterfs + project-type: freestyle + concurrent: true + + scm: + - glusterfs + + properties: + - discard-after-x: + x: 30 + - one-build-per-node + + triggers: + - timed: "H 15 * * *" + + builders: + - shell: !include-raw: ../scripts/tsan.sh + + publishers: + - post-tasks: + - matches: + - log-text: Build was aborted + script: !include-raw: ../scripts/regression-abort.sh + - gluster-logs + + parameters: + - string: + default: refs/heads/master + description: 'For review 12345 and patch set 6, this will be refs/changes/45/12345/6. Default: Tip of master' + name: GERRIT_REFSPEC + - string: + default: master + description: 'Name of the branch you want to build from. We usually build from master' + name: GERRIT_BRANCH + + wrappers: + - timestamps + diff --git a/build-gluster-org/scripts/tsan.sh b/build-gluster-org/scripts/tsan.sh new file mode 100644 index 0000000..5570bcb --- /dev/null +++ b/build-gluster-org/scripts/tsan.sh @@ -0,0 +1,30 @@ +#!/bin/bash +nproc=$(getconf _NPROCESSORS_ONLN) +SRC=$(pwd); +P=/build; + +sudo -E bash /opt/qa/cleanup.sh +# Clean up other Gluster dirs +sudo rm -rf /var/lib/glusterd/* /build/install /build/scratch >/dev/null 2>&1 +# Remove the many left over socket files in /var/run +sudo rm -f /var/run/????????????????????????????????.socket >/dev/null 2>&1 +# Remove GlusterFS log files from previous runs +sudo rm -rf /var/log/glusterfs/* /var/log/glusterfs/.cmd_log_history >/dev/null 2>&1 +JDIRS="/var/log/glusterfs /var/lib/glusterd /var/run/gluster /d /d/archived_builds /d/backends /d/build /d/logs /home/jenkins/root" +sudo mkdir -p $JDIRS +sudo chown jenkins:jenkins $JDIRS +chmod 755 $JDIRS + +set -e +./autogen.sh; +rm -rf $P/scratch; +mkdir -p $P/scratch; +cd $P/scratch; +rm -rf $P/install; +$SRC/configure --prefix=$P/install --with-mountutildir=$P/install/sbin \ + --with-initdir=$P/install/etc --localstatedir=/var \ + --enable-debug --enable-gnfs --silent --enable-tsan +make install -j ${nproc} +cd $SRC; +export TSAN_OPTIONS=log_path=/var/log/glusterfs/tsan-output.log +sudo -E bash /opt/qa/regression.sh -- cgit