charconvfw/charconv_fw/test/t_charconvfwserver.cpp
author hgs
Thu, 23 Sep 2010 12:50:02 +0800
changeset 64 f66674566702
permissions -rw-r--r--
201033_08
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64
f66674566702 201033_08
hgs
parents:
diff changeset
     1
/*
f66674566702 201033_08
hgs
parents:
diff changeset
     2
* Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
f66674566702 201033_08
hgs
parents:
diff changeset
     3
* All rights reserved.
f66674566702 201033_08
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
f66674566702 201033_08
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
f66674566702 201033_08
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
f66674566702 201033_08
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
f66674566702 201033_08
hgs
parents:
diff changeset
     8
*
f66674566702 201033_08
hgs
parents:
diff changeset
     9
* Initial Contributors:
f66674566702 201033_08
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
f66674566702 201033_08
hgs
parents:
diff changeset
    11
*
f66674566702 201033_08
hgs
parents:
diff changeset
    12
* Contributors:
f66674566702 201033_08
hgs
parents:
diff changeset
    13
*
f66674566702 201033_08
hgs
parents:
diff changeset
    14
* Description: 
f66674566702 201033_08
hgs
parents:
diff changeset
    15
*
f66674566702 201033_08
hgs
parents:
diff changeset
    16
*/
f66674566702 201033_08
hgs
parents:
diff changeset
    17
f66674566702 201033_08
hgs
parents:
diff changeset
    18
#include "t_charconvfwserver.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    19
#include "t_memory.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    20
#include "t_simple7.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    21
#include "t_simple8.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    22
#include "t_rfc1642.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    23
#include "t_comp7.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    24
#include "t_comp8.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    25
#include "t_realut8.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    26
#include "t_realuni.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    27
#include "t_error.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    28
#include "t_newlin7.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    29
#include "t_java.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    30
#include "t_partial.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    31
#include "t_imap.h"
f66674566702 201033_08
hgs
parents:
diff changeset
    32
f66674566702 201033_08
hgs
parents:
diff changeset
    33
f66674566702 201033_08
hgs
parents:
diff changeset
    34
/* Path to the script
f66674566702 201033_08
hgs
parents:
diff changeset
    35
f66674566702 201033_08
hgs
parents:
diff changeset
    36
c:\z:\t_TEF\t_TEF_All.script
f66674566702 201033_08
hgs
parents:
diff changeset
    37
f66674566702 201033_08
hgs
parents:
diff changeset
    38
*/
f66674566702 201033_08
hgs
parents:
diff changeset
    39
f66674566702 201033_08
hgs
parents:
diff changeset
    40
_LIT(KServerName,"T_CharConvFWServer");
f66674566702 201033_08
hgs
parents:
diff changeset
    41
f66674566702 201033_08
hgs
parents:
diff changeset
    42
CT_CharConvFwServer *CT_CharConvFwServer::NewL()
f66674566702 201033_08
hgs
parents:
diff changeset
    43
/**
f66674566702 201033_08
hgs
parents:
diff changeset
    44
   @return - Instance of the test server
f66674566702 201033_08
hgs
parents:
diff changeset
    45
   Same code for Secure and non-secure variants
f66674566702 201033_08
hgs
parents:
diff changeset
    46
   Called inside the MainL() function to create and start the
f66674566702 201033_08
hgs
parents:
diff changeset
    47
   CTestServer derived server.
f66674566702 201033_08
hgs
parents:
diff changeset
    48
 */
f66674566702 201033_08
hgs
parents:
diff changeset
    49
    {
f66674566702 201033_08
hgs
parents:
diff changeset
    50
    CT_CharConvFwServer * server = new (ELeave) CT_CharConvFwServer();
f66674566702 201033_08
hgs
parents:
diff changeset
    51
    CleanupStack::PushL(server);
f66674566702 201033_08
hgs
parents:
diff changeset
    52
    // CServer base class call
f66674566702 201033_08
hgs
parents:
diff changeset
    53
    server->StartL(KServerName);
f66674566702 201033_08
hgs
parents:
diff changeset
    54
    CleanupStack::Pop(server);
f66674566702 201033_08
hgs
parents:
diff changeset
    55
    return server;
f66674566702 201033_08
hgs
parents:
diff changeset
    56
    }
f66674566702 201033_08
hgs
parents:
diff changeset
    57
f66674566702 201033_08
hgs
parents:
diff changeset
    58
f66674566702 201033_08
hgs
parents:
diff changeset
    59
LOCAL_C void MainL()
f66674566702 201033_08
hgs
parents:
diff changeset
    60
