Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
yangql
googletest
Commits
a1923a59
Unverified
Commit
a1923a59
authored
Jan 30, 2018
by
Gennadiy Civil
Committed by
GitHub
Jan 30, 2018
Browse files
Merge pull request #1434 from gennadiycivil/master
Ability to optionally depend on Abseil plus upstream of 183716547
parents
798cc4a7
2a468302
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
67 additions
and
0 deletions
+67
-0
BUILD.bazel
BUILD.bazel
+20
-0
WORKSPACE
WORKSPACE
+7
-0
googletest/include/gtest/gtest-printers.h
googletest/include/gtest/gtest-printers.h
+28
-0
googletest/test/gtest-printers_test.cc
googletest/test/gtest-printers_test.cc
+12
-0
No files found.
BUILD.bazel
View file @
a1923a59
...
...
@@ -46,6 +46,12 @@ config_setting(
values
=
{
"cpu"
:
"x64_windows_msvc"
},
)
config_setting
(
name
=
"has_absl"
,
values
=
{
"define"
:
"absl=1"
},
)
# Google Test including Google Mock
cc_library
(
name
=
"gtest"
,
...
...
@@ -88,6 +94,20 @@ cc_library(
"-pthread"
,
],
}),
defines
=
select
({
":has_absl"
:
[
"GTEST_HAS_ABSL=1"
,
],
"//conditions:default"
:
[],
}
),
deps
=
select
({
":has_absl"
:
[
"@com_google_absl//absl/types:optional"
,
],
"//conditions:default"
:
[],
}
)
)
cc_library
(
...
...
WORKSPACE
View file @
a1923a59
workspace
(
name
=
"com_google_googletest"
)
# Abseil
http_archive
(
name
=
"com_google_absl"
,
urls
=
[
"https://github.com/abseil/abseil-cpp/archive/master.zip"
],
strip_prefix
=
"abseil-cpp-master"
,
)
googletest/include/gtest/gtest-printers.h
View file @
a1923a59
...
...
@@ -46,6 +46,10 @@
// 2. operator<<(ostream&, const T&) defined in either foo or the
// global namespace.
//
// However if T is an STL-style container then it is printed element-wise
// unless foo::PrintTo(const T&, ostream*) is defined. Note that
// operator<<() is ignored for container types.
//
// If none of the above is defined, it will print the debug string of
// the value if it is a protocol buffer, or print the raw bytes in the
// value otherwise.
...
...
@@ -107,6 +111,10 @@
# include <tuple>
#endif
#if GTEST_HAS_ABSL
#include "absl/types/optional.h"
#endif // GTEST_HAS_ABSL
namespace
testing
{
// Definitions in the 'internal' and 'internal2' name spaces are
...
...
@@ -722,6 +730,26 @@ class UniversalPrinter {
GTEST_DISABLE_MSC_WARNINGS_POP_
()
};
#if GTEST_HAS_ABSL
// Printer for absl::optional
template
<
typename
T
>
class
UniversalPrinter
<::
absl
::
optional
<
T
>>
{
public:
static
void
Print
(
const
::
absl
::
optional
<
T
>&
value
,
::
std
::
ostream
*
os
)
{
*
os
<<
'('
;
if
(
!
value
)
{
*
os
<<
"nullopt"
;
}
else
{
UniversalPrint
(
*
value
,
os
);
}
*
os
<<
')'
;
}
};
#endif // GTEST_HAS_ABSL
// UniversalPrintArray(begin, len, os) prints an array of 'len'
// elements, starting at address 'begin'.
template
<
typename
T
>
...
...
googletest/test/gtest-printers_test.cc
View file @
a1923a59
...
...
@@ -1765,5 +1765,17 @@ TEST(UniversalTersePrintTupleFieldsToStringsTestWithStd, PrintsTersely) {
#endif // GTEST_HAS_STD_TUPLE_
#if GTEST_HAS_ABSL
TEST
(
PrintOptionalTest
,
Basic
)
{
absl
::
optional
<
int
>
value
;
EXPECT_EQ
(
"(nullopt)"
,
PrintToString
(
value
));
value
=
{
7
};
EXPECT_EQ
(
"(7)"
,
PrintToString
(
value
));
EXPECT_EQ
(
"(1.1)"
,
PrintToString
(
absl
::
optional
<
double
>
{
1.1
}));
EXPECT_EQ
(
"(
\"
A
\"
)"
,
PrintToString
(
absl
::
optional
<
std
::
string
>
{
"A"
}));
}
#endif // GTEST_HAS_ABSL
}
// namespace gtest_printers_test
}
// namespace testing
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment