os/persistentdata/persistentstorage/sql/TEST/t_sqlcmdlineutil.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200 (2014-06-10)
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
#include <e32test.h>
sl@0
    16
#include "t_sqlcmdlineutil.h"
sl@0
    17
sl@0
    18
static void GetCmdLine(RTest& aTest, const TDesC& aTestName, TDes& aCmdLine)
sl@0
    19
	{
sl@0
    20
	User::CommandLine(aCmdLine);
sl@0
    21
	aCmdLine.TrimAll();
sl@0
    22
	if(aCmdLine.Length() == 0)
sl@0
    23
		{
sl@0
    24
		aTest.Printf(_L("Usage: %S [ [/enc=<16/8>] /drv=<drive letter>:] [/page=<512/1024/2048/4096/8192/16384/32768>] ] [/cache=<number>] [/hlimit=<Kb>]\r\n"), &aTestName);
sl@0
    25
		return;
sl@0
    26
		}
sl@0
    27
	aCmdLine.Append(TChar('/'));
sl@0
    28
	}
sl@0
    29
sl@0
    30
static void ExtractCmdLineParams(TDes& aCmdLine,  RArray<TPtrC>& aPrmNames, RArray<TPtrC>& aPrmValues)
sl@0
    31
	{
sl@0
    32
	aPrmNames.Reset();	
sl@0
    33
	aPrmValues.Reset();	
sl@0
    34
	
sl@0
    35
	enum TState{EWaitPrmStart, EReadPrmName, EReadPrmValue};
sl@0
    36
	TState state = EWaitPrmStart;
sl@0
    37
	TInt startPos = -1;
sl@0
    38
	TPtr prmName(0, 0);
sl@0
    39
	TPtr prmValue(0, 0);
sl@0
    40
	
sl@0
    41
	aCmdLine.Append(TChar('/'));
sl@0
    42
	
sl@0
    43
	for(TInt i=0;i<aCmdLine.Length();++i)
sl@0
    44
		{
sl@0
    45
		switch(state)
sl@0
    46
			{
sl@0
    47
			case EWaitPrmStart:
sl@0
    48
				if(aCmdLine[i] == TChar('/'))
sl@0
    49
					{
sl@0
    50
					startPos = i + 1;
sl@0
    51
					prmName.Zero();
sl@0
    52
					state = EReadPrmName;
sl@0
    53
					}
sl@0
    54
				break;
sl@0
    55
			case EReadPrmName:
sl@0
    56
				if(aCmdLine[i] == TChar('='))
sl@0
    57
					{
sl@0
    58
					TPtr p = aCmdLine.MidTPtr(startPos, i - startPos);
sl@0
    59
					prmName.Set(p);
sl@0
    60
					prmName.TrimRight();
sl@0
    61
					startPos = i + 1;
sl@0
    62
					prmValue.Zero();
sl@0
    63
					state = EReadPrmValue;
sl@0
    64
					}
sl@0
    65
				break;
sl@0
    66
			case EReadPrmValue:
sl@0
    67
				if(aCmdLine[i] == TChar('/'))
sl@0
    68
					{
sl@0
    69
					TPtr p = aCmdLine.MidTPtr(startPos, i - startPos);
sl@0
    70
					prmValue.Set(p);
sl@0
    71
					prmValue.Trim();
sl@0
    72
					startPos = i + 1;
sl@0
    73
					aPrmNames.Append(prmName);
sl@0
    74
					aPrmValues.Append(prmValue);
sl@0
    75
					prmName.Zero();
sl@0
    76
					prmValue.Zero();
sl@0
    77
					state = EReadPrmName;
sl@0
    78
					}
sl@0
    79
				break;
sl@0
    80
			default:
sl@0
    81
				break;
sl@0
    82
			}
sl@0
    83
		}
sl@0
    84
	}
sl@0
    85
sl@0
    86
