summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-27 20:13:37 +0000
committermark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-27 20:13:37 +0000
commit1e12b665c85c2a826e9f4f9af8744e888619affc (patch)
treeb17080d6ba221bf763eee8bd043109d927d12e9d
parent17a8396f14051151059e95ce14b8a3e27b7c5882 (diff)
downloadchromium_src-1e12b665c85c2a826e9f4f9af8744e888619affc.zip
chromium_src-1e12b665c85c2a826e9f4f9af8744e888619affc.tar.gz
chromium_src-1e12b665c85c2a826e9f4f9af8744e888619affc.tar.bz2
Run dsymutil before valgrind (Mac)
Review URL: http://codereview.chromium.org/55030 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@12693 0039d316-1c4b-4281-b951-d872f2087c98
-rwxr-xr-xbuild/mac/strip_save_dsym2
-rwxr-xr-xtools/valgrind/valgrind_test.py63
2 files changed, 64 insertions, 1 deletions
diff --git a/build/mac/strip_save_dsym b/build/mac/strip_save_dsym
index a1d3ecd..0e54b93 100755
--- a/build/mac/strip_save_dsym
+++ b/build/mac/strip_save_dsym
@@ -216,7 +216,7 @@ def make_fake_dsym(macho, dsym):
"uuid_dict": uuid_dict,
}
info_contents = info_template % info_dict
- info_file = os.path.join(dsym, "Info.plist")
+ info_file = os.path.join(dsym, "Contents", "Info.plist")
info_fd = open(info_file, "w")
info_fd.write(info_contents)
info_fd.close()
diff --git a/tools/valgrind/valgrind_test.py b/tools/valgrind/valgrind_test.py
index f13ad8e..2a07755 100755
--- a/tools/valgrind/valgrind_test.py
+++ b/tools/valgrind/valgrind_test.py
@@ -14,6 +14,7 @@ import glob
import logging
import optparse
import os
+import re
import shutil
import stat
import sys
@@ -100,6 +101,10 @@ class Valgrind(object):
def Setup(self):
return self.ParseArgv()
+ def PrepareForTest(self):
+ """Perform necessary tasks prior to executing the test."""
+ pass
+
def ValgrindCommand(self):
"""Get the valgrind command to run."""
raise RuntimeError, "Never use Valgrind directly. Always subclass and " \
@@ -136,6 +141,8 @@ class Valgrind(object):
return True
def RunTestsAndAnalyze(self):
+ self.PrepareForTest()
+
self.Execute()
if self._generate_suppressions:
logging.info("Skipping analysis to let you look at the raw output...")
@@ -240,6 +247,62 @@ class ValgrindMac(Valgrind):
def __init__(self):
Valgrind.__init__(self)
+ def PrepareForTest(self):
+ """Runs dsymutil if needed.
+
+ Valgrind for Mac OS X requires that debugging information be in a .dSYM
+ bundle generated by dsymutil. It is not currently able to chase DWARF
+ data into .o files like gdb does, so executables without .dSYM bundles or
+ with the Chromium-specific "fake_dsym" bundles generated by
+ build/mac/strip_save_dsym won't give source file and line number
+ information in valgrind.
+
+ This function will run dsymutil if the .dSYM bundle is missing or if
+ it looks like a fake_dsym. A non-fake dsym that already exists is assumed
+ to be up-to-date.
+ """
+
+ test_command = self._args[0]
+ dsym_bundle = self._args[0] + '.dSYM'
+ dsym_file = os.path.join(dsym_bundle, 'Contents', 'Resources', 'DWARF',
+ os.path.basename(test_command))
+ dsym_info_plist = os.path.join(dsym_bundle, 'Contents', 'Info.plist')
+
+ needs_dsymutil = True
+ saved_test_command = None
+
+ if os.path.exists(dsym_file) and os.path.exists(dsym_info_plist):
+ # Look for the special fake_dsym tag in dsym_info_plist.
+ dsym_info_plist_contents = open(dsym_info_plist).read()
+
+ if not re.search('^\s*<key>fake_dsym</key>$', dsym_info_plist_contents,
+ re.MULTILINE):
+ # fake_dsym is not set, this is a real .dSYM bundle produced by
+ # dsymutil. dsymutil does not need to be run again.
+ needs_dsymutil = False
+ else:
+ # fake_dsym is set. dsym_file is a copy of the original test_command
+ # before it was stripped. Copy it back to test_command so that
+ # dsymutil has unstripped input to work with. Move the stripped
+ # test_command out of the way, it will be restored when this is
+ # done.
+ saved_test_command = test_command + '.stripped'
+ os.rename(test_command, saved_test_command)
+ shutil.copyfile(dsym_file, test_command)
+
+ if needs_dsymutil:
+ # Remove the .dSYM bundle if it exists.
+ shutil.rmtree(dsym_bundle, True)
+
+ dsymutil_command = ['dsymutil', test_command]
+
+ # dsymutil is crazy slow. Let it run for up to a half hour. I hope
+ # that's enough.
+ common.RunSubprocess(dsymutil_command, 30 * 60)
+
+ if saved_test_command:
+ os.rename(saved_test_command, test_command)
+
def ValgrindCommand(self):
"""Get the valgrind command to run."""
proc = ["valgrind", "--smc-check=all", "--leak-check=full",