// Copyright 2013 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.

#ifndef BASE_TEST_LAUNCHER_TEST_RESULT_H_
#define BASE_TEST_LAUNCHER_TEST_RESULT_H_

#include <string>

#include "base/time/time.h"

namespace base {

// Structure containing result of a single test.
struct TestResult {
  enum Status {
    TEST_UNKNOWN,          // Status not set.
    TEST_SUCCESS,          // Test passed.
    TEST_FAILURE,          // Assertion failure (think EXPECT_TRUE, not DCHECK).
    TEST_FAILURE_ON_EXIT,  // Test passed but executable exit code was non-zero.
    TEST_TIMEOUT,          // Test timed out and was killed.
    TEST_CRASH,            // Test crashed (includes CHECK/DCHECK failures).
    TEST_SKIPPED,          // Test skipped (not run at all).
  };

  TestResult();
  ~TestResult();

  // Returns the test status as string (e.g. for display).
  std::string StatusAsString() const;

  // Returns the test name (e.g. "B" for "A.B").
  std::string GetTestName() const;

  // Returns the test case name (e.g. "A" for "A.B").
  std::string GetTestCaseName() const;

  // Returns true if the test has completed (i.e. the test binary exited
  // normally, possibly with an exit code indicating failure, but didn't crash
  // or time out in the middle of the test).
  bool completed() const {
    return status == TEST_SUCCESS ||
        status == TEST_FAILURE ||
        status == TEST_FAILURE_ON_EXIT;
  }

  // Full name of the test (e.g. "A.B").
  std::string full_name;

  Status status;

  // Time it took to run the test.
  base::TimeDelta elapsed_time;

  // Output of just this test (optional).
  std::string output_snippet;
};

}  // namespace base

#endif  // BASE_TEST_LAUNCHER_TEST_RESULT_H_