static void ExtractParamNamesAndValues(const RArray<TPtrC>& aPrmNames, const RArray<TPtrC>& aPrmValues, TCmdLineParams& aCmdLineParams)
sl@0
    87
	{
sl@0
    88
	__ASSERT_ALWAYS(aPrmNames.Count() == aPrmValues.Count(), User::Invariant());
sl@0
    89
	
sl@0
    90
	aCmdLineParams.SetDefaults();
sl@0
    91
	
sl@0
    92
	for(TInt i=0;i<aPrmNames.Count();++i)
sl@0
    93
		{
sl@0
    94
		if(aPrmNames[i].CompareF(_L("enc")) == 0)
sl@0
    95
			{
sl@0
    96
			TLex lex(aPrmValues[i]);
sl@0
    97
			TInt enc = 0;
sl@0
    98
			TInt err = lex.Val(enc);
sl@0
    99
			if(err == KErrNone)
sl@0
   100
				{
sl@0
   101
				if(enc == 8)
sl@0
   102
					{
sl@0
   103
					aCmdLineParams.iDbEncoding = TCmdLineParams::EDbUtf8;
sl@0
   104
					}
sl@0
   105
				else if(enc == 16)
sl@0
   106
					{
sl@0
   107
					aCmdLineParams.iDbEncoding = TCmdLineParams::EDbUtf16;
sl@0
   108
					}
sl@0
   109
				}
sl@0
   110
			}
sl@0
   111
		else if(aPrmNames[i].CompareF(_L("drv")) == 0)
sl@0
   112
			{
sl@0
   113
			if(aPrmValues[i].Length() == 2 && aPrmValues[i][1] == TChar(':'))
sl@0
   114
				{
sl@0
   115
				TChar ch(aPrmValues[i][0]);
sl@0
   116
				ch.LowerCase();
sl@0
   117
				if(ch >= TChar('a') && ch <= TChar('z'))
sl@0
   118
					aCmdLineParams.iDriveName.Copy(aPrmValues[i]);
sl@0
   119
				}
sl@0
   120
			}
sl@0
   121
		else if(aPrmNames[i].CompareF(_L("page")) == 0)
sl@0
   122
			{
sl@0
   123
			TLex lex(aPrmValues[i]);
sl@0
   124
			TInt pageSize = 0;
sl@0
   125
			TInt err = lex.Val(pageSize);
sl@0
   126
			if(err == KErrNone && (pageSize == 512 || pageSize == 1024 || pageSize == 2048 ||
sl@0
   127
			   pageSize == 4096 || pageSize == 8192 || pageSize == 16384 || pageSize == 32768))
sl@0
   128
				{
sl@0
   129
				aCmdLineParams.iPageSize = pageSize;
sl@0
   130
				}
sl@0
   131
			}
sl@0
   132
		else if(aPrmNames[i].CompareF(_L("cache")) == 0)
sl@0
   133
			{
sl@0
   134
			TLex lex(aPrmValues[i]);
sl@0
   135
			TInt cacheSize = 0;
sl@0
   136
			TInt err = lex.Val(cacheSize);
sl@0
   137
			if(err == KErrNone && (cacheSize > 0 && cacheSize < 1000000000))
sl@0
   138
				{
sl@0
   139
				aCmdLineParams.iCacheSize = cacheSize;
sl@0
   140
				}
sl@0
   141
			}
sl@0
   142
		else if(aPrmNames[i].CompareF(_L("hlimit")) == 0)
sl@0
   143
			{
sl@0
   144
			TLex lex(aPrmValues[i]);
sl@0
   145
			TInt softHeapLimit = 0;
sl@0
   146
			TInt err = lex.Val(softHeapLimit);
sl@0
   147
			if(err == KErrNone && (softHeapLimit >= 0 && softHeapLimit < 1000000000))
sl@0
   148
				{
sl@0
   149
				aCmdLineParams.iSoftHeapLimitKb = softHeapLimit;
sl@0
   150
				}
sl@0
   151
			}
sl@0
   152
		}
sl@0
   153
	}
sl@0
   154
sl@0
   155
