blob: 50204b5e755fba59f5e1c3f3e43f10ea14d86358 [file] [log] [blame]
// 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 <map>
#include <string>
#include <vector>
#include "base/threading/platform_thread.h"
#include "base/time/time.h"
#include "third_party/abseil-cpp/absl/types/optional.h"
namespace base {
// Structure contains result of a single EXPECT/ASSERT/SUCCESS/SKIP.
struct TestResultPart {
enum Type {
kSuccess, // SUCCESS
kNonFatalFailure, // EXPECT
kFatalFailure, // ASSERT
kSkip, // SKIP
};
Type type;
TestResultPart();
~TestResultPart();
TestResultPart(const TestResultPart& other);
TestResultPart(TestResultPart&& other);
TestResultPart& operator=(const TestResultPart& other);
TestResultPart& operator=(TestResultPart&& other);
// Convert type to string and back.
static bool TypeFromString(const std::string& str, Type* type);
std::string TypeAsString() const;
// Filename and line of EXPECT/ASSERT.
std::string file_name;
int line_number;
// Message without stacktrace, etc.
std::string summary;
// Complete message.
std::string message;
};
// Structure containing result of a single test.
struct TestResult {
enum Status {
TEST_UNKNOWN, // Status not set.
TEST_SUCCESS, // Test passed.
TEST_FAILURE, // Assertion failure (e.g. EXPECT_TRUE, not DCHECK).
TEST_FAILURE_ON_EXIT, // 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).
TEST_EXCESSIVE_OUTPUT, // Test exceeded output limit.
TEST_NOT_RUN, // Test has not yet been run.
};
TestResult();
~TestResult();
TestResult(const TestResult& other);
TestResult(TestResult&& other);
TestResult& operator=(const TestResult& other);
TestResult& operator=(TestResult&& other);
// 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;
// Add link in the xml output.
// See more in gtest_links.h.
void AddLink(const std::string& name, const std::string& url);
// 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 ||
status == TEST_EXCESSIVE_OUTPUT;
}
// Full name of the test (e.g. "A.B").
std::string full_name;
Status status;
// Start time of child test process, the field is optional the test could be
// NOT_RUN.
absl::optional<base::Time> timestamp;
// Thread id of the runner that launching the child process, which is also
// recorded in TestLauncherTracer.
absl::optional<base::PlatformThreadId> thread_id;
// The process num of child process launched it's recorded as event name in
// TestLauncherTracer.
// It's used instead of process id to distinguish processes that process id
// might be reused by OS.
absl::optional<int> process_num;
// Time it took to run the test.
base::TimeDelta elapsed_time;
// Output of just this test (optional).
std::string output_snippet;
// Information about failed expectations.
std::vector<TestResultPart> test_result_parts;
// The key is link name.
std::map<std::string, std::string> links;
};
} // namespace base
#endif // BASE_TEST_LAUNCHER_TEST_RESULT_H_