//
f66674566702 201033_08
hgs
parents:
diff changeset
    61
// Secure variant
f66674566702 201033_08
hgs
parents:
diff changeset
    62
// Much simpler, uses the new Rendezvous() call to sync with the client
f66674566702 201033_08
hgs
parents:
diff changeset
    63
//
f66674566702 201033_08
hgs
parents:
diff changeset
    64
    {
f66674566702 201033_08
hgs
parents:
diff changeset
    65
#if (defined __DATA_CAGING__)
f66674566702 201033_08
hgs
parents:
diff changeset
    66
    RProcess().DataCaging(RProcess::EDataCagingOn);
f66674566702 201033_08
hgs
parents:
diff changeset
    67
    RProcess().SecureApi(RProcess::ESecureApiOn);
f66674566702 201033_08
hgs
parents:
diff changeset
    68
#endif
f66674566702 201033_08
hgs
parents:
diff changeset
    69
    CActiveScheduler* sched=NULL;
f66674566702 201033_08
hgs
parents:
diff changeset
    70
    sched=new(ELeave) CActiveScheduler;
f66674566702 201033_08
hgs
parents:
diff changeset
    71
    CActiveScheduler::Install(sched);
f66674566702 201033_08
hgs
parents:
diff changeset
    72
    CT_CharConvFwServer *server = NULL;
f66674566702 201033_08
hgs
parents:
diff changeset
    73
    // Create the CTestServer derived server
f66674566702 201033_08
hgs
parents:
diff changeset
    74
    TRAPD(err,server = CT_CharConvFwServer::NewL());
f66674566702 201033_08
hgs
parents:
diff changeset
    75
    if(!err)
f66674566702 201033_08
hgs
parents:
diff changeset
    76
        {
f66674566702 201033_08
hgs
parents:
diff changeset
    77
        // Sync with the client and enter the active scheduler
f66674566702 201033_08
hgs
parents:
diff changeset
    78
        RProcess::Rendezvous(KErrNone);
f66674566702 201033_08
hgs
parents:
diff changeset
    79
        sched->Start();
f66674566702 201033_08
hgs
parents:
diff changeset
    80
        }
f66674566702 201033_08
hgs
parents:
diff changeset
    81
    delete server;
f66674566702 201033_08
hgs
parents:
diff changeset
    82
    delete sched;
f66674566702 201033_08
hgs
parents:
diff changeset
    83
    }
f66674566702 201033_08
hgs
parents:
diff changeset
    84
f66674566702 201033_08
hgs
parents:
diff changeset
    85
/** @return - Standard Epoc error code on process exit
f66674566702 201033_08
hgs
parents:
diff changeset
    86
    Secure variant only
f66674566702 201033_08
hgs
parents:
diff changeset
    87
    Process entry point. Called by client using RProcess API
f66674566702 201033_08
hgs
parents:
diff changeset
    88
*/
f66674566702 201033_08
hgs
parents:
diff changeset
    89
GLDEF_C TInt E32Main()
f66674566702 201033_08
hgs
parents:
diff changeset
    90
    {
f66674566702 201033_08
hgs
parents:
diff changeset
    91
    __UHEAP_MARK;
f66674566702 201033_08
hgs
parents:
diff changeset
    92
    CTrapCleanup* cleanup = CTrapCleanup::New();
f66674566702 201033_08
hgs
parents:
diff changeset
    93
    if(cleanup == NULL)
f66674566702 201033_08
hgs
parents:
diff changeset
    94
        {
f66674566702 201033_08
hgs
parents:
diff changeset
    95
        return KErrNoMemory;
f66674566702 201033_08
hgs
parents:
diff changeset
    96
        }
f66674566702 201033_08
hgs
parents:
diff changeset
    97
    TRAPD(err,MainL());
f66674566702 201033_08
hgs
parents:
diff changeset
    98
    // This if statement is here just to shut up RVCT, which would otherwise warn
f66674566702 201033_08
hgs
parents:
diff changeset
    99
    // that err was set but never used
f66674566702 201033_08
hgs
parents:
diff changeset
   100
    if (err)
f66674566702 201033_08
hgs
parents:
diff changeset
   101
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   102
        err = KErrNone;
f66674566702 201033_08
hgs
parents:
diff changeset
   103
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   104
    delete cleanup;
f66674566702 201033_08
hgs
parents:
diff changeset
   105
    __UHEAP_MARKEND;
f66674566702 201033_08
hgs
parents:
diff changeset
   106
    return KErrNone;
f66674566702 201033_08
hgs
parents:
diff changeset
   107
    }
