def testTime(self):
    actual_diff = []
    def func1():
      trace_begin("func1")
      start = time.time()
      time.sleep(0.25)
      end = time.time()
      actual_diff.append(end-start) # Pass via array because of Python scoping
      trace_end("func1")

    with self._test_trace():
      start_ts = time.time()
      trace_event.trace_begin('test')
      end_ts = time.time()
      trace_event.trace_end('test')
      trace_event.trace_flush()
      with open(self._log_path, 'r') as f:
        log_output = json.loads(f.read() + ']')
        self.assertEquals(len(log_output), 3)
        meta_data = log_output[0]
        open_data = log_output[1]
        close_data = log_output[2]
        self.assertEquals(meta_data['category'], 'process_argv')
        self.assertEquals(meta_data['name'], 'process_argv')
        self.assertTrue(meta_data['args']['argv'])
        self.assertEquals(meta_data['ph'], 'M')
        self.assertEquals(open_data['category'], 'python')
        self.assertEquals(open_data['name'], 'test')
        self.assertEquals(open_data['ph'], 'B')
        self.assertEquals(close_data['category'], 'python')
        self.assertEquals(close_data['name'], 'test')
        self.assertEquals(close_data['ph'], 'E')
        event_time_diff = close_data['ts'] - open_data['ts']
        recorded_time_diff = (end_ts - start_ts) * 1000000
        self.assertLess(math.fabs(event_time_diff - recorded_time_diff), 1000)
Example #2
0
    def testMultiprocessExceptionInChild(self):
        def bad_child():
            trace_event.trace_disable()

        with self._test_trace():
            p = multiprocessing.Pool(1)
            trace_event.trace_begin('parent')
            self.assertRaises(Exception, lambda: p.apply(bad_child, ()))
            p.close()
            p.terminate()
            p.join()
            trace_event.trace_end('parent')
            trace_event.trace_flush()
            with open(self._log_path, 'r') as f:
                log_output = json.loads(f.read() + ']')
                self.assertEquals(len(log_output), 3)
                meta_data = log_output[0]
                parent_open = log_output[1]
                parent_close = log_output[2]
                self.assertEquals(parent_open['category'], 'python')
                self.assertEquals(parent_open['name'], 'parent')
                self.assertEquals(parent_open['ph'], 'B')
                self.assertEquals(parent_close['category'], 'python')
                self.assertEquals(parent_close['name'], 'parent')
                self.assertEquals(parent_close['ph'], 'E')
  def testTime(self):
    actual_diff = []
    def func1():
      trace_begin("func1")
      start = time.time()
      time.sleep(0.25)
      end = time.time()
      actual_diff.append(end-start) # Pass via array because of Python scoping
      trace_end("func1")

    with self._test_trace():
      start_ts = time.time()
      trace_event.trace_begin('test')
      end_ts = time.time()
      trace_event.trace_end('test')
      trace_event.trace_flush()
      with open(self._log_path, 'r') as f:
        log_output = json.loads(f.read() + ']')
        self.assertEquals(len(log_output), 3)
        meta_data = log_output[0]
        open_data = log_output[1]
        close_data = log_output[2]
        self.assertEquals(meta_data['category'], 'process_argv')
        self.assertEquals(meta_data['name'], 'process_argv')
        self.assertTrue(meta_data['args']['argv'])
        self.assertEquals(meta_data['ph'], 'M')
        self.assertEquals(open_data['category'], 'python')
        self.assertEquals(open_data['name'], 'test')
        self.assertEquals(open_data['ph'], 'B')
        self.assertEquals(close_data['category'], 'python')
        self.assertEquals(close_data['name'], 'test')
        self.assertEquals(close_data['ph'], 'E')
        event_time_diff = close_data['ts'] - open_data['ts']
        recorded_time_diff = (end_ts - start_ts) * 1000000
        self.assertLess(math.fabs(event_time_diff - recorded_time_diff), 1000)
  def testMultiprocessExceptionInChild(self):
    def bad_child():
      trace_event.trace_disable()

    with self._test_trace():
      p = multiprocessing.Pool(1)
      trace_event.trace_begin('parent')
      self.assertRaises(Exception, lambda: p.apply(bad_child, ()))
      p.close()
      p.terminate()
      p.join()
      trace_event.trace_end('parent')
      trace_event.trace_flush()
      with open(self._log_path, 'r') as f:
        log_output = json.loads(f.read() + ']')
        self.assertEquals(len(log_output), 3)
        meta_data = log_output[0]
        parent_open = log_output[1]
        parent_close = log_output[2]
        self.assertEquals(parent_open['category'], 'python')
        self.assertEquals(parent_open['name'], 'parent')
        self.assertEquals(parent_open['ph'], 'B')
        self.assertEquals(parent_close['category'], 'python')
        self.assertEquals(parent_close['name'], 'parent')
        self.assertEquals(parent_close['ph'], 'E')
 def trace_if_enabled(test):
   try:
     if self._test_instance.trace_output:
       trace_event.trace_begin(test)
     yield
   finally:
     if self._test_instance.trace_output:
       trace_event.trace_end(test)
