--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/linklayercontrol/nullagt/TS_nullagt/src/Nullagentmultipleconnections.cpp Tue Jan 26 15:23:49 2010 +0200
@@ -0,0 +1,172 @@
+// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// Contain the implementation of the class for this null agent test
+//
+//
+
+#include "NullAgentTestSteps.h"
+#include "dummynifvar.h"
+#include "commdbconnpref.h"
+#include "in_sock.h"
+
+CTestStepNullAgtMultipleConnections::CTestStepNullAgtMultipleConnections(TPtrC aName)
+{
+ iTestStepName=aName;
+}
+
+enum TVerdict CTestStepNullAgtMultipleConnections::doTestStepL(void)
+{
+ __UHEAP_MARK;
+
+ TInt r; // the result of various operations
+ TRequestStatus status; // status of asynchronous ops
+
+ // connection paraphanelia, two of each
+ RSocketServ server1, server2;
+ RConnection connection1, connection2;
+ RSocket socket1, socket2;
+
+ TInetAddr dest;
+ dest.SetAddress(KDummyNifLocalAddressBase + 4);
+ dest.SetPort(KPortNo);
+
+ TBuf8<KBufferLength> buffer;
+
+ // as ever we need a socket server to create connections...
+ r = server1.Connect();
+ TESTEL(r == KErrNone, r);
+ CleanupClosePushL(server1);
+ // let's have two
+ r = server2.Connect();
+ TESTEL(r == KErrNone, r);
+ CleanupClosePushL(server2);
+
+ // create the first (default connection using commdb settings)
+ // Which according to connetion preferences, the one with ranking 1
+ // is IAP 5
+ r = connection1.Open(server1, KAfInet);
+ TESTEL(r == KErrNone, r);
+ CleanupClosePushL(connection1);
+
+ // create the second connection (overrides this time)
+ // on the same IAP, ie IAP5
+ r = connection2.Open(server2, KAfInet);
+ TESTEL(r == KErrNone, r);
+ // Don't push this connection as it will be stopped by connection1
+
+ // create the overrides
+ TCommDbConnPref prefs;
+ prefs.SetIapId(5);
+ prefs.SetDialogPreference(ECommDbDialogPrefDoNotPrompt);
+
+ connection1.Start(status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+
+ // start the connection with the overrides
+ connection2.Start(prefs, status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+
+ // open a socket over the first connection
+ r = socket1.Open(server1, KAfInet, KSockDatagram, KProtocolInetUdp);
+ TESTEL(r == KErrNone, r);
+ CleanupClosePushL(socket1);
+ TESTL(socket1.SetOpt(KSoReuseAddr, KSolInetIp, 1)==KErrNone);
+ // set the source port number
+ r = socket1.SetLocalPort(KPortNo);
+ TESTEL(r == KErrNone, r);
+
+ // open a socket over the second connection
+ r = socket2.Open(server2, KAfInet, KSockDatagram, KProtocolInetUdp);
+ TESTEL(r == KErrNone, r);
+ CleanupClosePushL(socket2);
+ TESTL(socket2.SetOpt(KSoReuseAddr, KSolInetIp, 1)==KErrNone);
+ // set the source port number - otherwise will panic cos it's zero
+ r = socket2.SetLocalPort(KPortNo);
+ TESTEL(r == KErrNone, r);
+
+ // build some data to send on the socket
+ buffer.SetMax();
+ buffer.FillZ();
+ buffer[0] = (TUint8) 0x8;
+ buffer[1] = (TUint8) 0x0;
+ buffer[2] = (TUint8) 0xF7;
+ buffer[3] = (TUint8) 0xFF;
+
+ // send the data out the first socket
+ socket1.SendTo(buffer, dest, 0, status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+
+ buffer.Zero();
+ // I expect to get the data looped back from the dummy NIF
+ socket1.RecvFrom(buffer, dest, 0, status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+
+ if (status.Int() == KErrNone)
+ {
+ // if the receive times out and we access buffer we get a panic
+ TESTL(buffer[0] == 0x08);
+ TESTL(buffer[1] == 0x00);
+ TESTL(buffer[2] == 0xF7);
+ TESTL(buffer[3] == 0xFF);
+ }
+
+ // send the same data out over the second socket
+ socket2.SendTo(buffer, dest, 0, status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+
+ buffer.Zero();
+ // again, I expect it to be looped back by the dummy NIF
+ socket2.RecvFrom(buffer, dest, 0, status);
+ User::WaitForRequest(status);
+
+ if (status.Int() == KErrNone)
+ {
+ // if the receive times out and we access buffer we get a panic
+ TESTL(buffer[0] == 0x08);
+ TESTL(buffer[1] == 0x00);
+ TESTL(buffer[2] == 0xF7);
+ TESTL(buffer[3] == 0xFF);
+ }
+
+ // close down both of the sockets
+ socket2.Shutdown(RSocket::ENormal, status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+ CleanupStack::Pop();
+ socket1.Shutdown(RSocket::ENormal, status);
+ User::WaitForRequest(status);
+ TESTEL(status.Int() == KErrNone, status.Int());
+ CleanupStack::Pop();
+
+ // Stop only connection1, as this points to the same IAP
+ // as connection2
+ r = connection1.Stop();
+ TESTEL(r == KErrNone, r);
+ CleanupStack::Pop();
+
+ // close the socket servers
+ server2.Close();
+ CleanupStack::Pop();
+ server1.Close();
+ CleanupStack::Pop();
+
+ __UHEAP_MARKEND;
+
+ return iTestStepResult;
+}