f66674566702 201033_08
hgs
parents:
diff changeset
   108
f66674566702 201033_08
hgs
parents:
diff changeset
   109
CTestStep *CT_CharConvFwServer::CreateTestStep(const TDesC& aStepName)
f66674566702 201033_08
hgs
parents:
diff changeset
   110
/**
f66674566702 201033_08
hgs
parents:
diff changeset
   111
   @return - A CTestStep derived instance
f66674566702 201033_08
hgs
parents:
diff changeset
   112
   Secure and non-secure variants
f66674566702 201033_08
hgs
parents:
diff changeset
   113
   Implementation of CTestServer pure virtual
f66674566702 201033_08
hgs
parents:
diff changeset
   114
 */
f66674566702 201033_08
hgs
parents:
diff changeset
   115
    {
f66674566702 201033_08
hgs
parents:
diff changeset
   116
    if(aStepName == KTestStep_T_MEMORY)
f66674566702 201033_08
hgs
parents:
diff changeset
   117
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   118
        return new CT_MEMORY();
f66674566702 201033_08
hgs
parents:
diff changeset
   119
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   120
    else if(aStepName == KTestStep_T_SIMPLE7)
f66674566702 201033_08
hgs
parents:
diff changeset
   121
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   122
        return new CT_SIMPLE7();
f66674566702 201033_08
hgs
parents:
diff changeset
   123
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   124
    else if(aStepName == KTestStep_T_SIMPLE8)
f66674566702 201033_08
hgs
parents:
diff changeset
   125
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   126
        return new CT_SIMPLE8();
f66674566702 201033_08
hgs
parents:
diff changeset
   127
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   128
    else if(aStepName == KTestStep_T_RFC1642)
f66674566702 201033_08
hgs
parents:
diff changeset
   129
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   130
        return new CT_RFC1642();
f66674566702 201033_08
hgs
parents:
diff changeset
   131
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   132
    else if(aStepName == KTestStep_T_COMP7)
f66674566702 201033_08
hgs
parents:
diff changeset
   133
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   134
        return new CT_COMP7();
f66674566702 201033_08
hgs
parents:
diff changeset
   135
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   136
    else if(aStepName == KTestStep_T_COMP8)
f66674566702 201033_08
hgs
parents:
diff changeset
   137
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   138
        return new CT_COMP8();
f66674566702 201033_08
hgs
parents:
diff changeset
   139
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   140
    else if(aStepName == KTestStep_T_REALUT8)
f66674566702 201033_08
hgs
parents:
diff changeset
   141
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   142
        return new CT_REALUT8();
f66674566702 201033_08
hgs
parents:
diff changeset
   143
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   144
    else if(aStepName == KTestStep_T_REALUNI)
f66674566702 201033_08
hgs
parents:
diff changeset
   145
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   146
        return new CT_REALUNI();
f66674566702 201033_08
hgs
parents:
diff changeset
   147
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   148
    else if(aStepName == KTestStep_T_ERROR)
f66674566702 201033_08
hgs
parents:
diff changeset
   149
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   150
        return new CT_ERROR();
f66674566702 201033_08
hgs
parents:
diff changeset
   151
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   152
    else if(aStepName == KTestStep_T_NEWLIN7)
f66674566702 201033_08
hgs
parents:
diff changeset
   153
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   154
        return new CT_NEWLIN7();
f66674566702 201033_08
hgs
parents:
diff changeset
   155
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   156
    else if(aStepName == KTestStep_T_JAVA)
f66674566702 201033_08
hgs
parents:
diff changeset
   157
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   158
        return new CT_JAVA();
f66674566702 201033_08
hgs
parents:
diff changeset
   159
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   160
    else if(aStepName == KTestStep_T_PARTIAL)
f66674566702 201033_08
hgs
parents:
diff changeset
   161
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   162
        return new CT_PARTIAL();
f66674566702 201033_08
hgs
parents:
diff changeset
   163
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   164
    else if(aStepName == KTestStep_T_IMAP)
f66674566702 201033_08
hgs
parents:
diff changeset
   165
        {
f66674566702 201033_08
hgs
parents:
diff changeset
   166
        return new CT_IMAP();
f66674566702 201033_08
hgs
parents:
diff changeset
   167
        }
f66674566702 201033_08
hgs
parents:
diff changeset
   168
    
f66674566702 201033_08
hgs
parents:
diff changeset
   169
    return NULL;
f66674566702 201033_08
hgs
parents:
diff changeset
   170
    }
f66674566702 201033_08
hgs
parents:
diff changeset
   171