Merge pull request #3546 from pherl/deathtest

Disable death tests on windows
pull/3548/head
Jisi Liu 8 years ago committed by GitHub
commit 30681c7578
  1. 38
      src/google/protobuf/message_unittest.cc
  2. 3
      src/google/protobuf/testing/googletest.h

@ -257,44 +257,6 @@ TEST(MessageTest, CheckInitialized) {
"fields: a, b, c");
}
TEST(MessageTest, CheckOverflow) {
unittest::TestAllTypes message;
// Create a message with size just over 2GB. This triggers integer overflow
// when computing message size.
const string data(1024, 'x');
Cord one_megabyte;
for (int i = 0; i < 1024; i++) {
one_megabyte.Append(data);
}
for (int i = 0; i < 2 * 1024 + 1; ++i) {
message.add_repeated_cord()->CopyFrom(one_megabyte);
}
Cord serialized;
EXPECT_FALSE(message.AppendToCord(&serialized));
}
TEST(MessageTest, CheckBigOverflow) {
// Checking for 4GB buffers on 32 bit systems is problematic.
if (sizeof(void*) < 8) return;
unittest::TestAllTypes message;
// Create a message with size just over 4GB. We should be able to detect this
// too, even though it will make a plain "int" wrap back to a positive number.
const string data(1024, 'x');
Cord one_megabyte;
for (int i = 0; i < 1024; i++) {
one_megabyte.Append(data);
}
for (int i = 0; i < 4 * 1024 + 1; ++i) {
message.add_repeated_cord()->CopyFrom(one_megabyte);
}
Cord serialized;
EXPECT_FALSE(message.AppendToCord(&serialized));
}
#endif // PROTOBUF_HAS_DEATH_TEST
namespace {

@ -39,7 +39,8 @@
#include <google/protobuf/stubs/common.h>
#include <gmock/gmock.h>
// Disable death tests if we use exceptions in CHECK().
#if !PROTOBUF_USE_EXCEPTIONS && defined(GTEST_HAS_DEATH_TEST)
#if !PROTOBUF_USE_EXCEPTIONS && defined(GTEST_HAS_DEATH_TEST) && \
!GTEST_OS_WINDOWS
#define PROTOBUF_HAS_DEATH_TEST
#endif

Loading…
Cancel
Save