Example #6
0
    def traceFunction(frame, event, arg):
        del arg

        # Don't try to trace in subprocesses.
        if os.getpid() != tracing_pid:
            sys.settrace(None)
            return None

        # pylint: disable=unused-argument
        if event not in ("call", "return"):
            return None

        function_name = frame.f_code.co_name
        filename = frame.f_code.co_filename
        line_number = frame.f_lineno

        if _shouldTrace(frame, to_include, to_exclude, included, excluded):
            if event == "call":
                # This function is beginning; we save the thread name (if that hasn't
                # been done), record the Begin event, and return this function to be
                # used as the local trace function.

                thread_id = threading.current_thread().ident

                if thread_id not in saved_thread_ids:
                    thread_name = threading.current_thread().name

                    trace_event.trace_set_thread_name(thread_name)

                    saved_thread_ids.add(thread_id)

                arguments = _TraceArguments()
                # The function's argument values are stored in the frame's
                # |co_varnames| as the first |co_argcount| elements. (Following that
                # are local variables.)
                for idx in range(frame.f_code.co_argcount):
                    arg_name = frame.f_code.co_varnames[idx]
                    arguments.add(arg_name, frame.f_locals[arg_name])
                trace_event.trace_begin(
                    function_name,
                    arguments=arguments,
                    module=inspect.getmodule(frame).__name__,
                    filename=filename,
                    line_number=line_number)

                # Return this function, so it gets used as the "local trace function"
                # within this function's frame (and in particular, gets called for this
                # function's "return" event).
                return traceFunction

            if event == "return":
                trace_event.trace_end(function_name)
                return None
        return None
  def traceFunction(frame, event, arg):
    del arg

    # Don't try to trace in subprocesses.
    if os.getpid() != tracing_pid:
      sys.settrace(None)
      return None

    # pylint: disable=unused-argument
    if event not in ("call", "return"):
      return None

    function_name = frame.f_code.co_name
    filename = frame.f_code.co_filename
    line_number = frame.f_lineno

    if _shouldTrace(frame, to_include, to_exclude, included, excluded):
      if event == "call":
        # This function is beginning; we save the thread name (if that hasn't
        # been done), record the Begin event, and return this function to be
        # used as the local trace function.

        thread_id = threading.current_thread().ident

        if thread_id not in saved_thread_ids:
          thread_name = threading.current_thread().name

          trace_event.trace_set_thread_name(thread_name)

          saved_thread_ids.add(thread_id)

        arguments = _TraceArguments()
        # The function's argument values are stored in the frame's
        # |co_varnames| as the first |co_argcount| elements. (Following that
        # are local variables.)
        for idx in range(frame.f_code.co_argcount):
          arg_name = frame.f_code.co_varnames[idx]
          arguments.add(arg_name, frame.f_locals[arg_name])
        trace_event.trace_begin(function_name, arguments=arguments,
                                module=inspect.getmodule(frame).__name__,
                                filename=filename, line_number=line_number)

        # Return this function, so it gets used as the "local trace function"
        # within this function's frame (and in particular, gets called for this
        # function's "return" event).
        return traceFunction

      if event == "return":
        trace_event.trace_end(function_name)
        return None
