37 #ifndef GTEST_SRC_GTEST_INTERNAL_INL_H_
38 #define GTEST_SRC_GTEST_INTERNAL_INL_H_
42 #if !GTEST_IMPLEMENTATION_
44 # error "gtest-internal-inl.h is part of Google Test's internal implementation."
45 # error "It must not be included except by Google Test itself."
46 #endif // GTEST_IMPLEMENTATION_
59 #include "gtest/internal/gtest-port.h"
61 #if GTEST_CAN_STREAM_RESULTS_
62 # include <arpa/inet.h>
68 #endif // GTEST_OS_WINDOWS
70 #include "gtest/gtest.h"
71 #include "gtest/gtest-spi.h"
80 GTEST_DECLARE_bool_(death_test_use_fork);
86 GTEST_API_
extern const TypeId kTestTypeIdInGoogleTest;
89 const char kAlsoRunDisabledTestsFlag[] =
"also_run_disabled_tests";
90 const char kBreakOnFailureFlag[] =
"break_on_failure";
91 const char kCatchExceptionsFlag[] =
"catch_exceptions";
92 const char kColorFlag[] =
"color";
93 const char kFilterFlag[] =
"filter";
94 const char kListTestsFlag[] =
"list_tests";
95 const char kOutputFlag[] =
"output";
96 const char kPrintTimeFlag[] =
"print_time";
97 const char kRandomSeedFlag[] =
"random_seed";
98 const char kRepeatFlag[] =
"repeat";
99 const char kShuffleFlag[] =
"shuffle";
100 const char kStackTraceDepthFlag[] =
"stack_trace_depth";
101 const char kStreamResultToFlag[] =
"stream_result_to";
102 const char kThrowOnFailureFlag[] =
"throw_on_failure";
103 const char kFlagfileFlag[] =
"flagfile";
106 const int kMaxRandomSeed = 99999;
110 GTEST_API_
extern bool g_help_flag;
113 GTEST_API_ TimeInMillis GetTimeInMillis();
116 GTEST_API_
bool ShouldUseColor(
bool stdout_is_tty);
119 GTEST_API_ std::string FormatTimeInMillisAsSeconds(TimeInMillis ms);
125 GTEST_API_ std::string FormatEpochTimeInMillisAsIso8601(TimeInMillis ms);
131 GTEST_API_
bool ParseInt32Flag(
132 const char* str,
const char* flag, Int32* value);
136 inline int GetRandomSeedFromFlag(Int32 random_seed_flag) {
137 const unsigned int raw_seed = (random_seed_flag == 0) ?
138 static_cast<unsigned int>(GetTimeInMillis()) :
139 static_cast<unsigned int>(random_seed_flag);
143 const int normalized_seed =
144 static_cast<int>((raw_seed - 1U) %
145 static_cast<unsigned int>(kMaxRandomSeed)) + 1;
146 return normalized_seed;
152 inline int GetNextRandomSeed(
int seed) {
153 GTEST_CHECK_(1 <= seed && seed <= kMaxRandomSeed)
154 <<
"Invalid random seed " << seed <<
" - must be in [1, "
155 << kMaxRandomSeed <<
"].";
156 const int next_seed = seed + 1;
157 return (next_seed > kMaxRandomSeed) ? 1 : next_seed;
166 also_run_disabled_tests_ = GTEST_FLAG(also_run_disabled_tests);
167 break_on_failure_ = GTEST_FLAG(break_on_failure);
168 catch_exceptions_ = GTEST_FLAG(catch_exceptions);
169 color_ = GTEST_FLAG(color);
170 death_test_style_ = GTEST_FLAG(death_test_style);
171 death_test_use_fork_ = GTEST_FLAG(death_test_use_fork);
172 filter_ = GTEST_FLAG(filter);
173 internal_run_death_test_ = GTEST_FLAG(internal_run_death_test);
174 list_tests_ = GTEST_FLAG(list_tests);
175 output_ = GTEST_FLAG(output);
176 print_time_ = GTEST_FLAG(print_time);
177 random_seed_ = GTEST_FLAG(random_seed);
178 repeat_ = GTEST_FLAG(repeat);
179 shuffle_ = GTEST_FLAG(shuffle);
180 stack_trace_depth_ = GTEST_FLAG(stack_trace_depth);
181 stream_result_to_ = GTEST_FLAG(stream_result_to);
182 throw_on_failure_ = GTEST_FLAG(throw_on_failure);
187 GTEST_FLAG(also_run_disabled_tests) = also_run_disabled_tests_;
188 GTEST_FLAG(break_on_failure) = break_on_failure_;
189 GTEST_FLAG(catch_exceptions) = catch_exceptions_;
190 GTEST_FLAG(color) = color_;
191 GTEST_FLAG(death_test_style) = death_test_style_;
192 GTEST_FLAG(death_test_use_fork) = death_test_use_fork_;
193 GTEST_FLAG(filter) = filter_;
194 GTEST_FLAG(internal_run_death_test) = internal_run_death_test_;
195 GTEST_FLAG(list_tests) = list_tests_;
196 GTEST_FLAG(output) = output_;
197 GTEST_FLAG(print_time) = print_time_;
198 GTEST_FLAG(random_seed) = random_seed_;
199 GTEST_FLAG(repeat) = repeat_;
200 GTEST_FLAG(shuffle) = shuffle_;
201 GTEST_FLAG(stack_trace_depth) = stack_trace_depth_;
202 GTEST_FLAG(stream_result_to) = stream_result_to_;
203 GTEST_FLAG(throw_on_failure) = throw_on_failure_;
208 bool also_run_disabled_tests_;
209 bool break_on_failure_;
210 bool catch_exceptions_;
212 std::string death_test_style_;
213 bool death_test_use_fork_;
215 std::string internal_run_death_test_;
219 internal::Int32 random_seed_;
220 internal::Int32 repeat_;
222 internal::Int32 stack_trace_depth_;
223 std::string stream_result_to_;
224 bool throw_on_failure_;
225 } GTEST_ATTRIBUTE_UNUSED_;
233 GTEST_API_ std::string CodePointToUtf8(UInt32 code_point);
248 GTEST_API_ std::string WideStringToUtf8(
const wchar_t* str,
int num_chars);
254 void WriteToShardStatusFileIfNeeded();
262 GTEST_API_
bool ShouldShard(
const char* total_shards_str,
263 const char* shard_index_str,
264 bool in_subprocess_for_death_test);
269 GTEST_API_ Int32 Int32FromEnvOrDie(
const char* env_var, Int32 default_val);
275 GTEST_API_
bool ShouldRunTestOnShard(
276 int total_shards,
int shard_index,
int test_id);
282 template <
class Container,
typename Predicate>
283 inline int CountIf(
const Container& c, Predicate predicate) {
287 for (
typename Container::const_iterator it = c.begin(); it != c.end(); ++it) {
295 template <
class Container,
typename Functor>
296 void ForEach(
const Container& c, Functor functor) {
297 std::for_each(c.begin(), c.end(), functor);
302 template <
typename E>
303 inline E GetElementOr(
const std::vector<E>& v,
int i, E default_value) {
304 return (i < 0 || i >= static_cast<int>(v.size())) ? default_value : v[i];
311 template <
typename E>
312 void ShuffleRange(internal::Random* random,
int begin,
int end,
314 const int size =
static_cast<int>(v->size());
315 GTEST_CHECK_(0 <= begin && begin <= size)
316 <<
"Invalid shuffle range start " << begin <<
": must be in range [0, "
318 GTEST_CHECK_(begin <= end && end <= size)
319 <<
"Invalid shuffle range finish " << end <<
": must be in range ["
320 << begin <<
", " << size <<
"].";
324 for (
int range_width = end - begin; range_width >= 2; range_width--) {
325 const int last_in_range = begin + range_width - 1;
326 const int selected = begin + random->Generate(range_width);
327 std::swap((*v)[selected], (*v)[last_in_range]);
332 template <
typename E>
333 inline void Shuffle(internal::Random* random, std::vector<E>* v) {
334 ShuffleRange(random, 0, static_cast<int>(v->size()), v);
339 template <
typename T>
340 static void Delete(T* x) {
355 bool operator()(
const TestProperty& test_property)
const {
356 return test_property.key() == key_;
378 static std::string GetOutputFormat();
383 static std::string GetAbsolutePathToOutputFile();
392 static bool PatternMatchesString(
const char *pattern,
const char *str);
396 static bool FilterMatchesTest(
const std::string &test_case_name,
397 const std::string &test_name);
405 static int GTestShouldProcessSEH(DWORD exception_code);
406 #endif // GTEST_OS_WINDOWS
410 static bool MatchesFilter(
const std::string& name,
const char* filter);
415 GTEST_API_
FilePath GetCurrentExecutableName();
429 virtual string CurrentStackTrace(
int max_depth,
int skip_count) = 0;
434 virtual void UponLeavingGTest() = 0;
438 static const char*
const kElidedFramesMarker;
449 virtual string CurrentStackTrace(
int max_depth,
int skip_count);
450 virtual void UponLeavingGTest();
515 void SetGlobalTestPartResultReporter(
522 void SetTestPartResultReporterForCurrentThread(
526 int successful_test_case_count()
const;
529 int failed_test_case_count()
const;
532 int total_test_case_count()
const;
536 int test_case_to_run_count()
const;
539 int successful_test_count()
const;
542 int failed_test_count()
const;
545 int reportable_disabled_test_count()
const;
548 int disabled_test_count()
const;
551 int reportable_test_count()
const;
554 int total_test_count()
const;
557 int test_to_run_count()
const;
561 TimeInMillis start_timestamp()
const {
return start_timestamp_; }
564 TimeInMillis elapsed_time()
const {
return elapsed_time_; }
567 bool Passed()
const {
return !Failed(); }
571 bool Failed()
const {
572 return failed_test_case_count() > 0 || ad_hoc_test_result()->Failed();
577 const TestCase* GetTestCase(
int i)
const {
578 const int index = GetElementOr(test_case_indices_, i, -1);
579 return index < 0 ? NULL : test_cases_[i];
584 TestCase* GetMutableTestCase(
int i) {
585 const int index = GetElementOr(test_case_indices_, i, -1);
586 return index < 0 ? NULL : test_cases_[index];
597 const TestResult* ad_hoc_test_result()
const {
return &ad_hoc_test_result_; }
621 std::string CurrentOsStackTraceExceptTop(
int skip_count) GTEST_NO_INLINE_;
633 TestCase* GetTestCase(
const char* test_case_name,
634 const char* type_param,
635 Test::SetUpTestCaseFunc set_up_tc,
636 Test::TearDownTestCaseFunc tear_down_tc);
645 void AddTestInfo(Test::SetUpTestCaseFunc set_up_tc,
646 Test::TearDownTestCaseFunc tear_down_tc,
655 if (original_working_dir_.IsEmpty()) {
656 original_working_dir_.Set(FilePath::GetCurrentDir());
657 GTEST_CHECK_(!original_working_dir_.IsEmpty())
658 <<
"Failed to get the current working directory.";
661 GetTestCase(test_info->test_case_name(),
662 test_info->type_param(),
664 tear_down_tc)->AddTestInfo(test_info);
667 #if GTEST_HAS_PARAM_TEST
670 internal::ParameterizedTestCaseRegistry& parameterized_test_registry() {
671 return parameterized_test_registry_;
673 #endif // GTEST_HAS_PARAM_TEST
676 void set_current_test_case(
TestCase* a_current_test_case) {
677 current_test_case_ = a_current_test_case;
683 void set_current_test_info(
TestInfo* a_current_test_info) {
684 current_test_info_ = a_current_test_info;
693 void RegisterParameterizedTests();
702 void ClearNonAdHocTestResult() {
703 ForEach(test_cases_, TestCase::ClearTestCaseResult);
707 void ClearAdHocTestResult() {
708 ad_hoc_test_result_.Clear();
717 enum ReactionToSharding {
718 HONOR_SHARDING_PROTOCOL,
719 IGNORE_SHARDING_PROTOCOL
728 int FilterTests(ReactionToSharding shard_tests);
731 void ListTestsMatchingFilter();
733 const TestCase* current_test_case()
const {
return current_test_case_; }
734 TestInfo* current_test_info() {
return current_test_info_; }
735 const TestInfo* current_test_info()
const {
return current_test_info_; }
739 std::vector<Environment*>& environments() {
return environments_; }
742 std::vector<TraceInfo>& gtest_trace_stack() {
743 return *(gtest_trace_stack_.pointer());
745 const std::vector<TraceInfo>& gtest_trace_stack()
const {
746 return gtest_trace_stack_.get();
749 #if GTEST_HAS_DEATH_TEST
750 void InitDeathTestSubprocessControlInfo() {
751 internal_run_death_test_flag_.reset(ParseInternalRunDeathTestFlag());
757 const InternalRunDeathTestFlag* internal_run_death_test_flag()
const {
758 return internal_run_death_test_flag_.get();
762 internal::DeathTestFactory* death_test_factory() {
763 return death_test_factory_.get();
766 void SuppressTestEventsIfInSubprocess();
768 friend class ReplaceDeathTestFactory;
769 #endif // GTEST_HAS_DEATH_TEST
773 void ConfigureXmlOutput();
775 #if GTEST_CAN_STREAM_RESULTS_
778 void ConfigureStreamingOutput();
786 void PostFlagParsingInit();
789 int random_seed()
const {
return random_seed_; }
799 void UnshuffleTests();
803 bool catch_exceptions()
const {
return catch_exceptions_; }
806 friend class ::testing::UnitTest;
810 void set_catch_exceptions(
bool value) { catch_exceptions_ = value; }
822 default_per_thread_test_part_result_reporter_;
832 per_thread_test_part_result_reporter_;
836 std::vector<Environment*> environments_;
840 std::vector<TestCase*> test_cases_;
846 std::vector<int> test_case_indices_;
848 #if GTEST_HAS_PARAM_TEST
851 internal::ParameterizedTestCaseRegistry parameterized_test_registry_;
854 bool parameterized_tests_registered_;
855 #endif // GTEST_HAS_PARAM_TEST
858 int last_death_test_case_;
893 bool post_flag_parse_init_performed_;
903 TimeInMillis start_timestamp_;
906 TimeInMillis elapsed_time_;
908 #if GTEST_HAS_DEATH_TEST
913 #endif // GTEST_HAS_DEATH_TEST
920 bool catch_exceptions_;
928 return UnitTest::GetInstance()->impl();
931 #if GTEST_USES_SIMPLE_RE
935 GTEST_API_
bool IsInSet(
char ch,
const char* str);
936 GTEST_API_
bool IsAsciiDigit(
char ch);
937 GTEST_API_
bool IsAsciiPunct(
char ch);
938 GTEST_API_
bool IsRepeat(
char ch);
939 GTEST_API_
bool IsAsciiWhiteSpace(
char ch);
940 GTEST_API_
bool IsAsciiWordChar(
char ch);
941 GTEST_API_
bool IsValidEscape(
char ch);
942 GTEST_API_
bool AtomMatchesChar(
bool escaped,
char pattern,
char ch);
943 GTEST_API_
bool ValidateRegex(
const char* regex);
944 GTEST_API_
bool MatchRegexAtHead(
const char* regex,
const char* str);
945 GTEST_API_
bool MatchRepetitionAndRegexAtHead(
946 bool escaped,
char ch,
char repeat,
const char* regex,
const char* str);
947 GTEST_API_
bool MatchRegexAnywhere(
const char* regex,
const char* str);
949 #endif // GTEST_USES_SIMPLE_RE
953 GTEST_API_
void ParseGoogleTestFlagsOnly(
int* argc,
char** argv);
954 GTEST_API_
void ParseGoogleTestFlagsOnly(
int* argc,
wchar_t** argv);
956 #if GTEST_HAS_DEATH_TEST
960 GTEST_API_ std::string GetLastErrnoDescription();
966 template <
typename Integer>
967 bool ParseNaturalNumber(const ::std::string& str, Integer* number) {
971 if (str.empty() || !IsDigit(str[0])) {
980 # if GTEST_OS_WINDOWS && !defined(__GNUC__)
983 typedef unsigned __int64 BiggestConvertible;
984 const BiggestConvertible parsed = _strtoui64(str.c_str(), &end, 10);
988 typedef unsigned long long BiggestConvertible;
989 const BiggestConvertible parsed = strtoull(str.c_str(), &end, 10);
991 # endif // GTEST_OS_WINDOWS && !defined(__GNUC__)
993 const bool parse_success = *end ==
'\0' && errno == 0;
997 GTEST_CHECK_(
sizeof(Integer) <=
sizeof(parsed));
999 const Integer result =
static_cast<Integer
>(parsed);
1000 if (parse_success && static_cast<BiggestConvertible>(result) == parsed) {
1006 #endif // GTEST_HAS_DEATH_TEST
1016 static void RecordProperty(
TestResult* test_result,
1017 const std::string& xml_element,
1019 test_result->RecordProperty(xml_element, property);
1022 static void ClearTestPartResults(
TestResult* test_result) {
1023 test_result->ClearTestPartResults();
1026 static const std::vector<testing::TestPartResult>& test_part_results(
1028 return test_result.test_part_results();
1032 #if GTEST_CAN_STREAM_RESULTS_
1038 class AbstractSocketWriter {
1040 virtual ~AbstractSocketWriter() {}
1043 virtual void Send(
const string& message) = 0;
1046 virtual void CloseConnection() {}
1049 void SendLn(
const string& message) {
1050 Send(message +
"\n");
1055 class SocketWriter :
public AbstractSocketWriter {
1057 SocketWriter(
const string& host,
const string& port)
1058 : sockfd_(-1), host_name_(host), port_num_(port) {
1062 virtual ~SocketWriter() {
1068 virtual void Send(
const string& message) {
1069 GTEST_CHECK_(sockfd_ != -1)
1070 <<
"Send() can be called only when there is a connection.";
1072 const int len =
static_cast<int>(message.length());
1073 if (write(sockfd_, message.c_str(), len) != len) {
1075 <<
"stream_result_to: failed to stream to "
1076 << host_name_ <<
":" << port_num_;
1082 void MakeConnection();
1085 void CloseConnection() {
1086 GTEST_CHECK_(sockfd_ != -1)
1087 <<
"CloseConnection() can be called only when there is a connection.";
1094 const string host_name_;
1095 const string port_num_;
1097 GTEST_DISALLOW_COPY_AND_ASSIGN_(SocketWriter);
1101 static string UrlEncode(
const char* str);
1103 StreamingListener(
const string& host,
const string& port)
1104 : socket_writer_(new SocketWriter(host, port)) { Start(); }
1106 explicit StreamingListener(AbstractSocketWriter* socket_writer)
1107 : socket_writer_(socket_writer) { Start(); }
1109 void OnTestProgramStart(
const UnitTest& ) {
1110 SendLn(
"event=TestProgramStart");
1113 void OnTestProgramEnd(
const UnitTest& unit_test) {
1116 SendLn(
"event=TestProgramEnd&passed=" + FormatBool(unit_test.Passed()));
1119 socket_writer_->CloseConnection();
1122 void OnTestIterationStart(
const UnitTest& ,
int iteration) {
1123 SendLn(
"event=TestIterationStart&iteration=" +
1124 StreamableToString(iteration));
1127 void OnTestIterationEnd(
const UnitTest& unit_test,
int ) {
1128 SendLn(
"event=TestIterationEnd&passed=" +
1129 FormatBool(unit_test.Passed()) +
"&elapsed_time=" +
1130 StreamableToString(unit_test.elapsed_time()) +
"ms");
1133 void OnTestCaseStart(
const TestCase& test_case) {
1134 SendLn(std::string(
"event=TestCaseStart&name=") + test_case.name());
1137 void OnTestCaseEnd(
const TestCase& test_case) {
1138 SendLn(
"event=TestCaseEnd&passed=" + FormatBool(test_case.Passed())
1139 +
"&elapsed_time=" + StreamableToString(test_case.elapsed_time())
1143 void OnTestStart(
const TestInfo& test_info) {
1144 SendLn(std::string(
"event=TestStart&name=") + test_info.name());
1147 void OnTestEnd(
const TestInfo& test_info) {
1148 SendLn(
"event=TestEnd&passed=" +
1149 FormatBool((test_info.result())->Passed()) +
1151 StreamableToString((test_info.result())->elapsed_time()) +
"ms");
1154 void OnTestPartResult(
const TestPartResult& test_part_result) {
1155 const char* file_name = test_part_result.file_name();
1156 if (file_name == NULL)
1158 SendLn(
"event=TestPartResult&file=" + UrlEncode(file_name) +
1159 "&line=" + StreamableToString(test_part_result.line_number()) +
1160 "&message=" + UrlEncode(test_part_result.message()));
1165 void SendLn(
const string& message) { socket_writer_->SendLn(message); }
1169 void Start() { SendLn(
"gtest_streaming_protocol_version=1.0"); }
1171 string FormatBool(
bool value) {
return value ?
"1" :
"0"; }
1173 const scoped_ptr<AbstractSocketWriter> socket_writer_;
1175 GTEST_DISALLOW_COPY_AND_ASSIGN_(StreamingListener);
1178 #endif // GTEST_CAN_STREAM_RESULTS_
1183 #endif // GTEST_SRC_GTEST_INTERNAL_INL_H_