persistentstorage/centralrepository/test/t_cenrep_pma_rfs.cpp
author hgs
Tue, 19 Oct 2010 16:26:13 +0100
changeset 55 44f437012c90
permissions -rw-r--r--
201041_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55
44f437012c90 201041_01
hgs
parents:
diff changeset
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
44f437012c90 201041_01
hgs
parents:
diff changeset
     2
// All rights reserved.
44f437012c90 201041_01
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
44f437012c90 201041_01
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
44f437012c90 201041_01
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
44f437012c90 201041_01
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
44f437012c90 201041_01
hgs
parents:
diff changeset
     7
//
44f437012c90 201041_01
hgs
parents:
diff changeset
     8
// Initial Contributors:
44f437012c90 201041_01
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
44f437012c90 201041_01
hgs
parents:
diff changeset
    10
//
44f437012c90 201041_01
hgs
parents:
diff changeset
    11
// Contributors:
44f437012c90 201041_01
hgs
parents:
diff changeset
    12
//
44f437012c90 201041_01
hgs
parents:
diff changeset
    13
// Description:
44f437012c90 201041_01
hgs
parents:
diff changeset
    14
//
44f437012c90 201041_01
hgs
parents:
diff changeset
    15
44f437012c90 201041_01
hgs
parents:
diff changeset
    16
#include "t_cenrep_helper.h"
44f437012c90 201041_01
hgs
parents:
diff changeset
    17
#include <centralrepository.h>
44f437012c90 201041_01
hgs
parents:
diff changeset
    18
#include <e32test.h>  // RTest
44f437012c90 201041_01
hgs
parents:
diff changeset
    19
#include <e32debug.h> // RDebug::Printf
44f437012c90 201041_01
hgs
parents:
diff changeset
    20
#include <f32file.h>  // RFs
44f437012c90 201041_01
hgs
parents:
diff changeset
    21
44f437012c90 201041_01
hgs
parents:
diff changeset
    22
#include "../cenrepsrv/srvparams.h" //KServerUid3
44f437012c90 201041_01
hgs
parents:
diff changeset
    23
44f437012c90 201041_01
hgs
parents:
diff changeset
    24
_LIT(KSoftReset, "--SoftReset");
44f437012c90 201041_01
hgs
parents:
diff changeset
    25
44f437012c90 201041_01
hgs
parents:
diff changeset
    26
RTest TheTest(_L("t_cenrep_pma_rfs.exe"));
44f437012c90 201041_01
hgs
parents:
diff changeset
    27
44f437012c90 201041_01
hgs
parents:
diff changeset
    28
const TUid KUidPMARepROMOnly = { 0xf1000501 };
44f437012c90 201041_01
hgs
parents:
diff changeset
    29
const TUid KUidPMARepInstallOnly = { 0xf1000502 };
44f437012c90 201041_01
hgs
parents:
diff changeset
    30
const TUid KUidPMARepROMAndInstall = { 0xf1000503 };
44f437012c90 201041_01
hgs
parents:
diff changeset
    31
const TUid KUidNonPMARep = { 0xf1000504 };
44f437012c90 201041_01
hgs
parents:
diff changeset
    32
44f437012c90 201041_01
hgs
parents:
diff changeset
    33
_LIT(KInstallOnlySource, "Z:\\private\\10202BE9\\f1000502.txi");
44f437012c90 201041_01
hgs
parents:
diff changeset
    34
_LIT(KInstallOnlyTarget, "C:\\private\\10202BE9\\f1000502.txt");
44f437012c90 201041_01
hgs
parents:
diff changeset
    35
            
44f437012c90 201041_01
hgs
parents:
diff changeset
    36
_LIT(KInstallOnlyPmaSource, "Z:\\private\\10202BE9\\f1000502.pma");
44f437012c90 201041_01
hgs
parents:
diff changeset
    37
_LIT(KInstallOnlyPmaTarget, "C:\\private\\10202BE9\\persists\\protected\\f1000502.cre");
44f437012c90 201041_01
hgs
parents:
diff changeset
    38
            
44f437012c90 201041_01
hgs
parents:
diff changeset
    39
