Update API for Objective-C RTCConfiguration.
BUG=
Review URL: https://codereview.webrtc.org/1616303002
Cr-Commit-Position: refs/heads/master@{#11386}
diff --git a/webrtc/api/objctests/RTCConfigurationTest.mm b/webrtc/api/objctests/RTCConfigurationTest.mm
new file mode 100644
index 0000000..429ce11
--- /dev/null
+++ b/webrtc/api/objctests/RTCConfigurationTest.mm
@@ -0,0 +1,118 @@
+/*
+ * Copyright 2015 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.
+ */
+
+#import <Foundation/Foundation.h>
+
+#include <vector>
+
+#include "webrtc/base/gunit.h"
+
+#import "webrtc/api/objc/RTCConfiguration.h"
+#import "webrtc/api/objc/RTCConfiguration+Private.h"
+#import "webrtc/api/objc/RTCIceServer.h"
+#import "webrtc/base/objc/NSString+StdString.h"
+
+@interface RTCConfigurationTest : NSObject
+- (void)testConversionToNativeConfiguration;
+- (void)testInitFromNativeConfiguration;
+@end
+
+@implementation RTCConfigurationTest
+
+- (void)testConversionToNativeConfiguration {
+ NSArray *urlStrings = @[ @"stun:stun1.example.net" ];
+ RTCIceServer *server = [[RTCIceServer alloc] initWithURLStrings:urlStrings];
+
+ RTCConfiguration *config =
+ [[RTCConfiguration alloc] initWithIceServers:@[ server ]
+ iceTransportPolicy:RTCIceTransportPolicyRelay
+ bundlePolicy:RTCBundlePolicyMaxBundle
+ rtcpMuxPolicy:RTCRtcpMuxPolicyNegotiate
+ tcpCandidatePolicy:RTCTcpCandidatePolicyDisabled
+ audioJitterBufferMaxPackets:60
+ iceConnectionReceivingTimeout:1
+ iceBackupCandidatePairPingInterval:2];
+
+ webrtc::PeerConnectionInterface::RTCConfiguration nativeConfig =
+ config.nativeConfiguration;
+ EXPECT_EQ(1u, nativeConfig.servers.size());
+ webrtc::PeerConnectionInterface::IceServer nativeServer =
+ nativeConfig.servers.front();
+ EXPECT_EQ(1u, nativeServer.urls.size());
+ EXPECT_EQ("stun:stun1.example.net", nativeServer.urls.front());
+
+ EXPECT_EQ(webrtc::PeerConnectionInterface::kRelay, nativeConfig.type);
+ EXPECT_EQ(webrtc::PeerConnectionInterface::kBundlePolicyMaxBundle,
+ nativeConfig.bundle_policy);
+ EXPECT_EQ(webrtc::PeerConnectionInterface::kRtcpMuxPolicyNegotiate,
+ nativeConfig.rtcp_mux_policy);
+ EXPECT_EQ(webrtc::PeerConnectionInterface::kTcpCandidatePolicyDisabled,
+ nativeConfig.tcp_candidate_policy);
+ EXPECT_EQ(60, nativeConfig.audio_jitter_buffer_max_packets);
+ EXPECT_EQ(1, nativeConfig.ice_connection_receiving_timeout);
+ EXPECT_EQ(2, nativeConfig.ice_backup_candidate_pair_ping_interval);
+}
+
+- (void)testInitFromNativeConfiguration {
+ webrtc::PeerConnectionInterface::RTCConfiguration nativeConfig;
+
+ webrtc::PeerConnectionInterface::IceServer nativeServer;
+ nativeServer.username = "username";
+ nativeServer.password = "password";
+ nativeServer.urls.push_back("stun:stun.example.net");
+ webrtc::PeerConnectionInterface::IceServers servers { nativeServer };
+
+ nativeConfig.servers = servers;
+ nativeConfig.type = webrtc::PeerConnectionInterface::kNoHost;
+ nativeConfig.bundle_policy =
+ webrtc::PeerConnectionInterface::kBundlePolicyMaxCompat;
+ nativeConfig.rtcp_mux_policy =
+ webrtc::PeerConnectionInterface::kRtcpMuxPolicyRequire;
+ nativeConfig.tcp_candidate_policy =
+ webrtc::PeerConnectionInterface::kTcpCandidatePolicyEnabled;
+ nativeConfig.audio_jitter_buffer_max_packets = 40;
+ nativeConfig.ice_connection_receiving_timeout =
+ webrtc::PeerConnectionInterface::RTCConfiguration::kUndefined;
+ nativeConfig.ice_backup_candidate_pair_ping_interval =
+ webrtc::PeerConnectionInterface::RTCConfiguration::kUndefined;
+
+ RTCConfiguration *config =
+ [[RTCConfiguration alloc] initWithNativeConfiguration:nativeConfig];
+
+ EXPECT_EQ(1u, config.iceServers.count);
+ RTCIceServer *server = config.iceServers.firstObject;
+ EXPECT_EQ(1u, server.urlStrings.count);
+ EXPECT_TRUE([@"stun:stun.example.net" isEqualToString:
+ server.urlStrings.firstObject]);
+
+ EXPECT_EQ(RTCIceTransportPolicyNoHost, config.iceTransportPolicy);
+ EXPECT_EQ(RTCBundlePolicyMaxCompat, config.bundlePolicy);
+ EXPECT_EQ(RTCRtcpMuxPolicyRequire, config.rtcpMuxPolicy);
+ EXPECT_EQ(RTCTcpCandidatePolicyEnabled, config.tcpCandidatePolicy);
+ EXPECT_EQ(40, config.audioJitterBufferMaxPackets);
+ EXPECT_EQ(-1, config.iceConnectionReceivingTimeout);
+ EXPECT_EQ(-1, config.iceBackupCandidatePairPingInterval);
+}
+
+@end
+
+TEST(RTCConfigurationTest, NativeConfigurationConversionTest) {
+ @autoreleasepool {
+ RTCConfigurationTest *test = [[RTCConfigurationTest alloc] init];
+ [test testConversionToNativeConfiguration];
+ }
+}
+
+TEST(RTCConfigurationTest, InitFromConfigurationTest) {
+ @autoreleasepool {
+ RTCConfigurationTest *test = [[RTCConfigurationTest alloc] init];
+ [test testInitFromNativeConfiguration];
+ }
+}