Googletest has no ready-to-wear solution for generating tests over a
template for a set of non-type template parameters, as you want.
Assuming C++11 or later, you can take advantage of std::integral_constant<T,N>
to create a class that uniquely represents each of the range of std::size_t
parameters N
for which you want tests covering Line<N>
, and use std::integral_constant<std::size_t,N>
as a proxy for N
to construct a TYPED_TEST_CASE
and associated TYPED_TEST
s. Like so:
A toy Line
class for illustration:
Line.h
#ifndef LINE_H
#define LINE_H
#include <cstddef>
template <std::size_t N>
class Line {
public:
static constexpr std::size_t capacity() {
return N;
}
explicit Line(std::size_t n)
: _length{n < N ? n : N}{};
std::size_t length() const {
return _length;
}
private:
std::size_t _length = 0;
};
#endif
Googletest test runner:
line_test.cpp
#include <gtest/gtest.h>
#include <type_traits>
#include "line.h"
template <typename T>
class line_tester : public ::testing::Test{};
using test_types = ::testing::Types<
std::integral_constant<std::size_t,2>,
std::integral_constant<std::size_t,3>,
std::integral_constant<std::size_t,5>>;
TYPED_TEST_CASE(line_tester, test_types);
TYPED_TEST(line_tester, get_capacity) {
static constexpr std::size_t n = TypeParam::value;
ASSERT_EQ(n,Line<n>::capacity());
}
TYPED_TEST(line_tester, set_length_preserved) {
Line<TypeParam::value> line{1};
ASSERT_EQ(line.length(),1);
}
TYPED_TEST(line_tester, set_length_trunctated) {
static constexpr std::size_t n = TypeParam::value;
Line<n> line{999};
ASSERT_EQ(line.length(),Line<n>::capacity());
}
int main(int argc, char **argv) {
::testing::InitGoogleTest(&argc, argv);
return RUN_ALL_TESTS();
}
Which runs like:
$ ./line_tester
[==========] Running 9 tests from 3 test cases.
[----------] Global test environment set-up.
[----------] 3 tests from line_tester/0, where TypeParam = std::integral_constant<unsigned long, 2ul>
[ RUN ] line_tester/0.get_capacity
[ OK ] line_tester/0.get_capacity (0 ms)
[ RUN ] line_tester/0.set_length_preserved
[ OK ] line_tester/0.set_length_preserved (0 ms)
[ RUN ] line_tester/0.set_length_trunctated
[ OK ] line_tester/0.set_length_trunctated (0 ms)
[----------] 3 tests from line_tester/0 (1 ms total)
[----------] 3 tests from line_tester/1, where TypeParam = std::integral_constant<unsigned long, 3ul>
[ RUN ] line_tester/1.get_capacity
[ OK ] line_tester/1.get_capacity (0 ms)
[ RUN ] line_tester/1.set_length_preserved
[ OK ] line_tester/1.set_length_preserved (0 ms)
[ RUN ] line_tester/1.set_length_trunctated
[ OK ] line_tester/1.set_length_trunctated (0 ms)
[----------] 3 tests from line_tester/1 (0 ms total)
[----------] 3 tests from line_tester/2, where TypeParam = std::integral_constant<unsigned long, 5ul>
[ RUN ] line_tester/2.get_capacity
[ OK ] line_tester/2.get_capacity (0 ms)
[ RUN ] line_tester/2.set_length_preserved
[ OK ] line_tester/2.set_length_preserved (0 ms)
[ RUN ] line_tester/2.set_length_trunctated
[ OK ] line_tester/2.set_length_trunctated (0 ms)
[----------] 3 tests from line_tester/2 (0 ms total)
[----------] Global test environment tear-down
[==========] 9 tests from 3 test cases ran. (1 ms total)
[ PASSED ] 9 tests.
static constexpr T value
as its template parameters ? That might be a bit tedious, but it should work at least. ( ideone.com/4l4H7y ) – Vann