_LIT(KRomAndInstallSource, "Z:\\private\\10202BE9\\f1000503.txi");
44f437012c90 201041_01
hgs
parents:
diff changeset
    40
_LIT(KRomAndInstallTarget, "C:\\private\\10202BE9\\f1000503.txt");
44f437012c90 201041_01
hgs
parents:
diff changeset
    41
44f437012c90 201041_01
hgs
parents:
diff changeset
    42
typedef enum
44f437012c90 201041_01
hgs
parents:
diff changeset
    43
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
    44
    EInstallOnly,
44f437012c90 201041_01
hgs
parents:
diff changeset
    45
    ERomAndInstall,
44f437012c90 201041_01
hgs
parents:
diff changeset
    46
    } TRepositoryFileState;
44f437012c90 201041_01
hgs
parents:
diff changeset
    47
44f437012c90 201041_01
hgs
parents:
diff changeset
    48
const TUint32 KInt1 = 1;
44f437012c90 201041_01
hgs
parents:
diff changeset
    49
const TInt KInt1_UpdatedValue = 73;
44f437012c90 201041_01
hgs
parents:
diff changeset
    50
44f437012c90 201041_01
hgs
parents:
diff changeset
    51
const TUint32 KNewInt = 1000;
44f437012c90 201041_01
hgs
parents:
diff changeset
    52
const TUint32 KNewInt2 = 0x0FFF; // outside range meta (in default meta)
44f437012c90 201041_01
hgs
parents:
diff changeset
    53
const TUint32 KNewInt3 = 0x1000; // inside range meta
44f437012c90 201041_01
hgs
parents:
diff changeset
    54
44f437012c90 201041_01
hgs
parents:
diff changeset
    55
const TUint32 KReal1 = 2;
44f437012c90 201041_01
hgs
parents:
diff changeset
    56
44f437012c90 201041_01
hgs
parents:
diff changeset
    57
const TUint32 KString1 = 5;
44f437012c90 201041_01
hgs
parents:
diff changeset
    58
_LIT(KString1_UpdatedValue, "another one");
44f437012c90 201041_01
hgs
parents:
diff changeset
    59
44f437012c90 201041_01
hgs
parents:
diff changeset
    60
const TUint32 KIntNonPMA = 1;
44f437012c90 201041_01
hgs
parents:
diff changeset
    61
const TInt KIntNonPMA_InitialValue = 100;
44f437012c90 201041_01
hgs
parents:
diff changeset
    62
const TInt KIntNonPMA_UpdatedValue = 102;
44f437012c90 201041_01
hgs
parents:
diff changeset
    63
44f437012c90 201041_01
hgs
parents:
diff changeset
    64
44f437012c90 201041_01
hgs
parents:
diff changeset
    65
LOCAL_C void Check(TInt aValue, TInt aLine)
44f437012c90 201041_01
hgs
parents:
diff changeset
    66
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
    67
    if(!aValue)
44f437012c90 201041_01
hgs
parents:
diff changeset
    68
        {
44f437012c90 201041_01
hgs
parents:
diff changeset
    69
        TRAPD(err, CleanupCDriveL());
44f437012c90 201041_01
hgs
parents:
diff changeset
    70
        if (err != KErrNone)
44f437012c90 201041_01
hgs
parents:
diff changeset
    71
            {
44f437012c90 201041_01
hgs
parents:
diff changeset
    72
            RDebug::Print( _L( "*** CleanupCDriveL also failed with error %d expecting KErrNone\r\n"), err );
44f437012c90 201041_01
hgs
parents:
diff changeset
    73
            }
44f437012c90 201041_01
hgs
parents:
diff changeset
    74
        TheTest(EFalse, aLine);
44f437012c90 201041_01
hgs
parents:
diff changeset
    75
        }
44f437012c90 201041_01
hgs
parents:
diff changeset
    76
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
    77
LOCAL_C void Check(TInt aValue, TInt aExpected, TInt aLine)
44f437012c90 201041_01
hgs
parents:
diff changeset
    78
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
    79
    if(aValue != aExpected)