static void PrepareSqlConfigString(RTest& aTest, const TCmdLineParams& aCmdLineParams, TDes8& aConfigStr)
sl@0
   156
	{
sl@0
   157
	aConfigStr.Zero();
sl@0
   158
	
sl@0
   159
	if(aCmdLineParams.iDbEncoding == TCmdLineParams::EDbUtf8)
sl@0
   160
		{
sl@0
   161
		aTest.Printf(_L("--PRM--Database Encoding: UTF8\r\n"));
sl@0
   162
		aConfigStr.Append(_L8("encoding=\"UTF-8\";"));
sl@0
   163
		}
sl@0
   164
	else
sl@0
   165
		{
sl@0
   166
		aTest.Printf(_L("--PRM--Database Encoding: UTF16\r\n"));
sl@0
   167
		aConfigStr.Append(_L8("encoding=\"UTF-16\";"));
sl@0
   168
		}
sl@0
   169
	
sl@0
   170
	aTest.Printf(_L("--PRM--Database page size: %d\r\n"), aCmdLineParams.iPageSize);
sl@0
   171
	TBuf8<20> pageSizeBuf;
sl@0
   172
	pageSizeBuf.Format(_L8("page_size=%d;"), aCmdLineParams.iPageSize);
sl@0
   173
	aConfigStr.Append(pageSizeBuf);
sl@0
   174
sl@0
   175
	aTest.Printf(_L("--PRM--Database cache size: %d\r\n"), aCmdLineParams.iCacheSize);
sl@0
   176
	TBuf8<20> cacheSizeBuf;
sl@0
   177
	cacheSizeBuf.Format(_L8("cache_size=%d;"), aCmdLineParams.iCacheSize);
sl@0
   178
	aConfigStr.Append(cacheSizeBuf);
sl@0
   179
	
sl@0
   180
	aTest.Printf(_L("--PRM--Database drive: %S\r\n"), &aCmdLineParams.iDriveName);
sl@0
   181
sl@0
   182
	if(aCmdLineParams.iSoftHeapLimitKb > 0)
sl@0
   183
		{
sl@0
   184
		aTest.Printf(_L("--PRM--Soft heap limit: %d Kb\r\n"), aCmdLineParams.iSoftHeapLimitKb);
sl@0
   185
		}
sl@0
   186
	else
sl@0
   187
		{
sl@0
   188
		aTest.Printf(_L("--PRM--Soft heap limit: default\r\n"));
sl@0
   189
		}
sl@0
   190
	}
sl@0
   191
sl@0
   192
#ifdef SQL_SOFT_HEAP_LIMIT_TEST	
sl@0
   193
sl@0
   194
static TInt KillProcess(const TDesC& aProcessName)
sl@0
   195
	{
sl@0
   196
	TFullName name;
sl@0
   197
	TBuf<64> pattern(aProcessName);
sl@0
   198
	TInt length = pattern.Length();
sl@0
   199
	pattern += _L("*");
sl@0
   200
	TFindProcess procFinder(pattern);
sl@0
   201
sl@0
   202
	while (procFinder.Next(name) == KErrNone)
sl@0
   203
		{
sl@0
   204
		if (name.Length() > length)
sl@0
   205
			{//If found name is a string containing aProcessName string.
sl@0
   206
			TChar c(name[length]);
sl@0
   207
			if (c.IsAlphaDigit() ||
sl@0
   208
				c == TChar('_') ||
sl@0
   209
				c == TChar('-'))
sl@0
   210
				{
sl@0
   211
				// If the found name is other valid application name
sl@0
   212
				// starting with aProcessName string.
sl@0
   213
				continue;
sl@0
   214
				}
sl@0
   215
			}
sl@0
   216
		RProcess proc;
sl@0
   217
		if (proc.Open(name) == KErrNone)
sl@0
   218
			{
sl@0
   219
			proc.Kill(0);
sl@0
   220
			}
sl@0
   221
		proc.Close();
sl@0
   222
		}
sl@0
   223
	return KErrNone;
sl@0
   224
	}
sl@0
   225
sl@0
   226
_LIT(KSqlSrvName, "sqlsrv.exe");
sl@0
   227
_LIT(KSqlSrvConfigFile, "c:\\test\\t_sqlserver.cfg");
sl@0
   228
sl@0
   229
static void ReplaceConfigFile(const TDesC16& aConfig)
sl@0
   230
	{
sl@0
   231
	RFs fs;
sl@0
   232
	TInt err = fs.Connect();
sl@0
   233
	__ASSERT_ALWAYS(err == KErrNone, User::Invariant());
sl@0
   234
	
sl@0
   235
	(void)KillProcess(KSqlSrvName);
sl@0
   236
	
sl@0
   237
	(void)fs.MkDirAll(KSqlSrvConfigFile);
sl@0
   238
	(void)fs.Delete(KSqlSrvConfigFile);
sl@0
   239
	
sl@0
   240
	RFile file;
sl@0
   241
	err = file.Create(fs, KSqlSrvConfigFile, EFileRead | EFileWrite);
sl@0
   242
	__ASSERT_ALWAYS(err == KErrNone, User::Invariant());
sl@0
   243
	
sl@0
   244
	TPtrC8 p((const TUint8*)aConfig.Ptr(), aConfig.Length() * sizeof(TUint16));
sl@0
   245
	err = file.Write(p);
sl@0
   246
	file.Close();
sl@0
   247
	__ASSERT_ALWAYS(err == KErrNone, User::Invariant());
sl@0
   248
	
sl@0
   249
	fs.Close();
sl@0
   250
	}
