|  | // Copyright 2013 The Chromium Authors | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef TESTING_DATA_DRIVEN_TESTING_DATA_DRIVEN_TEST_H_ | 
|  | #define TESTING_DATA_DRIVEN_TESTING_DATA_DRIVEN_TEST_H_ | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include "base/files/file_path.h" | 
|  |  | 
|  | namespace testing { | 
|  |  | 
|  | // A convenience class for implementing data-driven tests. Subclassers need only | 
|  | // implement the conversion of serialized input data to serialized output data | 
|  | // and provide a set of input files. For each input file, on the first run, a | 
|  | // gold output file is generated; for subsequent runs, the test output is | 
|  | // compared to this gold output. | 
|  | class DataDrivenTest { | 
|  | public: | 
|  | DataDrivenTest(const DataDrivenTest&) = delete; | 
|  | DataDrivenTest& operator=(const DataDrivenTest&) = delete; | 
|  |  | 
|  | // For each file in |input_directory| whose filename matches | 
|  | // |file_name_pattern|, slurps in the file contents and calls into | 
|  | // |GenerateResults()|. If the corresponding output file already exists in | 
|  | // the |output_directory|, verifies that the results match the file contents; | 
|  | // otherwise, writes a gold result file to the |output_directory|. | 
|  | void RunDataDrivenTest(const base::FilePath& input_directory, | 
|  | const base::FilePath& output_directory, | 
|  | const base::FilePath::StringType& file_name_pattern); | 
|  |  | 
|  | // As above, but runs a test for a single file, the full path of which is | 
|  | // given by |test_file_name|. | 
|  | void RunOneDataDrivenTest(const base::FilePath& test_file_name, | 
|  | const base::FilePath& output_directory, | 
|  | bool is_expected_to_pass); | 
|  |  | 
|  | // Given the |input| data, generates the |output| results. The output results | 
|  | // must be stable across runs. | 
|  | // Note: The return type is |void| so that googletest |ASSERT_*| macros will | 
|  | // compile. | 
|  | virtual void GenerateResults(const std::string& input, | 
|  | std::string* output) = 0; | 
|  |  | 
|  | // Return |base::FilePath|s to the test input and output subdirectories | 
|  | // ../|feature_dir|/|test_name|/input and ../|feature_dir|/|test_name|/output. | 
|  | base::FilePath GetInputDirectory(); | 
|  | base::FilePath GetOutputDirectory(); | 
|  |  | 
|  | protected: | 
|  | DataDrivenTest(const base::FilePath& test_data_directory, | 
|  | const base::FilePath::StringType& feature_name, | 
|  | const base::FilePath::StringType& test_name); | 
|  | virtual ~DataDrivenTest(); | 
|  |  | 
|  | private: | 
|  | base::FilePath test_data_directory_; | 
|  | base::FilePath::StringType feature_directory_; | 
|  | base::FilePath::StringType test_name_; | 
|  | }; | 
|  |  | 
|  | }  // namespace testing | 
|  |  | 
|  | #endif  // TESTING_DATA_DRIVEN_TESTING_DATA_DRIVEN_TEST_H_ |