sysstatemgmt/systemstateplugins/test/tintadptplugin/src/ti_adaptationplugin_stepbase.cpp
author hgs
Thu, 01 Jul 2010 11:20:10 +0300
changeset 41 c87e5f80c17d
parent 0 4e1aa6a622a0
child 61 8cb079868133
permissions -rw-r--r--
201025_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
41
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
     1
// Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies).
0
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     2
// All rights reserved.
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     3
// This component and the accompanying materials are made available
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     5
// which accompanies this distribution, and is available
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     7
//
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     8
// Initial Contributors:
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    10
//
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    11
// Contributors:
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    12
//
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    13
// Description:
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    14
//
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    15
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    16
/**
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    17
 @file
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    18
 @test
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    19
 @internalComponent - Internal Symbian test code 
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    20
*/
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    21
#include "ti_adaptationplugin_stepbase.h"
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    22
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    23
#include <e32debug.h>
41
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    24
#include <e32property.h>
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    25
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    26
_LIT (KExeToDefineTestPS, "\\sys\\bin\\definetestps.exe");
0
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    27
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    28
static TInt StopScheduler(TAny* aTestAdaptStep)
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    29
	{
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    30
	// We would stop the sceduler once all the required transitions are completed
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    31
	RDebug::Print(_L("Inside Stop Scheduler..."));
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    32
	CTestAdaptStep*  testAdaptStep = static_cast<CTestAdaptStep*>(aTestAdaptStep);
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    33
	testAdaptStep->StopActiveScheduler();
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    34
	return KErrNone;
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    35
	}
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    36
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    37
void CTestAdaptStep::StopActiveScheduler()
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    38
	{
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    39
	// We would stop the sceduler once all the required transitions are completed
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    40
	if (iAdptTransitionCompleted)
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    41
		{
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    42
		CActiveScheduler::Stop();
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    43
		}
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    44
	else
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    45
		{
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    46
		iAsyncStopScheduler->CallBack();
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    47
		}
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    48
	}
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    49
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    50
void CTestAdaptStep::SetActivationCompleted()
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    51
	{
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    52
	iAdptTransitionCompleted = ETrue;
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    53
	}
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    54
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    55
TVerdict CTestAdaptStep::doTestStepPreambleL()
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    56
	{
41
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    57
	RProcess processHandle;
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    58
	CleanupClosePushL(processHandle);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    59
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    60
	//Start the test exe which defines property keys for loading reference plugins
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    61
	    
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    62
	TInt err = processHandle.Create(KExeToDefineTestPS, KNullDesC);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    63
	INFO_PRINTF2(_L("Process creation returned : %d"), err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    64
	User::LeaveIfError(err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    65
	processHandle.Resume();
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    66
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    67
    // wait for the newly created process to rendezvous
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    68
    TRequestStatus status;
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    69
    processHandle.Rendezvous(status);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    70
    User::WaitForRequest(status);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    71
    TInt retVal = status.Int();
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    72
    INFO_PRINTF2(_L("iStatus.Int() returned : %d"), retVal);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    73
    TEST(KErrNone == retVal);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    74
    CleanupStack::PopAndDestroy();
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    75
    
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    76
	// Set all the property keys
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    77
	err = RProperty::Set(KPropertyCategory, KEmergencyCallRfAdaptationPluginPropertyKey, 1);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    78
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    79
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    80
	err = RProperty::Set(KPropertyCategory, KStateAdaptationPluginPropertyKey, 1);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    81
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    82
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    83
	err = RProperty::Set(KPropertyCategory, KRtcAdaptationPluginPropertyKey, 1);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    84
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    85
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    86
	err = RProperty::Set(KPropertyCategory, KSimPluginPropertyKey, 1);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    87
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    88
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    89
	err = RProperty::Set(KPropertyCategory, KMiscPluginPropertyKey, 1);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    90
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
    91
	
0
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    92
	INFO_PRINTF1(_L("Starting the scheduler in CTestEmergencyAdaptStep::doTestStepPreambleL ..."));
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    93
	iActiveScheduler = new(ELeave) CActiveScheduler;
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    94
	CActiveScheduler::Install (iActiveScheduler);
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    95
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    96
	iAsyncStopScheduler = new(ELeave) CAsyncCallBack(CActive::EPriorityIdle);
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    97
	TCallBack stop(StopScheduler, this);
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    98
	iAsyncStopScheduler->Set(stop);
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    99
	
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   100
	return CTestStep::doTestStepPreambleL();
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   101
	}
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   102
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   103
/** */
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   104
TVerdict CTestAdaptStep::doTestStepPostambleL()
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   105
	{
41
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   106
	//Unset all the PandS keys
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   107
	TInt err = RProperty::Set(KPropertyCategory, KEmergencyCallRfAdaptationPluginPropertyKey, 0); 
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   108
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   109
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   110
	err = RProperty::Set(KPropertyCategory, KStateAdaptationPluginPropertyKey, 0);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   111
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   112
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   113
	err = RProperty::Set(KPropertyCategory, KRtcAdaptationPluginPropertyKey, 0);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   114
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   115
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   116
	err = RProperty::Set(KPropertyCategory, KSimPluginPropertyKey, 0);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   117
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   118
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   119
	err = RProperty::Set(KPropertyCategory, KMiscPluginPropertyKey, 0);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   120
	TEST(KErrNone == err);
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   121
	
c87e5f80c17d 201025_04
hgs
parents: 0
diff changeset
   122
	
0
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   123
	return CTestStep::doTestStepPostambleL();
4e1aa6a622a0 Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   124
	}