Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4)

Side by Side Diff: tools/valgrind-webrtc/webrtc_tests.sh

Issue 2531573003: Make Valgrind memcheck work in swarming. (Closed)
Patch Set: Add more suppressions. Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « tools/valgrind-webrtc/memcheck/suppressions.txt ('k') | webrtc/build/mb_config.pyl » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/bin/bash 1 #!/bin/bash
2 2
3 # Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. 3 # Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
4 # 4 #
5 # Use of this source code is governed by a BSD-style license 5 # Use of this source code is governed by a BSD-style license
6 # that can be found in the LICENSE file in the root of the source 6 # that can be found in the LICENSE file in the root of the source
7 # tree. An additional intellectual property rights grant can be found 7 # tree. An additional intellectual property rights grant can be found
8 # in the file PATENTS. All contributing project authors may 8 # in the file PATENTS. All contributing project authors may
9 # be found in the AUTHORS file in the root of the source tree. 9 # be found in the AUTHORS file in the root of the source tree.
10 10
11 # Set up some paths and re-direct the arguments to webrtc_tests.py 11 # Set up some paths and re-direct the arguments to webrtc_tests.py
12 12
13 # This script is a copy of the chrome_tests.sh wrapper script with the following 13 # This script is a copy of the chrome_tests.sh wrapper script with the following
14 # changes: 14 # changes:
15 # - The locate_valgrind.sh of Chromium's Valgrind scripts dir is used to locate 15 # - The locate_valgrind.sh of Chromium's Valgrind scripts dir is used to locate
16 # the Valgrind framework install. 16 # the Valgrind framework install. If it fails a fallback path is used instead
17 # (../../chromium/src/third_party/valgrind/linux_x64) and a warning message
18 # is showed by |show_locate_valgrind_failed_warning|.
17 # - webrtc_tests.py is invoked instead of chrome_tests.py. 19 # - webrtc_tests.py is invoked instead of chrome_tests.py.
18 # - Chromium's Valgrind scripts directory is added to the PYTHONPATH to make it 20 # - Chromium's Valgrind scripts directory is added to the PYTHONPATH to make it
19 # possible to execute the Python scripts properly. 21 # possible to execute the Python scripts properly.
20 22
21 export THISDIR=`dirname $0` 23 export THISDIR=`dirname $0`
22 ARGV_COPY="$@" 24 ARGV_COPY="$@"
23 25
24 # We need to set CHROME_VALGRIND iff using Memcheck: 26 # We need to set CHROME_VALGRIND iff using Memcheck:
25 # tools/valgrind-webrtc/webrtc_tests.sh --tool memcheck 27 # tools/valgrind-webrtc/webrtc_tests.sh --tool memcheck
26 # or 28 # or
(...skipping 22 matching lines...) Expand all
49 51
50 # For WebRTC, we'll use the locate_valgrind.sh script in Chromium's Valgrind 52 # For WebRTC, we'll use the locate_valgrind.sh script in Chromium's Valgrind
51 # scripts dir to locate the Valgrind framework install 53 # scripts dir to locate the Valgrind framework install
52 CHROME_VALGRIND_SCRIPTS=$THISDIR/../valgrind 54 CHROME_VALGRIND_SCRIPTS=$THISDIR/../valgrind
53 55
54 if [ "$NEEDS_VALGRIND" == "1" ] 56 if [ "$NEEDS_VALGRIND" == "1" ]
55 then 57 then
56 CHROME_VALGRIND=`sh $CHROME_VALGRIND_SCRIPTS/locate_valgrind.sh` 58 CHROME_VALGRIND=`sh $CHROME_VALGRIND_SCRIPTS/locate_valgrind.sh`
57 if [ "$CHROME_VALGRIND" = "" ] 59 if [ "$CHROME_VALGRIND" = "" ]
58 then 60 then
59 # locate_valgrind.sh failed 61 CHROME_VALGRIND=../../chromium/src/third_party/valgrind/linux_x64
60 exit 1 62 echo
63 echo "-------------------- WARNING ------------------------"
64 echo "locate_valgrind.sh failed."
65 echo "Using $CHROME_VALGRIND as a fallback location."
66 echo "This might be because:"
67 echo "1) This is a swarming bot"
68 echo "2) You haven't set up the valgrind binaries correctly."
69 echo "In this case, please make sure you have followed the instructions at"
70 echo "http://www.chromium.org/developers/how-tos/using-valgrind/get-valgrind "
71 echo "Notice: In the .gclient file, you need to add this for the 'src'"
72 echo "solution since our directory structure is different from Chromium's:"
73 echo "\"custom_deps\": {"
74 echo " \"src/chromium/src/third_party/valgrind\":"
75 echo " \"https://chromium.googlesource.com/chromium/deps/valgrind/binar ies\","
76 echo "},"
77 echo "-----------------------------------------------------"
78 echo
61 fi 79 fi
62 echo "Using valgrind binaries from ${CHROME_VALGRIND}" 80 echo "Using valgrind binaries from ${CHROME_VALGRIND}"
63 81
64 PATH="${CHROME_VALGRIND}/bin:$PATH" 82 PATH="${CHROME_VALGRIND}/bin:$PATH"
65 # We need to set these variables to override default lib paths hard-coded into 83 # We need to set these variables to override default lib paths hard-coded into
66 # Valgrind binary. 84 # Valgrind binary.
67 export VALGRIND_LIB="$CHROME_VALGRIND/lib/valgrind" 85 export VALGRIND_LIB="$CHROME_VALGRIND/lib/valgrind"
68 export VALGRIND_LIB_INNER="$CHROME_VALGRIND/lib/valgrind" 86 export VALGRIND_LIB_INNER="$CHROME_VALGRIND/lib/valgrind"
69 87
70 # Clean up some /tmp directories that might be stale due to interrupted 88 # Clean up some /tmp directories that might be stale due to interrupted
71 # chrome_tests.py execution. 89 # chrome_tests.py execution.
72 # FYI: 90 # FYI:
73 # -mtime +1 <- only print files modified more than 24h ago, 91 # -mtime +1 <- only print files modified more than 24h ago,
74 # -print0/-0 are needed to handle possible newlines in the filenames. 92 # -print0/-0 are needed to handle possible newlines in the filenames.
75 echo "Cleanup /tmp from Valgrind stuff" 93 echo "Cleanup /tmp from Valgrind stuff"
76 find /tmp -maxdepth 1 \(\ 94 find /tmp -maxdepth 1 \(\
77 -name "vgdb-pipe-*" -or -name "vg_logs_*" -or -name "valgrind.*" \ 95 -name "vgdb-pipe-*" -or -name "vg_logs_*" -or -name "valgrind.*" \
78 \) -mtime +1 -print0 | xargs -0 rm -rf 96 \) -mtime +1 -print0 | xargs -0 rm -rf
79 fi 97 fi
80 98
81 # Add Chrome's Valgrind scripts dir to the PYTHON_PATH since it contains 99 # Add Chrome's Valgrind scripts dir to the PYTHON_PATH since it contains
82 # the scripts that are needed for this script to run 100 # the scripts that are needed for this script to run
83 PYTHONPATH=$THISDIR/../python/google:$CHROME_VALGRIND_SCRIPTS python \ 101 PYTHONPATH=$THISDIR/../python/google:$CHROME_VALGRIND_SCRIPTS python \
84 "$THISDIR/webrtc_tests.py" $ARGV_COPY 102 "$THISDIR/webrtc_tests.py" $ARGV_COPY
OLDNEW
« no previous file with comments | « tools/valgrind-webrtc/memcheck/suppressions.txt ('k') | webrtc/build/mb_config.pyl » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698