Example #8
0
 def testTraceBegin(self):
     with self._test_trace():
         with open(self._log_path, 'r') as f:
             trace_event.trace_begin('test_event', this='that')
             trace_event.trace_flush()
             log_output = json.loads(f.read() + ']')
             self.assertEquals(len(log_output), 2)
             current_entry = log_output.pop(0)
             self.assertEquals(current_entry['category'], 'process_argv')
             self.assertEquals(current_entry['name'], 'process_argv')
             self.assertTrue(current_entry['args']['argv'])
             self.assertEquals(current_entry['ph'], 'M')
             current_entry = log_output.pop(0)
             self.assertEquals(current_entry['category'], 'python')
             self.assertEquals(current_entry['name'], 'test_event')
             self.assertEquals(current_entry['args']['this'], '\'that\'')
             self.assertEquals(current_entry['ph'], 'B')
 def testTraceBegin(self):
   with self._test_trace():
     with open(self._log_path, 'r') as f:
       trace_event.trace_begin('test_event', this='that')
       trace_event.trace_flush()
       log_output = json.loads(f.read() + ']')
       self.assertEquals(len(log_output), 2)
       current_entry = log_output.pop(0)
       self.assertEquals(current_entry['category'], 'process_argv')
       self.assertEquals(current_entry['name'], 'process_argv')
       self.assertTrue( current_entry['args']['argv'])
       self.assertEquals( current_entry['ph'], 'M')
       current_entry = log_output.pop(0)
       self.assertEquals(current_entry['category'], 'python')
       self.assertEquals(current_entry['name'], 'test_event')
       self.assertEquals(current_entry['args']['this'], '\'that\'')
       self.assertEquals(current_entry['ph'], 'B')
Example #10
0
    def disabled_testMultiprocess(self):
        def child_function():
            with trace_event.trace('child_event'):
                pass

        with self._test_trace():
            trace_event.trace_begin('parent_event')
            trace_event.trace_flush()
            p = multiprocessing.Process(target=child_function)
            p.start()
            self.assertTrue(hasattr(p, "_shimmed_by_trace_event"))
            p.join()
            trace_event.trace_end('parent_event')
            trace_event.trace_flush()
            with open(self._log_path, 'r') as f:
                log_output = json.loads(f.read() + ']')
                self.assertEquals(len(log_output), 5)
                meta_data = log_output[0]
                parent_open = log_output[1]
                child_open = log_output[2]
                child_close = log_output[3]
                parent_close = log_output[4]
                self.assertEquals(meta_data['category'], 'process_argv')
                self.assertEquals(meta_data['name'], 'process_argv')
                self.assertTrue(meta_data['args']['argv'])
                self.assertEquals(meta_data['ph'], 'M')

                self.assertEquals(parent_open['category'], 'python')
                self.assertEquals(parent_open['name'], 'parent_event')
                self.assertEquals(parent_open['ph'], 'B')

                self.assertEquals(child_open['category'], 'python')
                self.assertEquals(child_open['name'], 'child_event')
                self.assertEquals(child_open['ph'], 'B')

                self.assertEquals(child_close['category'], 'python')
                self.assertEquals(child_close['name'], 'child_event')
                self.assertEquals(child_close['ph'], 'E')

                self.assertEquals(parent_close['category'], 'python')
                self.assertEquals(parent_close['name'], 'parent_event')
                self.assertEquals(parent_close['ph'], 'E')