sl@0
   251
sl@0
   252
static void DeleteConfigFile()
sl@0
   253
	{
sl@0
   254
	RFs fs;
sl@0
   255
	TInt err = fs.Connect();
sl@0
   256
	__ASSERT_ALWAYS(err == KErrNone, User::Invariant());
sl@0
   257
	
sl@0
   258
	(void)KillProcess(KSqlSrvName);
sl@0
   259
	
sl@0
   260
	(void)fs.MkDirAll(KSqlSrvConfigFile);
sl@0
   261
	(void)fs.Delete(KSqlSrvConfigFile);
sl@0
   262
	
sl@0
   263
	fs.Close();
sl@0
   264
	}
sl@0
   265
sl@0
   266
#endif //SQL_SOFT_HEAP_LIMIT_TEST	
sl@0
   267
sl@0
   268
void GetCmdLineParamsAndSqlConfigString(RTest& aTest, const TDesC& aTestName, TCmdLineParams& aCmdLineParams, TDes8& aConfigStr)
sl@0
   269
	{
sl@0
   270
	TBuf<200> cmdLine;
sl@0
   271
	GetCmdLine(aTest, aTestName, cmdLine);
sl@0
   272
	RArray<TPtrC> prmNames;
sl@0
   273
	RArray<TPtrC> prmValues;
sl@0
   274
	ExtractCmdLineParams(cmdLine, prmNames, prmValues);
sl@0
   275
	ExtractParamNamesAndValues(prmNames, prmValues, aCmdLineParams);
sl@0
   276
	prmValues.Close();
sl@0
   277
	prmNames.Close();
sl@0
   278
	PrepareSqlConfigString(aTest, aCmdLineParams, aConfigStr);
sl@0
   279
	}
sl@0
   280
sl@0
   281
void PrepareDbName(const TDesC& aDeafultDbName, const TDriveName& aDriveName, TDes& aDbName)
sl@0
   282
	{
sl@0
   283
	TParse parse;
sl@0
   284
	parse.Set(aDriveName, &aDeafultDbName, 0);
sl@0
   285
	const TDesC& dbFilePath = parse.FullName();
sl@0
   286
	aDbName.Copy(dbFilePath);
sl@0
   287
	}
sl@0
   288
sl@0
   289
void SetSoftHeapLimit(TInt aSoftHeapLimit)
sl@0
   290
	{
sl@0
   291
	if(aSoftHeapLimit > 0)
sl@0
   292
		{
sl@0
   293
#ifdef SQL_SOFT_HEAP_LIMIT_TEST	
sl@0
   294
		TBuf<50> configBuf;
sl@0
   295
		configBuf.Format(_L("soft_heap_limit_kb=%d"), aSoftHeapLimit);
sl@0
   296
		ReplaceConfigFile(configBuf);
sl@0
   297
#else
sl@0
   298
		RDebug::Print(_L("The soft heap limit cannot be set if \"SQL_SOFT_HEAP_LIMIT_TEST\" macro is not defined!\r\n"));
sl@0
   299
#endif
sl@0
   300
		}
sl@0
   301
	else if(aSoftHeapLimit < 0)
sl@0
   302
		{
sl@0
   303
		RDebug::Print(_L("Soft heap limit of %d Kb cannot be set!\r\n"), aSoftHeapLimit);
sl@0
   304
		}
sl@0
   305
	}
sl@0
   306
sl@0
   307
void ResetSoftHeapLimit()
sl@0
   308
	{
sl@0
   309
#ifdef SQL_SOFT_HEAP_LIMIT_TEST	
sl@0
   310
	DeleteConfigFile();
sl@0
   311
#endif
sl@0
   312
	}
sl@0
   313