|
1 // Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies). |
|
2 // All rights reserved. |
|
3 // This component and the accompanying materials are made available |
|
4 // under the terms of "Eclipse Public License v1.0" |
|
5 // which accompanies this distribution, and is available |
|
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
7 // |
|
8 // Initial Contributors: |
|
9 // Nokia Corporation - initial contribution. |
|
10 // |
|
11 // Contributors: |
|
12 // |
|
13 // Description: |
|
14 // |
|
15 |
|
16 /** |
|
17 @file |
|
18 @test |
|
19 @internalComponent - Internal Symbian test code |
|
20 */ |
|
21 #include "temergencycallrf_adaptationplugin_step.h" |
|
22 #include <test/susadaptionclisrv.h> |
|
23 |
|
24 #include <e32debug.h> |
|
25 |
|
26 const TInt KAsyncMessageSlots = -1; // Taken from ssmadaptationcli.cpp |
|
27 |
|
28 |
|
29 /** */ |
|
30 CEmergencyAdaptPlugin* CEmergencyAdaptPlugin::NewL(CTestEmergencyAdaptStep& aTestEmergencyAdaptStep) |
|
31 { |
|
32 CEmergencyAdaptPlugin* self = new(ELeave) CEmergencyAdaptPlugin(aTestEmergencyAdaptStep); |
|
33 CleanupStack::PushL( self ); |
|
34 self->Construct(); |
|
35 CleanupStack::Pop(); |
|
36 return self; |
|
37 } |
|
38 |
|
39 /** */ |
|
40 void CEmergencyAdaptPlugin::CallCommandsOfAdaptation(TRequestStatus& aStatus,TTestSusEmergencyCallAdaptionServerRequests aRequest) |
|
41 { |
|
42 aStatus = KRequestPending; |
|
43 iEmergencyStatus = &aStatus; |
|
44 switch(aRequest) |
|
45 { |
|
46 case ETestActivateRfForEmergencyCall: |
|
47 iEmergencyAdaptation.ActivateRfForEmergencyCall(iStatus); |
|
48 SetActive(); |
|
49 break; |
|
50 case ETestDeactivateRfForEmergencyCall: |
|
51 iEmergencyAdaptation.DeactivateRfForEmergencyCall(iStatus); |
|
52 SetActive(); |
|
53 break; |
|
54 case ETestEmergencyCallRfActAndDeActCall: |
|
55 iEmergencyAdaptation.ActivateRfForEmergencyCall(iStatus); |
|
56 iEmergencyAdaptation.DeactivateRfForEmergencyCall(iStatus); |
|
57 SetActive(); |
|
58 break; |
|
59 default: |
|
60 User::Panic(KTCTestEmergencyAdaptStep, KErrArgument); |
|
61 } |
|
62 } |
|
63 |
|
64 /** */ |
|
65 CEmergencyAdaptPlugin::CEmergencyAdaptPlugin(CTestEmergencyAdaptStep& aTestEmergencyAdaptStep) |
|
66 :CActive(EPriorityStandard), iTestEmergencyAdaptStep(aTestEmergencyAdaptStep) |
|
67 { |
|
68 CActiveScheduler::Add(this); |
|
69 } |
|
70 |
|
71 /** */ |
|
72 CEmergencyAdaptPlugin::~CEmergencyAdaptPlugin() |
|
73 { |
|
74 Cancel(); |
|
75 iEmergencyAdaptation.Close(); |
|
76 } |
|
77 |
|
78 /** */ |
|
79 void CEmergencyAdaptPlugin::RunL() |
|
80 { |
|
81 iTestEmergencyAdaptStep.SetActivationCompleted(); |
|
82 User::LeaveIfError(iStatus.Int()); |
|
83 User::RequestComplete(iEmergencyStatus, iStatus.Int()); |
|
84 } |
|
85 |
|
86 /** */ |
|
87 void CEmergencyAdaptPlugin::DoCancel() |
|
88 { |
|
89 } |
|
90 |
|
91 /** */ |
|
92 TInt CEmergencyAdaptPlugin::RunError(TInt aError) |
|
93 { |
|
94 if (iEmergencyStatus) |
|
95 { |
|
96 User::RequestComplete(iEmergencyStatus, aError); |
|
97 } |
|
98 return KErrNone; |
|
99 } |
|
100 |
|
101 /** */ |
|
102 void CEmergencyAdaptPlugin::Construct() |
|
103 { |
|
104 iEmergencyAdaptation.Connect(); |
|
105 } |
|
106 |
|
107 |
|
108 /*************************************************** |
|
109 * RTestSsmEmergencyCallRfAdaptation functions * |
|
110 ****************************************************/ |
|
111 |
|
112 EXPORT_C TInt RTestSsmEmergencyCallRfAdaptation::Connect() |
|
113 { |
|
114 const TInt err = Connect(KAsyncMessageSlots); |
|
115 return err; |
|
116 } |
|
117 |
|
118 TInt RTestSsmEmergencyCallRfAdaptation::Connect(TInt aAsyncMessageSlotCount) |
|
119 { |
|
120 TInt err = RSsmAdaptationBase::Connect(aAsyncMessageSlotCount); |
|
121 if(err == KErrNone) |
|
122 { |
|
123 err = HeapMark(); |
|
124 } |
|
125 return err; |
|
126 } |
|
127 |
|
128 void RTestSsmEmergencyCallRfAdaptation::Close() |
|
129 { |
|
130 TInt ret = CleanupAdaptations(); |
|
131 __ASSERT_DEBUG(ret == KErrNone, User::Panic(_L("TESTSSMEMERCALL"), ret)); |
|
132 ret = HeapMarkEnd(); |
|
133 __ASSERT_DEBUG(ret == KErrNone, User::Panic(_L("TESTSSMEMERCALL"), ret)); |
|
134 RSsmAdaptationBase::Close(); |
|
135 } |
|
136 |
|
137 TInt RTestSsmEmergencyCallRfAdaptation::HeapMark() |
|
138 { |
|
139 TInt ret = KErrNone; |
|
140 if(Handle()) |
|
141 { |
|
142 ret = SendReceive(EDebugMarkHeap); |
|
143 } |
|
144 return ret; |
|
145 } |
|
146 |
|
147 TInt RTestSsmEmergencyCallRfAdaptation::HeapMarkEnd() |
|
148 { |
|
149 TInt ret = KErrNone; |
|
150 if(Handle()) |
|
151 { |
|
152 ret = SendReceive(EDebugMarkHeapEnd); |
|
153 } |
|
154 return ret; |
|
155 } |
|
156 |
|
157 TInt RTestSsmEmergencyCallRfAdaptation::CleanupAdaptations() |
|
158 { |
|
159 TInt ret = KErrNone; |
|
160 if(Handle()) |
|
161 { |
|
162 ret = SendReceive(EDebugCleanupAdaptations); |
|
163 } |
|
164 return ret; |
|
165 } |
|
166 |
|
167 /** */ |
|
168 CTestEmergencyAdaptStep::CTestEmergencyAdaptStep () |
|
169 { |
|
170 SetTestStepName(KTCTestEmergencyAdaptStep); |
|
171 } |
|
172 |
|
173 /** */ |
|
174 CTestEmergencyAdaptStep::~CTestEmergencyAdaptStep () |
|
175 { |
|
176 delete iEmergencyAdapt; |
|
177 delete iActiveScheduler; |
|
178 delete iAsyncStopScheduler; |
|
179 } |
|
180 /** |
|
181 Old Test CaseID APPFWK-SAS-0005 |
|
182 New Test CaseID DEVSRVS-SSPLUGINS-SAS-0005 |
|
183 */ |
|
184 |
|
185 void CTestEmergencyAdaptStep::TestEmergencyAdaptState() |
|
186 { |
|
187 for (TInt opcode = 0; opcode<=ETestEmergencyCallRfActAndDeActCall; ++opcode) |
|
188 { |
|
189 TRequestStatus trs; |
|
190 TTestSusEmergencyCallAdaptionServerRequests rfsType = static_cast<TTestSusEmergencyCallAdaptionServerRequests>(opcode); |
|
191 iEmergencyAdapt->CallCommandsOfAdaptation(trs,rfsType); |
|
192 //this callback will not run until the test is finished because it has priority idle |
|
193 iAsyncStopScheduler->CallBack(); |
|
194 iActiveScheduler->Start(); |
|
195 User::WaitForRequest(trs); |
|
196 iAdptTransitionCompleted = EFalse; |
|
197 RDebug::Print(_L("Status...%d"),trs.Int()); |
|
198 TInt res = trs.Int(); |
|
199 TEST(KErrNone == res); |
|
200 |
|
201 switch(rfsType) |
|
202 { |
|
203 case ETestActivateRfForEmergencyCall: |
|
204 INFO_PRINTF3(_L("TestActivateRfForEmergencyCall completed with %d error, Expected %d"),res,KErrNone); |
|
205 break; |
|
206 case ETestDeactivateRfForEmergencyCall: |
|
207 INFO_PRINTF3(_L("TestDeactivateRfForEmergencyCall completed with %d error, Expected %d"),res,KErrNone); |
|
208 break; |
|
209 case ETestEmergencyCallRfActAndDeActCall: |
|
210 INFO_PRINTF3(_L("TestEmergencyCallRfActAndDeActCall completed with %d error, Expected %d"),res,KErrNone); |
|
211 break; |
|
212 default: |
|
213 break; |
|
214 } |
|
215 } |
|
216 |
|
217 } |
|
218 |
|
219 /** |
|
220 Old Test CaseID APPFWK-SAS-0005 |
|
221 New Test CaseID DEVSRVS-SSPLUGINS-SAS-0005 |
|
222 */ |
|
223 |
|
224 void CTestEmergencyAdaptStep::TestEmergencyAdaptStateCancel() |
|
225 { |
|
226 //The following test case has been moved from TestEmergencyAdaptState() |
|
227 //since the test cases were failing only on NaviEngine. |
|
228 //In NaviEngine, the requests were executed much earlier than expected. |
|
229 //The test case expected the requests to be queued and then canceled. |
|
230 |
|
231 TRequestStatus tReq; |
|
232 TRequestStatus tReqCancel, tReqCancel1, tReqCancel2, tReqCancel3, tReqCancel4, tReqCancel5 ; |
|
233 |
|
234 RTestSsmEmergencyCallRfAdaptation callRfAdaptation; |
|
235 callRfAdaptation.Connect(); |
|
236 |
|
237 callRfAdaptation.ActivateRfForEmergencyCall(tReq); |
|
238 |
|
239 callRfAdaptation.DeactivateRfForEmergencyCall(tReqCancel); |
|
240 callRfAdaptation.DeactivateRfForEmergencyCall(tReqCancel1); |
|
241 callRfAdaptation.DeactivateRfForEmergencyCall(tReqCancel2); |
|
242 callRfAdaptation.DeactivateRfForEmergencyCall(tReqCancel3); |
|
243 callRfAdaptation.DeactivateRfForEmergencyCall(tReqCancel4); |
|
244 callRfAdaptation.DeactivateRfForEmergencyCall(tReqCancel5); |
|
245 |
|
246 callRfAdaptation.Cancel(); |
|
247 |
|
248 User::WaitForRequest(tReqCancel5); |
|
249 |
|
250 TEST(KErrCancel == tReqCancel5.Int()); |
|
251 |
|
252 callRfAdaptation.Close(); |
|
253 |
|
254 INFO_PRINTF3(_L("TestRequestCoopSysCancel completed with %d error , Expected %d "),tReqCancel5.Int(),KErrCancel); |
|
255 } |
|
256 |
|
257 /** */ |
|
258 TVerdict CTestEmergencyAdaptStep::doTestStepL() |
|
259 { |
|
260 iEmergencyAdapt = CEmergencyAdaptPlugin::NewL(*this); |
|
261 __UHEAP_MARK; |
|
262 INFO_PRINTF1(_L("TestEmergencyAdaptStep started")); |
|
263 TRAPD(err, TestEmergencyAdaptState()); |
|
264 TEST(err == KErrNone); |
|
265 INFO_PRINTF2(_L("TestEmergencyAdaptState completed with %d error "),err); |
|
266 TRAP(err, TestEmergencyAdaptStateCancel()); |
|
267 TEST(err == KErrNone); |
|
268 INFO_PRINTF2(_L("TestEmergencyAdaptStateCancel completed with %d error "),err); |
|
269 __UHEAP_MARKEND; |
|
270 |
|
271 return TestStepResult(); |
|
272 } |
|
273 |