Example #11
0
  def testMultiprocess(self):
    def child_function():
      with trace_event.trace('child_event'):
        pass

    with self._test_trace():
      trace_event.trace_begin('parent_event')
      trace_event.trace_flush()
      p = multiprocessing.Process(target=child_function)
      p.start()
      self.assertTrue(hasattr(p, "_shimmed_by_trace_event"))
      p.join()
      trace_event.trace_end('parent_event')
      trace_event.trace_flush()
      with open(self._log_path, 'r') as f:
        log_output = json.loads(f.read() + ']')
        self.assertEquals(len(log_output), 5)
        meta_data = log_output[0]
        parent_open = log_output[1]
        child_open = log_output[2]
        child_close = log_output[3]
        parent_close = log_output[4]
        self.assertEquals(meta_data['category'], 'process_argv')
        self.assertEquals(meta_data['name'], 'process_argv')
        self.assertTrue(meta_data['args']['argv'])
        self.assertEquals(meta_data['ph'], 'M')

        self.assertEquals(parent_open['category'], 'python')
        self.assertEquals(parent_open['name'], 'parent_event')
        self.assertEquals(parent_open['ph'], 'B')

        self.assertEquals(child_open['category'], 'python')
        self.assertEquals(child_open['name'], 'child_event')
        self.assertEquals(child_open['ph'], 'B')

        self.assertEquals(child_close['category'], 'python')
        self.assertEquals(child_close['name'], 'child_event')
        self.assertEquals(child_close['ph'], 'E')

        self.assertEquals(parent_close['category'], 'python')
        self.assertEquals(parent_close['name'], 'parent_event')
        self.assertEquals(parent_close['ph'], 'E')
Example #12
0
    def testInterleavedCalls(self):
        with self._test_trace():
            trace_event.trace_begin('one')
            trace_event.trace_begin('two')
            trace_event.trace_end('one')
            trace_event.trace_end('two')
            trace_event.trace_flush()
            with open(self._log_path, 'r') as f:
                log_output = json.loads(f.read() + ']')
                self.assertEquals(len(log_output), 5)
                meta_data = log_output[0]
                one_open = log_output[1]
                two_open = log_output[2]
                two_close = log_output[4]
                one_close = log_output[3]
                self.assertEquals(meta_data['category'], 'process_argv')
                self.assertEquals(meta_data['name'], 'process_argv')
                self.assertTrue(meta_data['args']['argv'])
                self.assertEquals(meta_data['ph'], 'M')

                self.assertEquals(one_open['category'], 'python')
                self.assertEquals(one_open['name'], 'one')
                self.assertEquals(one_open['ph'], 'B')
                self.assertEquals(one_close['category'], 'python')
                self.assertEquals(one_close['name'], 'one')
                self.assertEquals(one_close['ph'], 'E')

                self.assertEquals(two_open['category'], 'python')
                self.assertEquals(two_open['name'], 'two')
                self.assertEquals(two_open['ph'], 'B')
                self.assertEquals(two_close['category'], 'python')
                self.assertEquals(two_close['name'], 'two')
                self.assertEquals(two_close['ph'], 'E')

                self.assertLessEqual(one_open['ts'], two_open['ts'])
                self.assertLessEqual(one_close['ts'], two_close['ts'])
Example #13
0
  def testInterleavedCalls(self):
    with self._test_trace():
      trace_event.trace_begin('one')
      trace_event.trace_begin('two')
      trace_event.trace_end('one')
      trace_event.trace_end('two')
      trace_event.trace_flush()
      with open(self._log_path, 'r') as f:
        log_output = json.loads(f.read() + ']')
        self.assertEquals(len(log_output), 5)
        meta_data = log_output[0]
        one_open = log_output[1]
        two_open = log_output[2]
        two_close = log_output[4]
        one_close = log_output[3]
        self.assertEquals(meta_data['category'], 'process_argv')
        self.assertEquals(meta_data['name'], 'process_argv')
        self.assertTrue(meta_data['args']['argv'])
        self.assertEquals(meta_data['ph'], 'M')

        self.assertEquals(one_open['category'], 'python')
        self.assertEquals(one_open['name'], 'one')
        self.assertEquals(one_open['ph'], 'B')
        self.assertEquals(one_close['category'], 'python')
        self.assertEquals(one_close['name'], 'one')
        self.assertEquals(one_close['ph'], 'E')

        self.assertEquals(two_open['category'], 'python')
        self.assertEquals(two_open['name'], 'two')
        self.assertEquals(two_open['ph'], 'B')
        self.assertEquals(two_close['category'], 'python')
        self.assertEquals(two_close['name'], 'two')
        self.assertEquals(two_close['ph'], 'E')

        self.assertLessEqual(one_open['ts'], two_open['ts'])
        self.assertLessEqual(one_close['ts'], two_close['ts'])