This refactoring takes a careful approach to avoid rushing the change: * stub headers are left in all the old locations of webrtc/base * existing GN targets are kept and now just forward to the moved ones using public_deps. The only exception to the above is the base_java target and its .java files, which were moved to webrtc/rtc_base right away since it's not possible to use public_deps for android_library. To avoid breaking builds, a temporary Dummy.java file was added to the new intermediate target in webrtc/rtc_base:base_java as well to avoid hitting a GN assert in the android_library template. The above approach should make the transition smooth without breaking downstream. A helper script was created (https://codereview.webrtc.org/2879203002/) and was run like this: stub-headers.py -s webrtc/base -d webrtc/rtc_base -i 7634 stub-headers.py -s webrtc/base/numerics -d webrtc/rtc_base/numerics -i 7634 Fixed invalid header guards in the following files: webrtc/base/base64.h webrtc/base/cryptstring.h webrtc/base/event.h webrtc/base/flags.h webrtc/base/httpbase.h webrtc/base/httpcommon-inl.h webrtc/base/httpcommon.h webrtc/base/httpserver.h webrtc/base/logsinks.h webrtc/base/macutils.h webrtc/base/nattypes.h webrtc/base/openssladapter.h webrtc/base/opensslstreamadapter.h webrtc/base/pathutils.h webrtc/base/physicalsocketserver.h webrtc/base/proxyinfo.h webrtc/base/sigslot.h webrtc/base/sigslotrepeater.h webrtc/base/socket.h webrtc/base/socketaddresspair.h webrtc/base/socketfactory.h webrtc/base/stringutils.h webrtc/base/testbase64.h webrtc/base/testutils.h webrtc/base/transformadapter.h webrtc/base/win32filesystem.h Added new header guards to: sslroots.h testbase64.h BUG=webrtc:7634 NOTRY=True NOPRESUBMIT=True R=kwiberg@webrtc.org Review-Url: https://codereview.webrtc.org/2877023002 . Cr-Commit-Position: refs/heads/master@{#18816}
99 lines
3.0 KiB
C++
99 lines
3.0 KiB
C++
/*
|
|
* Copyright 2010 The WebRTC 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 in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include <string>
|
|
|
|
#include "webrtc/base/gunit.h"
|
|
#include "webrtc/base/nethelpers.h"
|
|
#include "webrtc/base/win32.h"
|
|
|
|
#if !defined(WEBRTC_WIN)
|
|
#error Only for Windows
|
|
#endif
|
|
|
|
namespace rtc {
|
|
|
|
class Win32Test : public testing::Test {
|
|
public:
|
|
Win32Test() {
|
|
}
|
|
};
|
|
|
|
TEST_F(Win32Test, FileTimeToUInt64Test) {
|
|
FILETIME ft;
|
|
ft.dwHighDateTime = 0xBAADF00D;
|
|
ft.dwLowDateTime = 0xFEED3456;
|
|
|
|
uint64_t expected = 0xBAADF00DFEED3456;
|
|
EXPECT_EQ(expected, ToUInt64(ft));
|
|
}
|
|
|
|
TEST_F(Win32Test, IPv6AddressCompression) {
|
|
IPAddress ipv6;
|
|
|
|
// Zero compression should be done on the leftmost 0s when there are
|
|
// multiple longest series.
|
|
ASSERT_TRUE(IPFromString("2a00:8a00:a000:1190:0000:0001:000:252", &ipv6));
|
|
EXPECT_EQ("2a00:8a00:a000:1190::1:0:252", ipv6.ToString());
|
|
|
|
// Ensure the zero compression could handle multiple octects.
|
|
ASSERT_TRUE(IPFromString("0:0:0:0:0:0:0:1", &ipv6));
|
|
EXPECT_EQ("::1", ipv6.ToString());
|
|
|
|
// Make sure multiple 0 octects compressed.
|
|
ASSERT_TRUE(IPFromString("fe80:0:0:0:2aa:ff:fe9a:4ca2", &ipv6));
|
|
EXPECT_EQ("fe80::2aa:ff:fe9a:4ca2", ipv6.ToString());
|
|
|
|
// Test zero compression at the end of string.
|
|
ASSERT_TRUE(IPFromString("2a00:8a00:a000:1190:0000:0001:000:00", &ipv6));
|
|
EXPECT_EQ("2a00:8a00:a000:1190:0:1::", ipv6.ToString());
|
|
|
|
// Test zero compression at the beginning of string.
|
|
ASSERT_TRUE(IPFromString("0:0:000:1190:0000:0001:000:00", &ipv6));
|
|
EXPECT_EQ("::1190:0:1:0:0", ipv6.ToString());
|
|
|
|
// Test zero compression only done once.
|
|
ASSERT_TRUE(IPFromString("0:1:000:1190:0000:0001:000:01", &ipv6));
|
|
EXPECT_EQ("::1:0:1190:0:1:0:1", ipv6.ToString());
|
|
|
|
// Make sure noncompressable IPv6 is the same.
|
|
ASSERT_TRUE(IPFromString("1234:5678:abcd:1234:5678:abcd:1234:5678", &ipv6));
|
|
EXPECT_EQ("1234:5678:abcd:1234:5678:abcd:1234:5678", ipv6.ToString());
|
|
}
|
|
|
|
// Test that invalid IPv6 addresses are recognized and false is returned.
|
|
TEST_F(Win32Test, InvalidIPv6AddressParsing) {
|
|
IPAddress ipv6;
|
|
|
|
// More than 1 run of "::"s.
|
|
EXPECT_FALSE(IPFromString("1::2::3", &ipv6));
|
|
|
|
// More than 1 run of "::"s in a longer address.
|
|
// See: https://bugs.chromium.org/p/webrtc/issues/detail?id=7592
|
|
EXPECT_FALSE(IPFromString("1::2::3::4::5::6::7::8", &ipv6));
|
|
|
|
// Three ':'s in a row.
|
|
EXPECT_FALSE(IPFromString("1:::2", &ipv6));
|
|
|
|
// Non-hex character.
|
|
EXPECT_FALSE(IPFromString("test::1", &ipv6));
|
|
|
|
// More than 4 hex digits per group.
|
|
EXPECT_FALSE(IPFromString("abcde::1", &ipv6));
|
|
|
|
// More than 8 groups.
|
|
EXPECT_FALSE(IPFromString("1:2:3:4:5:6:7:8:9", &ipv6));
|
|
|
|
// Less than 8 groups.
|
|
EXPECT_FALSE(IPFromString("1:2:3:4:5:6:7", &ipv6));
|
|
}
|
|
|
|
} // namespace rtc
|