2014-08-14 06:33:50 +00:00
|
|
|
// Copyright 2014 the V8 project 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 V8_TESTING_GTEST_SUPPORT_H_
|
|
|
|
#define V8_TESTING_GTEST_SUPPORT_H_
|
|
|
|
|
2014-10-21 08:25:14 +00:00
|
|
|
#include <stddef.h>
|
2014-08-14 06:33:50 +00:00
|
|
|
#include "testing/gtest/include/gtest/gtest.h"
|
|
|
|
|
|
|
|
namespace testing {
|
|
|
|
namespace internal {
|
|
|
|
|
|
|
|
#define GET_TYPE_NAME(type) \
|
|
|
|
template <> \
|
|
|
|
inline std::string GetTypeName<type>() { \
|
|
|
|
return #type; \
|
|
|
|
}
|
2014-10-06 12:27:24 +00:00
|
|
|
GET_TYPE_NAME(bool)
|
|
|
|
GET_TYPE_NAME(signed char)
|
|
|
|
GET_TYPE_NAME(unsigned char)
|
|
|
|
GET_TYPE_NAME(short)
|
|
|
|
GET_TYPE_NAME(unsigned short)
|
|
|
|
GET_TYPE_NAME(int)
|
|
|
|
GET_TYPE_NAME(unsigned int)
|
|
|
|
GET_TYPE_NAME(long)
|
|
|
|
GET_TYPE_NAME(unsigned long)
|
|
|
|
GET_TYPE_NAME(long long)
|
|
|
|
GET_TYPE_NAME(unsigned long long)
|
2014-08-14 06:33:50 +00:00
|
|
|
GET_TYPE_NAME(float)
|
|
|
|
GET_TYPE_NAME(double)
|
|
|
|
#undef GET_TYPE_NAME
|
|
|
|
|
|
|
|
|
|
|
|
// TRACED_FOREACH(type, var, array) expands to a loop that assigns |var| every
|
|
|
|
// item in the |array| and adds a SCOPED_TRACE() message for the |var| while
|
|
|
|
// inside the loop body.
|
|
|
|
// TODO(bmeurer): Migrate to C++11 once we're ready.
|
|
|
|
#define TRACED_FOREACH(_type, _var, _array) \
|
2014-08-26 09:19:24 +00:00
|
|
|
for (size_t _i = 0; _i < arraysize(_array); ++_i) \
|
2014-08-14 06:33:50 +00:00
|
|
|
for (bool _done = false; !_done;) \
|
2014-09-23 11:26:49 +00:00
|
|
|
for (_type const _var = _array[_i]; !_done;) \
|
2014-08-14 06:33:50 +00:00
|
|
|
for (SCOPED_TRACE(::testing::Message() << #_var << " = " << _var); \
|
|
|
|
!_done; _done = true)
|
|
|
|
|
|
|
|
|
|
|
|
// TRACED_FORRANGE(type, var, low, high) expands to a loop that assigns |var|
|
|
|
|
// every value in the range |low| to (including) |high| and adds a
|
|
|
|
// SCOPED_TRACE() message for the |var| while inside the loop body.
|
|
|
|
// TODO(bmeurer): Migrate to C++11 once we're ready.
|
|
|
|
#define TRACED_FORRANGE(_type, _var, _low, _high) \
|
|
|
|
for (_type _i = _low; _i <= _high; ++_i) \
|
|
|
|
for (bool _done = false; !_done;) \
|
2014-09-23 11:26:49 +00:00
|
|
|
for (_type const _var = _i; !_done;) \
|
2014-08-14 06:33:50 +00:00
|
|
|
for (SCOPED_TRACE(::testing::Message() << #_var << " = " << _var); \
|
|
|
|
!_done; _done = true)
|
|
|
|
|
|
|
|
} // namespace internal
|
|
|
|
} // namespace testing
|
|
|
|
|
|
|
|
#endif // V8_TESTING_GTEST_SUPPORT_H_
|