diff options
| author | Gennadiy Civil <misterg@google.com> | 2019-01-29 14:32:04 -0500 | 
|---|---|---|
| committer | Gennadiy Civil <misterg@google.com> | 2019-01-29 14:32:06 -0500 | 
| commit | 1f42ae7353b3c52f0fe014da31e5210f266274cc (patch) | |
| tree | 11cbf31423ec230213c3f526b5330cf8a6acde80 | |
| parent | 01148677a937eae1c0fd1e488ca81445531ea368 (diff) | |
| parent | 7c4164bf404d899b6d4c74beb1070da5647f55a2 (diff) | |
| download | googletest-1f42ae7353b3c52f0fe014da31e5210f266274cc.tar.gz googletest-1f42ae7353b3c52f0fe014da31e5210f266274cc.tar.bz2 googletest-1f42ae7353b3c52f0fe014da31e5210f266274cc.zip | |
Merge pull request #2063 from mathbunnyru:master
PiperOrigin-RevId: 231434457
| -rw-r--r-- | .travis.yml | 4 | ||||
| -rw-r--r-- | googletest/include/gtest/gtest-param-test.h | 23 | ||||
| -rw-r--r-- | googletest/include/gtest/internal/gtest-param-util.h | 22 | 
3 files changed, 18 insertions, 31 deletions
| diff --git a/.travis.yml b/.travis.yml index fd8f7c65..3c52e78c 100644 --- a/.travis.yml +++ b/.travis.yml @@ -46,9 +46,9 @@ matrix:        env: BUILD_TYPE=Release VERBOSE=1 CXX_FLAGS=-std=c++11 NO_EXCEPTION=ON NO_RTTI=ON COMPILER_IS_GNUCXX=ON      - os: osx        compiler: gcc -      env: BUILD_TYPE=Release VERBOSE=1 CXX_FLAGS=-std=c++11 +      env: BUILD_TYPE=Release VERBOSE=1 CXX_FLAGS=-std=c++11 HOMEBREW_LOGS=~/homebrew-logs HOMEBREW_TEMP=~/homebrew-temp      - os: osx -      env: BUILD_TYPE=Release VERBOSE=1 CXX_FLAGS=-std=c++11 +      env: BUILD_TYPE=Release VERBOSE=1 CXX_FLAGS=-std=c++11 HOMEBREW_LOGS=~/homebrew-logs HOMEBREW_TEMP=~/homebrew-temp        if: type != pull_request  # These are the install and build (script) phases for the most common entries in the matrix.  They could be included diff --git a/googletest/include/gtest/gtest-param-test.h b/googletest/include/gtest/gtest-param-test.h index a0eecc69..3f712cfd 100644 --- a/googletest/include/gtest/gtest-param-test.h +++ b/googletest/include/gtest/gtest-param-test.h @@ -544,10 +544,11 @@ internal::CartesianProductHolder10<Generator1, Generator2, Generator3,        GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::AddToRegistry();     \    void GTEST_TEST_CLASS_NAME_(test_suite_name, test_name)::TestBody() -// The optional last argument to INSTANTIATE_TEST_SUITE_P allows the user -// to specify a function or functor that generates custom test name suffixes -// based on the test parameters. The function should accept one argument of -// type testing::TestParamInfo<class ParamType>, and return std::string. +// The last argument to INSTANTIATE_TEST_SUITE_P allows the user to specify +// generator and an optional function or functor that generates custom test name +// suffixes based on the test parameters. Such a function or functor should +// accept one argument of type testing::TestParamInfo<class ParamType>, and +// return std::string.  //  // testing::PrintToStringParamName is a builtin test suffix generator that  // returns the value of testing::PrintToString(GetParam()). @@ -556,15 +557,21 @@ internal::CartesianProductHolder10<Generator1, Generator2, Generator3,  // alphanumeric characters or underscore. Because PrintToString adds quotes  // to std::string and C strings, it won't work for these types. -#define INSTANTIATE_TEST_SUITE_P(prefix, test_suite_name, generator, ...)     \ +#define GTEST_EXPAND_(arg) arg +#define GTEST_GET_FIRST_(first, ...) first +#define GTEST_GET_SECOND_(first, second, ...) second + +#define INSTANTIATE_TEST_SUITE_P(prefix, test_suite_name, ...)                \    static ::testing::internal::ParamGenerator<test_suite_name::ParamType>      \        gtest_##prefix##test_suite_name##_EvalGenerator_() {                    \ -    return generator;                                                         \ +    return GTEST_EXPAND_(GTEST_GET_FIRST_(__VA_ARGS__, DUMMY_PARAM_));        \    }                                                                           \    static ::std::string gtest_##prefix##test_suite_name##_EvalGenerateName_(   \        const ::testing::TestParamInfo<test_suite_name::ParamType>& info) {     \ -    return ::testing::internal::GetParamNameGen<test_suite_name::ParamType>(  \ -        __VA_ARGS__)(info);                                                   \ +    return GTEST_EXPAND_(GTEST_GET_SECOND_(                                   \ +        __VA_ARGS__,                                                          \ +        ::testing::internal::DefaultParamName<test_suite_name::ParamType>,    \ +        DUMMY_PARAM_))(info);                                                 \    }                                                                           \    static int gtest_##prefix##test_suite_name##_dummy_                         \        GTEST_ATTRIBUTE_UNUSED_ =                                               \ diff --git a/googletest/include/gtest/internal/gtest-param-util.h b/googletest/include/gtest/internal/gtest-param-util.h index bca72539..12b1e527 100644 --- a/googletest/include/gtest/internal/gtest-param-util.h +++ b/googletest/include/gtest/internal/gtest-param-util.h @@ -378,26 +378,6 @@ std::string DefaultParamName(const TestParamInfo<ParamType>& info) {  // INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.  // -// Parameterized test name overload helpers, which help the -// INSTANTIATE_TEST_SUITE_P macro choose between the default parameterized -// test name generator and user param name generator. -template <class ParamType, class ParamNameGenFunctor> -ParamNameGenFunctor GetParamNameGen(ParamNameGenFunctor func) { -  return func; -} - -template <class ParamType> -struct ParamNameGenFunc { -  typedef std::string Type(const TestParamInfo<ParamType>&); -}; - -template <class ParamType> -typename ParamNameGenFunc<ParamType>::Type *GetParamNameGen() { -  return DefaultParamName; -} - -// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE. -//  // Stores a parameter value and later creates tests parameterized with that  // value.  template <class TestClass> @@ -500,7 +480,7 @@ class ParameterizedTestSuiteInfo : public ParameterizedTestSuiteInfoBase {    using ParamType = typename TestSuite::ParamType;    // A function that returns an instance of appropriate generator type.    typedef ParamGenerator<ParamType>(GeneratorCreationFunc)(); -  typedef typename ParamNameGenFunc<ParamType>::Type ParamNameGeneratorFunc; +  typedef std::string ParamNameGeneratorFunc(const TestParamInfo<ParamType>&);    explicit ParameterizedTestSuiteInfo(const char* name,                                        CodeLocation code_location) | 
