// 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_RESULTS_TRACKER_H_ #define BASE_TEST_LAUNCHER_TEST_RESULTS_TRACKER_H_ #include <map> #include <set> #include <string> #include <vector> #include "base/callback.h" #include "base/test/launcher/test_result.h" #include "base/threading/thread_checker.h" namespace base { class CommandLine; class FilePath; // A helper class to output results. // Note: as currently XML is the only supported format by gtest, we don't // check output format (e.g. "xml:" prefix) here and output an XML file // unconditionally. // Note: we don't output per-test-case or total summary info like // total failed_test_count, disabled_test_count, elapsed_time and so on. // Only each test (testcase element in the XML) will have the correct // failed/disabled/elapsed_time information. Each test won't include // detailed failure messages either. class TestResultsTracker { public: TestResultsTracker(); ~TestResultsTracker(); // Initialize the result tracker. Must be called exactly once before // calling any other methods. Returns true on success. bool Init(const CommandLine& command_line) WARN_UNUSED_RESULT; // Called when a test iteration is starting. void OnTestIterationStarting(); // Adds |test_name| to the set of discovered tests (this includes all tests // present in the executable, not necessarily run). void AddTest(const std::string& test_name); // Adds |test_name| to the set of disabled tests. void AddDisabledTest(const std::string& test_name); // Adds |result| to the stored test results. void AddTestResult(const TestResult& result); // Prints a summary of current test iteration to stdout. void PrintSummaryOfCurrentIteration() const; // Prints a summary of all test iterations (not just the last one) to stdout. void PrintSummaryOfAllIterations() const; // Adds a string tag to the JSON summary. This is intended to indicate // conditions that affect the entire test run, as opposed to individual tests. void AddGlobalTag(const std::string& tag); // Saves a JSON summary of all test iterations results to |path|. Returns // true on success. bool SaveSummaryAsJSON(const FilePath& path) const WARN_UNUSED_RESULT; // Map where keys are test result statuses, and values are sets of tests // which finished with that status. typedef std::map<TestResult::Status, std::set<std::string> > TestStatusMap; // Returns a test status map (see above) for current test iteration. TestStatusMap GetTestStatusMapForCurrentIteration() const; // Returns a test status map (see above) for all test iterations. TestStatusMap GetTestStatusMapForAllIterations() const; private: void GetTestStatusForIteration(int iteration, TestStatusMap* map) const; struct AggregateTestResult { AggregateTestResult(); ~AggregateTestResult(); std::vector<TestResult> test_results; }; struct PerIterationData { PerIterationData(); ~PerIterationData(); // Aggregate test results grouped by full test name. typedef std::map<std::string, AggregateTestResult> ResultsMap; ResultsMap results; }; ThreadChecker thread_checker_; // Set of global tags, i.e. strings indicating conditions that apply to // the entire test run. std::set<std::string> global_tags_; // Set of all test names discovered in the current executable. std::set<std::string> all_tests_; // Set of all disabled tests in the current executable. std::set<std::string> disabled_tests_; // Store test results for each iteration. std::vector<PerIterationData> per_iteration_data_; // Index of current iteration (starting from 0). -1 before the first // iteration. int iteration_; // File handle of output file (can be NULL if no file). FILE* out_; DISALLOW_COPY_AND_ASSIGN(TestResultsTracker); }; } // namespace base #endif // BASE_TEST_LAUNCHER_TEST_RESULTS_TRACKER_H_