#!/usr/bin/env python # Copyright 2015 The PDFium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import glob import os import subprocess import sys def os_name(): if sys.platform.startswith('linux'): return 'linux' if sys.platform.startswith('win'): return 'win' if sys.platform.startswith('darwin'): return 'mac' raise Exception('Confused, can not determine OS, aborting.') def RunCommand(cmd): try: subprocess.check_call(cmd) return None except subprocess.CalledProcessError as e: return e # Adjust Dr. Memory wrapper to have separate log directory for each test # for better error reporting. def DrMemoryWrapper(wrapper, pdf_name): if not wrapper: return [] # convert string to list cmd_to_run = wrapper.split() # Do nothing if using default log directory. if cmd_to_run.count("-logdir") == 0: return cmd_to_run # Usually, we pass "-logdir" "foo\bar\spam path" args to Dr. Memory. # To group reports per test, we want to put the reports for each test into a # separate directory. This code can be simplified when we have # https://github.com/DynamoRIO/drmemory/issues/684 fixed. logdir_idx = cmd_to_run.index("-logdir") old_logdir = cmd_to_run[logdir_idx + 1] wrapper_pid = str(os.getpid()) # We are using the same pid of the same python process, so append the number # of entries in the logdir at the end of wrapper_pid to avoid conflict. wrapper_pid += "_%d" % len(glob.glob(old_logdir + "\\*")) cmd_to_run[logdir_idx + 1] += "\\testcase.%s.logs" % wrapper_pid os.makedirs(cmd_to_run[logdir_idx + 1]) f = open(old_logdir + "\\testcase.%s.name" % wrapper_pid, "w") print >>f, pdf_name + ".pdf" f.close() return cmd_to_run class DirectoryFinder: '''A class for finding directories and paths under either a standalone checkout or a chromium checkout of PDFium.''' def __init__(self, build_location): # |build_location| is typically "out/Debug" or "out/Release". # Expect |my_dir| to be .../pdfium/testing/tools. self.my_dir = os.path.dirname(os.path.realpath(__file__)) self.testing_dir = os.path.dirname(self.my_dir) if (os.path.basename(self.my_dir) != 'tools' or os.path.basename(self.testing_dir) != 'testing'): raise Exception('Confused, can not find pdfium root directory, aborting.') self.pdfium_dir = os.path.dirname(self.testing_dir) # Find path to build directory. This depends on whether this is a # standalone build vs. a build as part of a chromium checkout. For # standalone, we expect a path like .../pdfium/out/Debug, but for # chromium, we expect a path like .../src/out/Debug two levels # higher (to skip over the third_party/pdfium path component under # which chromium sticks pdfium). self.base_dir = self.pdfium_dir one_up_dir = os.path.dirname(self.base_dir) two_up_dir = os.path.dirname(one_up_dir) if (os.path.basename(two_up_dir) == 'src' and os.path.basename(one_up_dir) == 'third_party'): self.base_dir = two_up_dir self.build_dir = os.path.join(self.base_dir, build_location) self.os_name = os_name() def ExecutablePath(self, name): '''Finds compiled binaries under the build path.''' result = os.path.join(self.build_dir, name) if self.os_name == 'win': result = result + '.exe' return result def ScriptPath(self, name): '''Finds other scripts in the same directory as this one.''' return os.path.join(self.my_dir, name) def WorkingDir(self, other_components=''): '''Places generated files under the build directory, not source dir.''' result = os.path.join(self.build_dir, 'gen', 'pdfium') if other_components: result = os.path.join(result, other_components) return result def TestingDir(self, other_components=''): '''Finds test files somewhere under the testing directory.''' result = self.testing_dir if other_components: result = os.path.join(result, other_components) return result