webrtc_m130/media/base/turnutils_unittest.cc

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

121 lines
4.6 KiB
C++
Raw Normal View History

/*
* Copyright (c) 2016 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.
*/
Move talk/media to webrtc/media I removed the 'libjingle' target in talk/libjingle.gyp and replaced all users of it with base/base.gyp:rtc_base. It seems the jsoncpp and expat dependencies were not used by it's previous references. The files in talk/media/testdata were uploaded to Google Storage and added .sha1 files in resources/media instead of simply moving them. The previously disabled warnings that were inherited from talk/build/common.gypi are now replaced by target-specific disabling of only the failing warnings. Additional disabling was needed since the stricter compilation warnings that applies to code in webrtc/. License headers will be updated in a follow-up CL in order to not break Git history. Other modifications: * Updated the header guards. * Sorted the includes using chromium/src/tools/sort-headers.py except for these files: talk/app/webrtc/peerconnectionendtoend_unittest.cc talk/app/webrtc/java/jni/androidmediadecoder_jni.cc talk/app/webrtc/java/jni/androidmediaencoder_jni.cc webrtc/media/devices/win32devicemanager.cc. * Unused GYP reference to libjingle_tests_additional_deps was removed. * Removed duplicated GYP entries of webrtc/base/testutils.cc webrtc/base/testutils.h The HAVE_WEBRTC_VIDEO and HAVE_WEBRTC_VOICE defines were used by only talk/media, so they were moved to the media.gyp. I also checked that none of EXPAT_RELATIVE_PATH, FEATURE_ENABLE_VOICEMAIL, GTEST_RELATIVE_PATH, JSONCPP_RELATIVE_PATH, LOGGING=1, SRTP_RELATIVE_PATH, FEATURE_ENABLE_SSL, FEATURE_ENABLE_VOICEMAIL, FEATURE_ENABLE_PSTN, HAVE_SCTP, HAVE_SRTP, are used by the talk/media code. For Chromium, the following changes will need to be applied to the roll CL that updates the DEPS for WebRTC and libjingle: https://codereview.chromium.org/1604303002/ BUG=webrtc:5420 NOPRESUBMIT=True TBR=tommi@webrtc.org Review URL: https://codereview.webrtc.org/1587193006 Cr-Commit-Position: refs/heads/master@{#11495}
2016-02-04 23:52:28 -08:00
#include "webrtc/media/base/turnutils.h"
#include <stddef.h>
#include "webrtc/rtc_base/gunit.h"
namespace cricket {
// Invalid TURN send indication messages. Messages are proper STUN
// messages with incorrect values in attributes.
TEST(TurnUtilsTest, InvalidTurnSendIndicationMessages) {
size_t content_pos = SIZE_MAX;
size_t content_size = SIZE_MAX;
// Stun Indication message with Zero length
uint8_t kTurnSendIndicationMsgWithNoAttributes[] = {
0x00, 0x16, 0x00, 0x00, // Zero length
0x21, 0x12, 0xA4, 0x42, // magic cookie
'0', '1', '2', '3', // transaction id
'4', '5', '6', '7', '8', '9', 'a', 'b',
};
EXPECT_FALSE(UnwrapTurnPacket(kTurnSendIndicationMsgWithNoAttributes,
sizeof(kTurnSendIndicationMsgWithNoAttributes),
&content_pos, &content_size));
EXPECT_EQ(SIZE_MAX, content_pos);
EXPECT_EQ(SIZE_MAX, content_size);
// Stun Send Indication message with invalid length in stun header.
const uint8_t kTurnSendIndicationMsgWithInvalidLength[] = {
0x00, 0x16, 0xFF, 0x00, // length of 0xFF00
0x21, 0x12, 0xA4, 0x42, // magic cookie
'0', '1', '2', '3', // transaction id
'4', '5', '6', '7', '8', '9', 'a', 'b',
};
EXPECT_FALSE(UnwrapTurnPacket(kTurnSendIndicationMsgWithInvalidLength,
sizeof(kTurnSendIndicationMsgWithInvalidLength),
&content_pos, &content_size));
EXPECT_EQ(SIZE_MAX, content_pos);
EXPECT_EQ(SIZE_MAX, content_size);
// Stun Send Indication message with no DATA attribute in message.
const uint8_t kTurnSendIndicatinMsgWithNoDataAttribute[] = {
0x00, 0x16, 0x00, 0x08, // length of
0x21, 0x12, 0xA4, 0x42, // magic cookie
'0', '1', '2', '3', // transaction id
'4', '5', '6', '7', '8', '9', 'a', 'b',
0x00, 0x20, 0x00, 0x04, // Mapped address.
0x00, 0x00, 0x00, 0x00,
};
EXPECT_FALSE(
UnwrapTurnPacket(kTurnSendIndicatinMsgWithNoDataAttribute,
sizeof(kTurnSendIndicatinMsgWithNoDataAttribute),
&content_pos, &content_size));
EXPECT_EQ(SIZE_MAX, content_pos);
EXPECT_EQ(SIZE_MAX, content_size);
}
// Valid TURN Send Indication messages.
TEST(TurnUtilsTest, ValidTurnSendIndicationMessage) {
size_t content_pos = SIZE_MAX;
size_t content_size = SIZE_MAX;
// A valid STUN indication message with a valid RTP header in data attribute
// payload field and no extension bit set.
const uint8_t kTurnSendIndicationMsgWithoutRtpExtension[] = {
0x00, 0x16, 0x00, 0x18, // length of
0x21, 0x12, 0xA4, 0x42, // magic cookie
'0', '1', '2', '3', // transaction id
'4', '5', '6', '7', '8', '9', 'a', 'b',
0x00, 0x20, 0x00, 0x04, // Mapped address.
0x00, 0x00, 0x00, 0x00,
0x00, 0x13, 0x00, 0x0C, // Data attribute.
0x80, 0x00, 0x00, 0x00, // RTP packet.
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
EXPECT_TRUE(UnwrapTurnPacket(
kTurnSendIndicationMsgWithoutRtpExtension,
sizeof(kTurnSendIndicationMsgWithoutRtpExtension), &content_pos,
&content_size));
EXPECT_EQ(12U, content_size);
EXPECT_EQ(32U, content_pos);
}
// Verify that parsing of valid TURN Channel Messages.
TEST(TurnUtilsTest, ValidTurnChannelMessages) {
const uint8_t kTurnChannelMsgWithRtpPacket[] = {
0x40, 0x00, 0x00, 0x0C,
0x80, 0x00, 0x00, 0x00, // RTP packet.
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
};
size_t content_pos = 0, content_size = 0;
EXPECT_TRUE(UnwrapTurnPacket(
kTurnChannelMsgWithRtpPacket,
sizeof(kTurnChannelMsgWithRtpPacket), &content_pos, &content_size));
EXPECT_EQ(12U, content_size);
EXPECT_EQ(4U, content_pos);
}
TEST(TurnUtilsTest, ChannelMessageZeroLength) {
const uint8_t kTurnChannelMsgWithZeroLength[] = {0x40, 0x00, 0x00, 0x00};
size_t content_pos = SIZE_MAX;
size_t content_size = SIZE_MAX;
EXPECT_TRUE(UnwrapTurnPacket(kTurnChannelMsgWithZeroLength,
sizeof(kTurnChannelMsgWithZeroLength),
&content_pos, &content_size));
EXPECT_EQ(4, content_pos);
EXPECT_EQ(0, content_size);
}
} // namespace cricket