44f437012c90 201041_01
hgs
parents:
diff changeset
    80
        {
44f437012c90 201041_01
hgs
parents:
diff changeset
    81
        RDebug::Print(_L("*** Expected error: %d, got: %d\r\n"), aExpected, aValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
    82
        TRAPD(err, CleanupCDriveL());
44f437012c90 201041_01
hgs
parents:
diff changeset
    83
        if (err != KErrNone)
44f437012c90 201041_01
hgs
parents:
diff changeset
    84
            {
44f437012c90 201041_01
hgs
parents:
diff changeset
    85
            RDebug::Print( _L( "*** CleanupCDriveL also failed with error %d expecting KErrNone\r\n"), err );
44f437012c90 201041_01
hgs
parents:
diff changeset
    86
            }
44f437012c90 201041_01
hgs
parents:
diff changeset
    87
        TheTest(EFalse, aLine);
44f437012c90 201041_01
hgs
parents:
diff changeset
    88
        }
44f437012c90 201041_01
hgs
parents:
diff changeset
    89
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
    90
#define TEST(arg) ::Check((arg), __LINE__)
44f437012c90 201041_01
hgs
parents:
diff changeset
    91
#define TEST2(aValue, aExpected) ::Check(aValue, aExpected, __LINE__)
44f437012c90 201041_01
hgs
parents:
diff changeset
    92
44f437012c90 201041_01
hgs
parents:
diff changeset
    93
// This function kills the C32exe.exe process. This commsdat process will
44f437012c90 201041_01
hgs
parents:
diff changeset
    94
// interfere with the test if not killed. In a nutshell, some of the test cases 
44f437012c90 201041_01
hgs
parents:
diff changeset
    95
// will kill and then wait for 2 seconds and restart the centrep server 
44f437012c90 201041_01
hgs
parents:
diff changeset
    96
// with --SoftReset option. During that 2 seconds wait sometimes C32exe.exe 
44f437012c90 201041_01
hgs
parents:
diff changeset
    97
// will use centrep API, thus starting the server normally without --SoftReset.
44f437012c90 201041_01
hgs
parents:
diff changeset
    98
LOCAL_C void KillC32Exe()
44f437012c90 201041_01
hgs
parents:
diff changeset
    99
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   100
    _LIT( KC32ServerName, "c32exe");
44f437012c90 201041_01
hgs
parents:
diff changeset
   101
    KillProcess(KC32ServerName); // Don't need to check the return code, it always return KErrNone anyway.
44f437012c90 201041_01
hgs
parents:
diff changeset
   102
    User::After(KGeneralDelay);
44f437012c90 201041_01
hgs
parents:
diff changeset
   103
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   104
44f437012c90 201041_01
hgs
parents:
diff changeset
   105
LOCAL_C void KillCentrepExe()
44f437012c90 201041_01
hgs
parents:
diff changeset
   106
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   107
    _LIT( KCentralRepositoryServerName, "Centralrepositorysrv");
44f437012c90 201041_01
hgs
parents:
diff changeset
   108
    KillProcess(KCentralRepositoryServerName); // Don't need to check the return code, it always return KErrNone anyway.
44f437012c90 201041_01
hgs
parents:
diff changeset
   109
    User::After(KGeneralDelay);
44f437012c90 201041_01
hgs
parents:
diff changeset
   110
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   111
44f437012c90 201041_01
hgs
parents:
diff changeset
   112
//This function restores the state of the files required for this test
44f437012c90 201041_01
hgs
parents:
diff changeset
   113
//Existing files are deleted and then the required files are copied
44f437012c90 201041_01
hgs
parents:
diff changeset
   114
//back from the Z drive to the c drive
44f437012c90 201041_01
hgs
parents:
diff changeset
   115
LOCAL_C void RestoreRFSTestFilesL(TRepositoryFileState aState)
44f437012c90 201041_01
hgs
parents:
diff changeset
   116
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   117
    //Delete all files from C:\\private\\10202BE9\\persists\\ dir
44f437012c90 201041_01
hgs
parents:
diff changeset
   118
    //and C:\\private\\10202BE9\\ dir
44f437012c90 201041_01
hgs
parents:
diff changeset
   119
    CleanupCDriveL();
44f437012c90 201041_01
hgs
parents:
diff changeset
   120
    RFs fs;
44f437012c90 201041_01
hgs
parents:
diff changeset
   121
    User::LeaveIfError(fs.Connect());
44f437012c90 201041_01
hgs
parents:
diff changeset
   122
    CleanupClosePushL(fs);
44f437012c90 201041_01
hgs
parents:
diff changeset
   123
44f437012c90 201041_01
hgs
parents:
diff changeset
   124
    CFileMan* fm = CFileMan::NewL(fs);
44f437012c90 201041_01
hgs
parents:
diff changeset
   125
    CleanupStack::PushL(fm);
44f437012c90 201041_01
hgs
parents:
diff changeset
   126
        
44f437012c90 201041_01
hgs
parents:
diff changeset
   127
    switch(aState)
44f437012c90 201041_01
hgs
parents:
diff changeset
   128
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   129
        case EInstallOnly:
44f437012c90 201041_01
hgs
parents:
diff changeset
   130
            CopyTestFilesL(*fm,KInstallOnlySource, KInstallOnlyTarget);
44f437012c90 201041_01
hgs
parents:
diff changeset
   131
            //Since we can't open and modify a PMA keyspace in install directory
44f437012c90 201041_01
hgs
parents:
diff changeset
   132
            // we have to copy a pre-persisted version to the PMA drive.
44f437012c90 201041_01
hgs
parents:
diff changeset
   133
            CopyTestFilesL(*fm,KInstallOnlyPmaSource, KInstallOnlyPmaTarget);
44f437012c90 201041_01
hgs
parents:
diff changeset
   134
            break;
44f437012c90 201041_01
hgs
parents:
diff changeset
   135
44f437012c90 201041_01
hgs
parents:
diff changeset
   136
        case ERomAndInstall:
44f437012c90 201041_01
hgs
parents:
diff changeset
   137
            CopyTestFilesL(*fm,KRomAndInstallSource, KRomAndInstallTarget);
44f437012c90 201041_01
hgs
parents:
diff changeset
   138
            break;
44f437012c90 201041_01
hgs
parents:
diff changeset
   139
44f437012c90 201041_01
hgs
parents:
diff changeset
   140
        default:
44f437012c90 201041_01
hgs
parents:
diff changeset
   141
            break;
44f437012c90 201041_01
hgs
parents:
diff changeset
   142
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   143
44f437012c90 201041_01
hgs
parents:
diff changeset
   144
    CleanupStack::PopAndDestroy(2);
44f437012c90 201041_01
hgs
parents:
diff changeset
   145
44f437012c90 201041_01
hgs
parents:
diff changeset
   146
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   147
44f437012c90 201041_01
hgs
parents:
diff changeset
   148
//
44f437012c90 201041_01
hgs
parents:
diff changeset
   149
// Start the server process or thread
44f437012c90 201041_01
hgs
parents:
diff changeset
   150
//
44f437012c90 201041_01
hgs
parents:
diff changeset
   151
LOCAL_C TInt ReStartServerInSoftResetMode()
44f437012c90 201041_01
hgs
parents:
diff changeset
   152
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   153
    const TUidType serverUid(KNullUid, KNullUid, KServerUid3);
44f437012c90 201041_01
hgs
parents:
diff changeset
   154
44f437012c90 201041_01
hgs
parents:
diff changeset
   155
    //
44f437012c90 201041_01
hgs
parents:
diff changeset
   156
    // EPOC and EKA2 is easy, we just create a new server process. Simultaneous
44f437012c90 201041_01
hgs
parents:
diff changeset
   157
    // launching of two such processes should be detected when the second one
44f437012c90 201041_01
hgs
parents:
diff changeset
   158
    // attempts to create the server object, failing with KErrAlreadyExists.
44f437012c90 201041_01
hgs
parents:
diff changeset
   159
    //
44f437012c90 201041_01
hgs
parents:
diff changeset
   160
    RProcess server;
44f437012c90 201041_01
hgs
parents:
diff changeset
   161
    TInt r=server.Create(KServerImg,
44f437012c90 201041_01
hgs
parents:
diff changeset
   162
                         KSoftReset,
44f437012c90 201041_01
hgs
parents:
diff changeset
   163
                         serverUid);
44f437012c90 201041_01
hgs
parents:
diff changeset
   164
44f437012c90 201041_01
hgs
parents:
diff changeset
   165
    if (r != KErrNone)
44f437012c90 201041_01
hgs
parents:
diff changeset
   166
        {
44f437012c90 201041_01
hgs
parents:
diff changeset
   167
        return r;
44f437012c90 201041_01
hgs
parents:
diff changeset
   168
        }
44f437012c90 201041_01
hgs
parents:
diff changeset
   169
44f437012c90 201041_01
hgs
parents:
diff changeset
   170
    TRequestStatus stat;
44f437012c90 201041_01
hgs
parents:
diff changeset
   171
    server.Rendezvous(stat);
44f437012c90 201041_01
hgs
parents:
diff changeset
   172
44f437012c90 201041_01
hgs
parents:
diff changeset
   173
    if (stat != KRequestPending)
44f437012c90 201041_01
hgs
parents:
diff changeset
   174
        {
44f437012c90 201041_01
hgs
parents:
diff changeset
   175
        server.Kill(0);        // abort startup
44f437012c90 201041_01
hgs
parents:
diff changeset
   176
        }
44f437012c90 201041_01
hgs
parents:
diff changeset
   177
    else
44f437012c90 201041_01
hgs
parents:
diff changeset
   178
        {
44f437012c90 201041_01
hgs
parents:
diff changeset
   179
        server.Resume();    // logon OK - start the server
44f437012c90 201041_01
hgs
parents:
diff changeset
   180
        }
44f437012c90 201041_01
hgs
parents:
diff changeset
   181
44f437012c90 201041_01
hgs
parents:
diff changeset
   182
    User::WaitForRequest(stat);        // wait for start or death
44f437012c90 201041_01
hgs
parents:
diff changeset
   183
    // we can't use the 'exit reason' if the server panicked as this
44f437012c90 201041_01
hgs
parents:
diff changeset
   184
    // is the panic 'reason' and may be '0' which cannot be distinguished
44f437012c90 201041_01
hgs
parents:
diff changeset
   185
    // from KErrNone
44f437012c90 201041_01
hgs
parents:
diff changeset
   186
    r = (server.ExitType() == EExitPanic) ? KErrGeneral : stat.Int();
44f437012c90 201041_01
hgs
parents:
diff changeset
   187
44f437012c90 201041_01
hgs
parents:
diff changeset
   188
    server.Close();
44f437012c90 201041_01
hgs
parents:
diff changeset
   189
    return r;
44f437012c90 201041_01
hgs
parents:
diff changeset
   190
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   191
44f437012c90 201041_01
hgs
parents:
diff changeset
   192
44f437012c90 201041_01
hgs
parents:
diff changeset
   193
LOCAL_C void RestoreFactorySettingsTestL( TUid aRepUid )
44f437012c90 201041_01
hgs
parents:
diff changeset
   194
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   195
    TheTest.Next(_L(" RestoreFactorySettingsTestL "));
44f437012c90 201041_01
hgs
parents:
diff changeset
   196
    TInt r;
44f437012c90 201041_01
hgs
parents:
diff changeset
   197
    TInt i;
44f437012c90 201041_01
hgs
parents:
diff changeset
   198
    TBuf<20> str;
44f437012c90 201041_01
hgs
parents:
diff changeset
   199
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   200
    //Kill centrep server to pick new test files
44f437012c90 201041_01
hgs
parents:
diff changeset
   201
    KillCentrepExe();
44f437012c90 201041_01
hgs
parents:
diff changeset
   202
44f437012c90 201041_01
hgs
parents:
diff changeset
   203
    TheTest.Printf(_L("Open repository to ensure server is running"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   204
    CRepository* repository = CRepository::NewLC(aRepUid);
44f437012c90 201041_01
hgs
parents:
diff changeset
   205
44f437012c90 201041_01
hgs
parents:
diff changeset
   206
    TheTest.Printf(_L("Add a Setting"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   207
    const TInt KIntValue = 1234;
44f437012c90 201041_01
hgs
parents:
diff changeset
   208
    r = repository->Create(KNewInt, KIntValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   209
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   210
    r = repository->Create(KNewInt2, KIntValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   211
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   212
    r = repository->Create(KNewInt3, KIntValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   213
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   214
44f437012c90 201041_01
hgs
parents:
diff changeset
   215
    TheTest.Printf(_L("Delete a PMA Setting"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   216
    r = repository->Delete(KReal1);
44f437012c90 201041_01
hgs
parents:
diff changeset
   217
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   218
44f437012c90 201041_01
hgs
parents:
diff changeset
   219
    TheTest.Printf(_L("Modify PMA Setting"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   220
    r = repository->Set(KInt1, KInt1_UpdatedValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   221
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   222
    r = repository->Set(KString1, KString1_UpdatedValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   223
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   224
44f437012c90 201041_01
hgs
parents:
diff changeset
   225
    // Close repository
44f437012c90 201041_01
hgs
parents:
diff changeset
   226
    CleanupStack::PopAndDestroy(repository);
44f437012c90 201041_01
hgs
parents:
diff changeset
   227
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   228
    // Open a Non-PMA rep to prove that the RFS actually did happened later
44f437012c90 201041_01
hgs
parents:
diff changeset
   229
    repository = CRepository::NewLC(KUidNonPMARep);
44f437012c90 201041_01
hgs
parents:
diff changeset
   230
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   231
    TheTest.Printf(_L("Modify a Non-PMA and RFS-enabled setting"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   232
    r = repository->Set(KIntNonPMA, KIntNonPMA_UpdatedValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   233
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   234
    CleanupStack::PopAndDestroy(repository);
44f437012c90 201041_01
hgs
parents:
diff changeset
   235
44f437012c90 201041_01
hgs
parents:
diff changeset
   236
    TheTest.Printf(_L("Kill the server process"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   237
    _LIT( KCentralRepositoryServerName, "Centralrepositorysrv");
44f437012c90 201041_01
hgs
parents:
diff changeset
   238
    r = KillProcess(KCentralRepositoryServerName);
44f437012c90 201041_01
hgs
parents:
diff changeset
   239
    TEST2(r,KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   240
44f437012c90 201041_01
hgs
parents:
diff changeset
   241
    User::After(KGeneralDelay);
44f437012c90 201041_01
hgs
parents:
diff changeset
   242
44f437012c90 201041_01
hgs
parents:
diff changeset
   243
    TheTest.Printf(_L("Manually start central respository in softreset mode"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   244
    ReStartServerInSoftResetMode();
44f437012c90 201041_01
hgs
parents:
diff changeset
   245
44f437012c90 201041_01
hgs
parents:
diff changeset
   246
    TheTest.Printf(_L("Re-create the repository to ensure server is running"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   247
    repository = CRepository::NewLC(aRepUid);
44f437012c90 201041_01
hgs
parents:
diff changeset
   248
44f437012c90 201041_01
hgs
parents:
diff changeset
   249
    TheTest.Printf(_L("Get 'Added' value"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   250
    r = repository->Get(KNewInt, i);
44f437012c90 201041_01
hgs
parents:
diff changeset
   251
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   252
    r = repository->Get(KNewInt2, i);
44f437012c90 201041_01
hgs
parents:
diff changeset
   253
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   254
    r = repository->Get(KNewInt3, i);
44f437012c90 201041_01
hgs
parents:
diff changeset
   255
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   256
44f437012c90 201041_01
hgs
parents:
diff changeset
   257
    TReal real;
44f437012c90 201041_01
hgs
parents:
diff changeset
   258
    TheTest.Printf(_L("Get 'Deleted' value"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   259
    r = repository->Get(KReal1, real);
44f437012c90 201041_01
hgs
parents:
diff changeset
   260
    TEST2(r, KErrNotFound);
44f437012c90 201041_01
hgs
parents:
diff changeset
   261
44f437012c90 201041_01
hgs
parents:
diff changeset
   262
    TheTest.Printf(_L("Get 'Modified' value"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   263
    r = repository->Get(KInt1, i);
44f437012c90 201041_01
hgs
parents:
diff changeset
   264
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   265
    TEST(i == KInt1_UpdatedValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   266
44f437012c90 201041_01
hgs
parents:
diff changeset
   267
    r = repository->Get(KString1, str);
44f437012c90 201041_01
hgs
parents:
diff changeset
   268
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   269
    TEST(str == KString1_UpdatedValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   270
44f437012c90 201041_01
hgs
parents:
diff changeset
   271
    // Close repository
44f437012c90 201041_01
hgs
parents:
diff changeset
   272
    CleanupStack::PopAndDestroy(repository);
44f437012c90 201041_01
hgs
parents:
diff changeset
   273
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   274
    repository = CRepository::NewLC(KUidNonPMARep);
44f437012c90 201041_01
hgs
parents:
diff changeset
   275
    TheTest.Printf(_L("Check the Non-PMA and RFS-enabled setting"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   276
    //If RFS did happen, this value should now be reverted back to the initial ROM value
44f437012c90 201041_01
hgs
parents:
diff changeset
   277
    r = repository->Get(KIntNonPMA, i);
44f437012c90 201041_01
hgs
parents:
diff changeset
   278
    TEST2(r, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   279
    TEST(i == KIntNonPMA_InitialValue);
44f437012c90 201041_01
hgs
parents:
diff changeset
   280
    CleanupStack::PopAndDestroy(repository);
44f437012c90 201041_01
hgs
parents:
diff changeset
   281
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   282
44f437012c90 201041_01
hgs
parents:
diff changeset
   283
/**
44f437012c90 201041_01
hgs
parents:
diff changeset
   284
@SYMTestCaseID          PDS-CENTRALREPOSITORY-CT-4128
44f437012c90 201041_01
hgs
parents:
diff changeset
   285
@SYMTestCaseDesc        Restore Factory Setting test on PMA keyspaces
44f437012c90 201041_01
hgs
parents:
diff changeset
   286
@SYMTestPriority        High
44f437012c90 201041_01
hgs
parents:
diff changeset
   287
@SYMTestActions         - Add a PMA setting.
44f437012c90 201041_01
hgs
parents:
diff changeset
   288
                        - Delete a PMA setting.
44f437012c90 201041_01
hgs
parents:
diff changeset
   289
                        - Modify a PMA Setting.
44f437012c90 201041_01
hgs
parents:
diff changeset
   290
                        - Modify a Non-PMA and RFS-enabled setting.
44f437012c90 201041_01
hgs
parents:
diff changeset
   291
                        - Kill and manually restart central respository server with --SoftReset option.
44f437012c90 201041_01
hgs
parents:
diff changeset
   292
                        - Check the aftermath of the RFS.
44f437012c90 201041_01
hgs
parents:
diff changeset
   293
@SYMTestExpectedResults - Added PMA setting should still be there.
44f437012c90 201041_01
hgs
parents:
diff changeset
   294
                        - Delete PMA setting should still be missing.
44f437012c90 201041_01
hgs
parents:
diff changeset
   295
                        - Modified PMA setting should have the modified value.
44f437012c90 201041_01
hgs
parents:
diff changeset
   296
                        - Modified Non-PMA setting should have its value reverted. 
44f437012c90 201041_01
hgs
parents:
diff changeset
   297
@SYMREQ                 REQ42876
44f437012c90 201041_01
hgs
parents:
diff changeset
   298
*/
44f437012c90 201041_01
hgs
parents:
diff changeset
   299
LOCAL_C void MainL()
44f437012c90 201041_01
hgs
parents:
diff changeset
   300
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   301
    TheTest.Next(_L(" @SYMTestCaseID:PDS-CENTRALREPOSITORY-CT-4128 RFS Test on PMA keyspaces"));
44f437012c90 201041_01
hgs
parents:
diff changeset
   302
    RFs fs;
44f437012c90 201041_01
hgs
parents:
diff changeset
   303
    TEntry entry;
44f437012c90 201041_01
hgs
parents:
diff changeset
   304
    TInt err = fs.Connect();
44f437012c90 201041_01
hgs
parents:
diff changeset
   305
    TEST2(err, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   306
    CleanupClosePushL(fs);
44f437012c90 201041_01
hgs
parents:
diff changeset
   307
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   308
    CleanupCDriveL();
44f437012c90 201041_01
hgs
parents:
diff changeset
   309
    KillC32Exe(); //Need to kill C32Exe as it is interfering with the test.
44f437012c90 201041_01
hgs
parents:
diff changeset
   310
    KillCentrepExe();
44f437012c90 201041_01
hgs
parents:
diff changeset
   311
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   312
    RestoreFactorySettingsTestL(KUidPMARepROMOnly);
44f437012c90 201041_01
hgs
parents:
diff changeset
   313
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   314
    RestoreRFSTestFilesL(EInstallOnly);
44f437012c90 201041_01
hgs
parents:
diff changeset
   315
    RestoreFactorySettingsTestL(KUidPMARepInstallOnly);
44f437012c90 201041_01
hgs
parents:
diff changeset
   316
    err = fs.Entry(KInstallOnlyTarget,entry);//The PMA file in install dir should have been deleted during RFS
44f437012c90 201041_01
hgs
parents:
diff changeset
   317
    TEST2(err, KErrNotFound);
44f437012c90 201041_01
hgs
parents:
diff changeset
   318
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   319
    RestoreRFSTestFilesL(ERomAndInstall);
44f437012c90 201041_01
hgs
parents:
diff changeset
   320
    RestoreFactorySettingsTestL(KUidPMARepROMAndInstall);
44f437012c90 201041_01
hgs
parents:
diff changeset
   321
    err = fs.Entry(KRomAndInstallTarget,entry);//The PMA file in install dir should have been deleted during RFS
44f437012c90 201041_01
hgs
parents:
diff changeset
   322
    TEST2(err, KErrNotFound);
44f437012c90 201041_01
hgs
parents:
diff changeset
   323
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   324
    CleanupCDriveL();
44f437012c90 201041_01
hgs
parents:
diff changeset
   325
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   326
    CleanupStack::PopAndDestroy(); //fs
44f437012c90 201041_01
hgs
parents:
diff changeset
   327
    }
44f437012c90 201041_01
hgs
parents:
diff changeset
   328
44f437012c90 201041_01
hgs
parents:
diff changeset
   329
TInt E32Main()
44f437012c90 201041_01
hgs
parents:
diff changeset
   330
    {
44f437012c90 201041_01
hgs
parents:
diff changeset
   331
    TheTest.Title ();
44f437012c90 201041_01
hgs
parents:
diff changeset
   332
    TheTest.Start(_L("PMA Restore Factory Settings tests "));
44f437012c90 201041_01
hgs
parents:
diff changeset
   333
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   334
    CTrapCleanup* cleanup = CTrapCleanup::New();
44f437012c90 201041_01
hgs
parents:
diff changeset
   335
    TheTest(cleanup != NULL);
44f437012c90 201041_01
hgs
parents:
diff changeset
   336
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   337
    __UHEAP_MARK;
44f437012c90 201041_01
hgs
parents:
diff changeset
   338
        
44f437012c90 201041_01
hgs
parents:
diff changeset
   339
    TRAPD(err, MainL());
44f437012c90 201041_01
hgs
parents:
diff changeset
   340
    TEST2(err, KErrNone);
44f437012c90 201041_01
hgs
parents:
diff changeset
   341
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   342
    __UHEAP_MARKEND;
44f437012c90 201041_01
hgs
parents:
diff changeset
   343
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   344
    TheTest.End ();
44f437012c90 201041_01
hgs
parents:
diff changeset
   345
    TheTest.Close ();
44f437012c90 201041_01
hgs
parents:
diff changeset
   346
    
44f437012c90 201041_01
hgs
parents:
diff changeset
   347
    delete cleanup;
44f437012c90 201041_01
hgs
parents:
diff changeset
   348
        
44f437012c90 201041_01
hgs
parents:
diff changeset
   349
    User::Heap().Check();
44f437012c90 201041_01
hgs
parents:
diff changeset
   350
    return KErrNone;
44f437012c90 201041_01
hgs
parents:
diff changeset
   351
    }