# Copyright 2014 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.

import os

from profile_chrome import controllers_unittest
from profile_chrome import systrace_controller


class SystraceControllerTest(controllers_unittest.BaseControllerTest):
  def testGetCategories(self):
    categories = \
        systrace_controller.SystraceController.GetCategories(self.device)
    self.assertTrue(categories)
    assert 'gfx' in ' '.join(categories)

  def testTracing(self):
    categories = ['gfx', 'input', 'view']
    ring_buffer = False
    controller = systrace_controller.SystraceController(self.device,
                                                        categories,
                                                        ring_buffer)

    interval = 1
    try:
      controller.StartTracing(interval)
    finally:
      controller.StopTracing()
    result = controller.PullTrace()

    self.assertFalse(controller.IsTracingOn())
    try:
      with open(result) as f:
        self.assertTrue('CPU#' in f.read())
    finally:
      os.remove(result)