summaryrefslogtreecommitdiffstats
path: root/tools/valgrind/shard-all-tests.sh
blob: c496fb9147c54ebeea7c56c1e3954dedd12fe72a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#!/bin/sh

# Copyright (c) 2009 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

# Script to run tests under tools/valgrind/chrome_tests.sh
# in a loop looking for rare/flaky valgrind warnings, and
# generate suppressions for them, to be later filed as bugs
# and added to our suppressions file.
#
# FIXME: Layout tests are a bit funny - they have their own
# sharding control, and should probably be tweaked to obey
# GTEST_SHARD_INDEX/GTEST_TOTAL_SHARDS like the rest,
# but they take days and days to run, so they are left
# out of this script.

if test ! -d chrome
then
  echo "Please run from parent directory of chrome and build directories"
  exit 1
fi

if test "$1" = ""
then
  echo "Usage: shard-all-tests.sh [BUILDTYPE=Release] target [target ...]"
  echo "Example: shard-all-tests.sh ui_tests"
  exit 1
fi

set -x
set -e

# Regexp to match any valgrind error
PATTERN="ERROR SUMMARY: [^0]|are definitely|uninitialised|Unhandled exception|\
Invalid read|Invalid write|Invalid free|Source and desti|Mismatched free|\
unaddressable byte|vex x86|impossible|Assertion|INTERNAL ERROR|finish writing|OUCH"

BUILDTYPE=Debug
case "$1" in
  BUILDTYPE=Debug) BUILDTYPE=Debug ; shift ;;
  BUILDTYPE=Release) BUILDTYPE=Release ; shift ;;
  BUILDTYPE=*) echo "unknown build type $1"; exit 1;;
  *) ;;
esac
TESTS="$@"

what_to_build() {
  echo $TESTS | tr ' ' '\012' | grep -v layout_tests || true
  echo $TESTS | grep -q layout_tests && echo test_shell || true
  echo $TESTS | grep -q ui_tests && echo chrome || true
}

# Wrap xcodebuild to take same arguments as our make, more or less
xcodemake() {
  for target in $*
  do
    case $target in
    chrome)         xcodebuild -configuration $BUILDTYPE -project chrome/chrome.xcodeproj -target chrome ;;
    ui_tests)       xcodebuild -configuration $BUILDTYPE -project chrome/chrome.xcodeproj -target ui_tests ;;
    base_unittests) xcodebuild -configuration $BUILDTYPE -project base/base.xcodeproj     -target base_unittests ;;
    net_unittests)  xcodebuild -configuration $BUILDTYPE -project net/net.xcodeproj       -target net_unittests ;;
    *) echo "dunno how to build $target yet"; exit 1 ;;
    esac
  done
}

build_tests() {
  buildtype=$1
  shift

  OS=`uname`
  case $OS in
  Linux)
    # Lame way to autodetect whether 'make' or 'hammer' is in use
    if test -d out
    then
      make -j4 BUILDTYPE=$1 $@
    else
      # fixme: obey buildtype
      hammer $@
    fi
    ;;
  Darwin)
    xcodemake $@
    ;;
  *) echo "don't know how to build on os $OS"
    ;;
  esac
}

TESTS_BUILDABLE=`what_to_build`
echo building $TESTS_BUILDABLE
build_tests $BUILDTYPE $TESTS_BUILDABLE

# Divide each test suite up into 100 shards, as first step
# in tracking down exact source of errors.
export GTEST_TOTAL_SHARDS=100

rm -rf *.vlog *.vtmp || true

iter=0
while test $iter -lt 1000
do
  for testname in $TESTS
  do
    export GTEST_SHARD_INDEX=0
    while test $GTEST_SHARD_INDEX -lt $GTEST_TOTAL_SHARDS
    do
      i=$GTEST_SHARD_INDEX
      sh tools/valgrind/chrome_tests.sh -b xcodebuild/$BUILDTYPE -t ${testname} --tool_flags="--nocleanup_on_exit" > ${testname}_$i.vlog 2>&1 || true
      mv valgrind.tmp ${testname}_$i.vtmp
      GTEST_SHARD_INDEX=`expr $GTEST_SHARD_INDEX + 1`
    done
  done

  # Save any interesting log files from this iteration
  # Also show interesting lines on stdout, to make tail -f more interesting
  if egrep "$PATTERN" *.vlog
  then
    mkdir -p shard-results/$iter
    mv `egrep -l "$PATTERN" *.vlog` shard-results/$iter
    # ideally we'd only save the .vtmp's corresponding to the .vlogs we saved
    mv *.vtmp shard-results/$iter
  fi

  rm -rf *.vlog *.vtmp || true
  iter=`expr $iter + 1`
done