|
1 /* |
|
2 * Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). |
|
3 * All rights reserved. |
|
4 * This component and the accompanying materials are made available |
|
5 * under the terms of "Eclipse Public License v1.0" |
|
6 * which accompanies this distribution, and is available |
|
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
8 * |
|
9 * Initial Contributors: |
|
10 * Nokia Corporation - initial contribution. |
|
11 * |
|
12 * Contributors: |
|
13 * |
|
14 * Description: |
|
15 * |
|
16 */ |
|
17 |
|
18 #include <ss_glob.h> |
|
19 #include <comms-infras/ss_thread.h> |
|
20 #include <comms-infras/ss_nodemessages_factory.h> |
|
21 #include <comms-infras/ss_nodemessages_dataclient.h> |
|
22 #include "ptcpservertests.h" |
|
23 #include "upnp_cf_msgs.h" |
|
24 #include "upnpflowbase.h" |
|
25 #include "upnpflowfactory.h" |
|
26 #include "CTcpServerTestCase.h" |
|
27 |
|
28 #include <httperr.h> |
|
29 #include "CTcpServerTestUPnP34.h" |
|
30 |
|
31 using namespace Messages; |
|
32 |
|
33 //------------------------------------------------------------// |
|
34 /////////////////// CTcpServerTestUPnP34 ///////////////////////// |
|
35 ////// Testcase: Send the test data from the test client///////// |
|
36 //------------------------------------------------------------// |
|
37 |
|
38 _LIT8 ( KTestUPnPServiceUri,"http://127.0.0.1:80/testserviceuri1" ); |
|
39 _LIT8 ( KData, "UNSUBSCRIBE /testserviceuri1 HTTP/1.1\r\nHOST: 127.0.0.1:80\r\nSID: testserviceuri1\r\nNT: upnp:event\r\n\r\n"); |
|
40 _LIT8 ( KExpectedResponse, "HTTP/1.1 400 Bad Request"); |
|
41 |
|
42 CTcpServerTestUPnP34* CTcpServerTestUPnP34::NewL ( CProxyProvd* aProvd ) |
|
43 { |
|
44 CTcpServerTestUPnP34* ret = new ( ELeave ) CTcpServerTestUPnP34 ( aProvd ); |
|
45 CleanupStack::PushL ( ret ); |
|
46 ret->ConstructL (); |
|
47 CleanupStack::Pop ( ret ); |
|
48 return ret; |
|
49 } |
|
50 |
|
51 CTcpServerTestUPnP34::CTcpServerTestUPnP34 ( CProxyProvd* aProvd ) : |
|
52 CTcpServerTestCase ( aProvd ) |
|
53 { |
|
54 } |
|
55 |
|
56 CTcpServerTestUPnP34::~CTcpServerTestUPnP34 () |
|
57 { |
|
58 |
|
59 } |
|
60 |
|
61 void CTcpServerTestUPnP34::ConstructL () |
|
62 { |
|
63 CTcpServerTestCase::ConstructL(KTestUPnPServiceUri); |
|
64 } |
|
65 |
|
66 TVerdict CTcpServerTestUPnP34::RunTestL () |
|
67 { |
|
68 switch ( iState ) |
|
69 { |
|
70 |
|
71 case ESendData: |
|
72 { |
|
73 iSendChain.CreateL ( KData ); |
|
74 iSocketHandler.Send ( iSendChain ); |
|
75 |
|
76 iState = ESendStopServer; |
|
77 iStatus = KRequestPending; |
|
78 Reschedule (); |
|
79 return EPass; |
|
80 } |
|
81 |
|
82 default: |
|
83 { |
|
84 return CTcpServerTestCase::RunTestL(); |
|
85 } |
|
86 } |
|
87 } |
|
88 |
|
89 |
|
90 void CTcpServerTestUPnP34::RecvComplete ( RMBufChain& aData ) |
|
91 { |
|
92 RBuf8 responseBuf; |
|
93 responseBuf.CreateMax ( aData.Length () ); |
|
94 aData.CopyOut ( responseBuf ); |
|
95 aData.Free (); |
|
96 |
|
97 if ( responseBuf.FindF ( KExpectedResponse ) == KErrNotFound ) |
|
98 { |
|
99 iResponse = EFail; // test case failed |
|
100 } |
|
101 else |
|
102 { |
|
103 iResponse = EPass; // test case passed |
|
104 } |
|
105 |
|
106 responseBuf.Close (); |
|
107 CompleteSelf ( KErrNone ); |
|
108 } |
|
109 |
|
110 //------------------------------------------------------------------------------------ |
|
111 _LIT8 ( KTestUPnPServiceUri1,"http://127.0.0.1:80/testserviceuri1" ); |
|
112 _LIT8 ( KPartialData, "POST /testserviceuri1 HTTP/1.1\r\nHOST: 127.0.0.1:80\r\nContent-Length: 10\r\n\r\n"); |
|
113 |
|
114 CTcpServerTestUPnP35* CTcpServerTestUPnP35::NewL ( CProxyProvd* aProvd ) |
|
115 { |
|
116 CTcpServerTestUPnP35* ret = new ( ELeave ) CTcpServerTestUPnP35 ( aProvd ); |
|
117 CleanupStack::PushL ( ret ); |
|
118 ret->ConstructL (); |
|
119 CleanupStack::Pop ( ret ); |
|
120 return ret; |
|
121 } |
|
122 |
|
123 CTcpServerTestUPnP35::CTcpServerTestUPnP35 ( CProxyProvd* aProvd ) : |
|
124 CTcpServerTestCase ( aProvd ) |
|
125 { |
|
126 } |
|
127 |
|
128 CTcpServerTestUPnP35::~CTcpServerTestUPnP35 () |
|
129 { |
|
130 } |
|
131 |
|
132 void CTcpServerTestUPnP35::ConstructL () |
|
133 { |
|
134 CTcpServerTestCase::ConstructL(KTestUPnPServiceUri1); |
|
135 } |
|
136 |
|
137 TVerdict CTcpServerTestUPnP35::RunTestL () |
|
138 { |
|
139 switch ( iState ) |
|
140 { |
|
141 case ESendData: |
|
142 { |
|
143 //iSendChain.CreateL ( KData1 ); |
|
144 iSendChain.CreateL ( KPartialData ); |
|
145 iSocketHandler.Send ( iSendChain ); |
|
146 |
|
147 iState = EStartTimer; |
|
148 iStatus = KRequestPending; |
|
149 Reschedule (); |
|
150 return EPass; |
|
151 } |
|
152 case EStartTimer: |
|
153 { |
|
154 const TUint KTimeOutVal = 31000000; // 31secs |
|
155 iTimer.After ( iStatus, KTimeOutVal ); |
|
156 iState = ETimerStopped; |
|
157 Reschedule (); |
|
158 return EPass; |
|
159 } |
|
160 case ETimerStopped: |
|
161 { |
|
162 iClientSocket.Close (); |
|
163 iState = ESendStopServer; |
|
164 CTcpServerTestCase::RunTestL (); |
|
165 return EPass; |
|
166 } |
|
167 default: |
|
168 { |
|
169 return CTcpServerTestCase::RunTestL(); |
|
170 } |
|
171 } |
|
172 } |
|
173 |
|
174 void CTcpServerTestUPnP35::SendComplete ( TInt /*aLength*/ ) |
|
175 { |
|
176 iSendChain.Init (); |
|
177 CompleteSelf ( KErrNone ); |
|
178 } |
|
179 |
|
180 void CTcpServerTestUPnP35::RecvComplete ( RMBufChain& /*aData*/ ) |
|
181 { |
|
182 // will not reach here, since after sending partial data & socket is closed |
|
183 } |
|
184 |
|
185 //------------------------------------------------------------------------------------ |
|
186 // KTestUPnPServiceUri1 -- same as above |
|
187 // KPartialData -- same as above |
|
188 _LIT8 ( KExpectedResponse1, "HTTP/1.1 408 Request Timeout"); |
|
189 |
|
190 CTcpServerTestUPnP36* CTcpServerTestUPnP36::NewL ( CProxyProvd* aProvd ) |
|
191 { |
|
192 CTcpServerTestUPnP36* ret = new ( ELeave ) CTcpServerTestUPnP36 ( aProvd ); |
|
193 CleanupStack::PushL ( ret ); |
|
194 ret->ConstructL (); |
|
195 CleanupStack::Pop ( ret ); |
|
196 return ret; |
|
197 } |
|
198 |
|
199 CTcpServerTestUPnP36::CTcpServerTestUPnP36 ( CProxyProvd* aProvd ) : |
|
200 CTcpServerTestCase ( aProvd ) |
|
201 { |
|
202 } |
|
203 |
|
204 CTcpServerTestUPnP36::~CTcpServerTestUPnP36 () |
|
205 { |
|
206 } |
|
207 |
|
208 void CTcpServerTestUPnP36::ConstructL () |
|
209 { |
|
210 CTcpServerTestCase::ConstructL(KTestUPnPServiceUri1); |
|
211 } |
|
212 |
|
213 TVerdict CTcpServerTestUPnP36::RunTestL () |
|
214 { |
|
215 switch ( iState ) |
|
216 { |
|
217 case ESendData: |
|
218 { |
|
219 iSendChain.CreateL ( KPartialData ); |
|
220 iSocketHandler.Send ( iSendChain ); |
|
221 |
|
222 iState = ESendStopServer; |
|
223 iStatus = KRequestPending; |
|
224 Reschedule (); |
|
225 return EPass; |
|
226 } |
|
227 default: |
|
228 { |
|
229 return CTcpServerTestCase::RunTestL(); |
|
230 } |
|
231 } |
|
232 } |
|
233 |
|
234 void CTcpServerTestUPnP36::RecvComplete ( RMBufChain& aData ) |
|
235 { |
|
236 // will reach here, after sending partial, and should 408 status code |
|
237 RBuf8 responseBuf; |
|
238 responseBuf.CreateMax ( aData.Length () ); |
|
239 aData.CopyOut ( responseBuf ); |
|
240 aData.Free (); |
|
241 |
|
242 if ( responseBuf.FindF ( KExpectedResponse1 ) == KErrNotFound ) |
|
243 { |
|
244 iResponse = EFail; // test case failed |
|
245 } |
|
246 else |
|
247 { |
|
248 iResponse = EPass; // test case passed |
|
249 } |
|
250 |
|
251 responseBuf.Close (); |
|
252 CompleteSelf ( KErrNone ); |
|
253 } |
|
254 |
|
255 //------------------------------------------------------------------------------------ |
|
256 // KTestUPnPServiceUri1 -- same as above |
|
257 _LIT8 ( KData1, "GET /testserviceuri1 HTTP/1.1\r\nHOST: 127.0.0.1:80\r\nContent-Length: 0\r\nConnection: close\r\n\r\n" ); |
|
258 // KExpectedResponse1,-- same above |
|
259 _LIT8 ( KBodyData, "ppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppvppppppppppppppppppppppppppppppppppppvppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppvppppppppppppppppppppppppppppppppppppvppppppppppppppppppppppppppppppppppppvvppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppvvppppppppppppppppppppppppppppppppppppvvppppppppppppppppppppppppppppppppppppvpppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp" ); |
|
260 |
|
261 CTcpServerTestUPnP37* CTcpServerTestUPnP37::NewL ( CProxyProvd* aProvd ) |
|
262 { |
|
263 CTcpServerTestUPnP37* ret = new ( ELeave ) CTcpServerTestUPnP37 ( aProvd ); |
|
264 CleanupStack::PushL ( ret ); |
|
265 ret->ConstructL (); |
|
266 CleanupStack::Pop ( ret ); |
|
267 return ret; |
|
268 } |
|
269 |
|
270 CTcpServerTestUPnP37::CTcpServerTestUPnP37 ( CProxyProvd* aProvd ) : |
|
271 CTcpServerTestCase ( aProvd ) |
|
272 { |
|
273 } |
|
274 |
|
275 CTcpServerTestUPnP37::~CTcpServerTestUPnP37 () |
|
276 { |
|
277 iResponseBuf.Close (); |
|
278 } |
|
279 |
|
280 void CTcpServerTestUPnP37::ConstructL () |
|
281 { |
|
282 CTcpServerTestCase::ConstructL(KTestUPnPServiceUri1); |
|
283 iUPnPTimer = CUPnPTimer::NewL ( *this ); |
|
284 } |
|
285 |
|
286 TVerdict CTcpServerTestUPnP37::RunTestL () |
|
287 { |
|
288 switch ( iState ) |
|
289 { |
|
290 case ESendData: |
|
291 { |
|
292 iSendChain.CreateL ( KData1 ); |
|
293 iSocketHandler.Send ( iSendChain ); |
|
294 |
|
295 iState = ESendStopServer; |
|
296 iStatus = KRequestPending; |
|
297 Reschedule (); |
|
298 return EPass; |
|
299 } |
|
300 default: |
|
301 { |
|
302 return CTcpServerTestCase::RunTestL(); |
|
303 } |
|
304 } |
|
305 } |
|
306 |
|
307 void CTcpServerTestUPnP37::RecvComplete ( RMBufChain& aData ) |
|
308 { |
|
309 RBuf8 partialBuf; |
|
310 partialBuf.CreateMax ( aData.Length () ); |
|
311 aData.CopyOut ( partialBuf ); |
|
312 aData.Free (); |
|
313 |
|
314 _LIT8 ( KContentLength, "\r\n\r\n" ); |
|
315 if ( partialBuf.Find ( KContentLength ) != KErrNotFound ) |
|
316 { |
|
317 TRAP_IGNORE(iResponseBuf.CreateL ( KBodyData ().Length () )); |
|
318 } |
|
319 else |
|
320 { |
|
321 iResponseBuf.Append ( partialBuf ); |
|
322 } |
|
323 partialBuf.Close (); |
|
324 |
|
325 if ( iResponseBuf.Length () != KBodyData ().Length () ) |
|
326 { |
|
327 iSocketHandler.Recv (); |
|
328 } |
|
329 else |
|
330 { |
|
331 CompleteSelf ( KErrNone ); |
|
332 } |
|
333 } |
|
334 |
|
335 void CTcpServerTestUPnP37::ReceivedL ( const TRuntimeCtxId& aSender, const TNodeId& aRecipient, TSignatureBase& aMessage ) |
|
336 { |
|
337 if ( aMessage.IsMessage<TUpnpMessage::TUPnPRequestInfo> () ) |
|
338 { |
|
339 TUpnpMessage::TUPnPRequestInfo& requestMsg = message_cast< TUpnpMessage::TUPnPRequestInfo > ( aMessage ); |
|
340 iTransaction = static_cast<CTransaction*> ( requestMsg.iPtr ); |
|
341 const TUint KTimeOutVal = 30000000; // 30secs |
|
342 iUPnPTimer->StartTimer ( KTimeOutVal ); |
|
343 } |
|
344 else |
|
345 { |
|
346 CTcpServerTestCase::ReceivedL ( aSender, aRecipient,aMessage ); |
|
347 } |
|
348 } |
|
349 |
|
350 void CTcpServerTestUPnP37::TimeOut () |
|
351 { |
|
352 SendResponseToServerFlow (); |
|
353 } |
|
354 |
|
355 void CTcpServerTestUPnP37::SendResponseToServerFlow () |
|
356 { |
|
357 RMBufChain dataChian; |
|
358 TRAP_IGNORE(dataChian.CreateL( KBodyData )); |
|
359 iTransaction->AddBodyPart( dataChian ); |
|
360 RClientInterface::OpenPostMessageClose ( NodeId (), iTcpServer, |
|
361 TUpnpMessage::TUPnPResponseInfo ( iTransaction, HTTPStatus::EOk, NULL ).CRef () ); |
|
362 } |
|
363 |
|
364 |
|
365 |
|
366 |
|
367 |
|
368 |
|
369 |
|
370 |
|
371 |