persistentstorage/sql/TEST/t_sqldefect2.cpp
author Shabe Razvi <shaber@symbian.org>
Tue, 19 Oct 2010 15:57:30 +0100
changeset 54 a0e1d366428c
parent 40 b8bdbc8f59c7
child 55 44f437012c90
permissions -rw-r--r--
Workaround for Bug 3854 - featuremgr bld.inf no longer exports features.dat for emulator
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
     1
// Copyright (c) 2006-2010 Nokia Corporation and/or its subsidiary(-ies).
0
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     2
// All rights reserved.
08ec8eefde2f 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
08ec8eefde2f 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"
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     5
// which accompanies this distribution, and is available
08ec8eefde2f 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".
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     7
//
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     8
// Initial Contributors:
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    10
//
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    11
// Contributors:
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    12
//
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    13
// Description:
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    14
//
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    15
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    16
#include <e32test.h>
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    17
#include <f32file.h>
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    18
#include <sqldb.h>
31
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
    19
#include <f32file.h>
0
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    20
///////////////////////////////////////////////////////////////////////////////////////
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    21
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    22
static RFs TheFs;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    23
static RTest TheTest(_L("t_sqldefect2 test"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    24
static RSqlDatabase TheDb1;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    25
static RSqlDatabase TheDb2;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    26
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    27
_LIT(KTestDir, "c:\\test\\");
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    28
_LIT(KTestDatabase1, "c:\\test\\t_sqldefect2.db");
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    29
_LIT(KTestDatabaseJournal1, "c:\\test\\t_sqldefect2.db-journal");
40
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
    30
_LIT(KServerTempDir, "c:\\private\\10281e17\\temp\\");
0
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    31
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    32
///////////////////////////////////////////////////////////////////////////////////////
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    33
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    34
//Deletes all created test files.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    35
void DestroyTestEnv()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    36
	{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    37
    TheDb2.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    38
    TheDb1.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    39
	(void)RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    40
	TheFs.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    41
	}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    42
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    43
///////////////////////////////////////////////////////////////////////////////////////
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    44
///////////////////////////////////////////////////////////////////////////////////////
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    45
//Test macros and functions
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    46
void Check1(TInt aValue, TInt aLine)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    47
	{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    48
	if(!aValue)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    49
		{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    50
		DestroyTestEnv();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    51
		RDebug::Print(_L("*** Line %d\r\n"), aLine);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    52
		TheTest(EFalse, aLine);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    53
		}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    54
	}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    55
void Check2(TInt aValue, TInt aExpected, TInt aLine)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    56
	{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    57
	if(aValue != aExpected)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    58
		{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    59
		DestroyTestEnv();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    60
		RDebug::Print(_L("*** Line %d, Expected error: %d, got: %d\r\n"), aLine, aExpected, aValue);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    61
		TheTest(EFalse, aLine);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    62
		}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    63
	}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    64
#define TEST(arg) ::Check1((arg), __LINE__)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    65
#define TEST2(aValue, aExpected) ::Check2(aValue, aExpected, __LINE__)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    66
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    67
///////////////////////////////////////////////////////////////////////////////////////
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    68
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    69
//Creates file session instance and the test directory
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    70
void CreateTestEnv()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    71
    {
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    72
	TInt err = TheFs.Connect();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    73
	TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    74
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    75
	err = TheFs.MkDir(KTestDir);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    76
	TEST(err == KErrNone || err == KErrAlreadyExists);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    77
	}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    78
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    79
/**
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    80
@SYMTestCaseID          PDS-SQL-CT-4154
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    81
@SYMTestCaseDesc        Test for DEF143062: SQL, "CREATE INDEX" sql crashes SQL server.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    82
                        The test creates a database with one empty table and establishes two connections
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    83
                        to that database. Then, while the first connection is at the middle of a read
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    84
                        transaction, the second connection attempts to create an index.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    85
                        If the defect is not fixed, the SQL server will crash.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    86
@SYMTestPriority        High
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    87
@SYMTestActions         DEF143062: SQL, "CREATE INDEX" sql crashes SQL server.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    88
@SYMTestExpectedResults Test must not fail
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    89
@SYMDEF                 DEF143062
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    90
*/
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    91
void DEF143062()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    92
    {
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    93
    (void)RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    94
    TInt err = TheDb1.Create(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    95
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    96
    err = TheDb1.Exec(_L("CREATE TABLE T0(Thread INTEGER, LocalIndex INTEGER, Inserts INTEGER, Updates INTEGER, IndexMod8 INTEGER)"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    97
    TEST(err >= 0);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    98
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    99
    err = TheDb2.Open(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   100
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   101
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   102
    RSqlStatement stmt;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   103
    err = stmt.Prepare(TheDb1, _L8("SELECT COUNT(Thread) FROM T0 WHERE Thread = 0"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   104
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   105
    err = stmt.Next();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   106
    TEST2(err, KSqlAtRow);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   107
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   108
    err = TheDb2.Exec(_L8("CREATE INDEX T0INDEX ON T0(Thread,IndexMod8)"));//crashes the SQL server if the defect is not fixed 
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   109
    TEST2(err, KSqlErrLocked);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   110
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   111
    stmt.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   112
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   113
    TheDb2.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   114
    TheDb1.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   115
    err = RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   116
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   117
    }
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   118
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   119
/**
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   120
@SYMTestCaseID          PDS-SQL-CT-4155
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   121
@SYMTestCaseDesc        Test for DEF143061: SQL, SQLITE_DEFAULT_JOURNAL_SIZE_LIMIT value is too big.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   122
                                         The test verifies that after comitting a big transaction, the journal file size is made equal the 
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   123
                                          max journal file size limit of 64Kb.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   124
@SYMTestPriority        High
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   125
@SYMTestActions         DEF143061: SQL, SQLITE_DEFAULT_JOURNAL_SIZE_LIMIT value is too big..
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   126
@SYMTestExpectedResults Test must not fail
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   127
@SYMDEF                 DEF143061
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   128
*/
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   129
void DEF143061()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   130
    {
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   131
    (void)RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   132
    //"Auto" compaction is used in order to see how the journal file is immediatelly used.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   133
    _LIT8(KConfig, "compaction=auto");
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   134
    TInt err = TheDb1.Create(KTestDatabase1, &KConfig);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   135
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   136
    err = TheDb1.Exec(_L("CREATE TABLE A(I INTEGER, B BLOB)"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   137
    TEST(err >= 0);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   138
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   139
    const TInt KBlobSize = 100000;//bigger than the journal size limit
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   140
    HBufC8* buf = HBufC8::New(KBlobSize);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   141
    TEST(buf != NULL);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   142
    TPtr8 ptr = buf->Des();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   143
    ptr.SetLength(KBlobSize);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   144
        
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   145
    RSqlStatement stmt;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   146
    err = stmt.Prepare(TheDb1, _L("INSERT INTO A VALUES(1, :Prm)"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   147
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   148
    ptr.Fill(TChar('N'));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   149
    err = stmt.BindBinary(0, ptr);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   150
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   151
    err = stmt.Exec();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   152
    TEST2(err, 1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   153
    stmt.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   154
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   155
    //Try to update the BLOB in the record that was just inserted. This operation should create a big journal file.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   156
    err = stmt.Prepare(TheDb1, _L("UPDATE A SET B=:Prm WHERE I=1"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   157
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   158
    ptr.Fill(TChar('Y'));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   159
    err = stmt.BindBinary(0, ptr);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   160
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   161
    err = stmt.Exec();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   162
    TEST2(err, 1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   163
    stmt.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   164
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   165
    //Check the journal file size. It should be less than the 64Kb limit defined in sqlite_macro.mmh file.  
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   166
    TEntry entry;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   167
    err = TheFs.Entry(KTestDatabaseJournal1, entry);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   168
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   169
    TInt64 fsize = entry.FileSize();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   170
    TEST(fsize <= SQLITE_DEFAULT_JOURNAL_SIZE_LIMIT);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   171
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   172
    delete buf;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   173
    TheDb1.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   174
    err = RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   175
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   176
    }
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   177
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   178
/**
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   179
@SYMTestCaseID          PDS-SQL-CT-4156
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   180
@SYMTestCaseDesc        Test for DEF143150: SQL, strftime() returns incorrect result.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   181
                        The test takes the current universal time (using TTime) 
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   182
                        and the current time retrieved from the SQL  server.
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   183
                        The test compares the times and expects the difference to be no more than
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   184
                        1 second. 
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   185
@SYMTestPriority        High
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   186
@SYMTestActions         DEF143150: SQL, strftime() returns incorrect result
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   187
@SYMTestExpectedResults Test must not fail
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   188
@SYMDEF                 DEF143150
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   189
*/
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   190
void DEF143150()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   191
    {
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   192
    (void)RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   193
    TInt err = TheDb1.Create(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   194
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   195
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   196
    //Home date & time
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   197
    TBuf<50> dtstr1;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   198
    TTime time;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   199
    time.UniversalTime();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   200
    TDateTime dt = time.DateTime();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   201
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   202
    RSqlStatement stmt;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   203
    err = stmt.Prepare(TheDb1, _L("SELECT strftime('%Y-%m-%d,%H:%M:%S','now')"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   204
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   205
    err = stmt.Next();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   206
    TEST2(err, KSqlAtRow);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   207
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   208
    //SQLite date & time
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   209
    TBuf<50> dtstr2;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   210
    err = stmt.ColumnText(0, dtstr2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   211
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   212
    stmt.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   213
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   214
    TheDb1.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   215
    err = RSqlDatabase::Delete(KTestDatabase1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   216
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   217
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   218
    dtstr1.Format(_L("%04d-%02d-%02d,%02d:%02d:%02d"), dt.Year(), dt.Month() + 1, dt.Day() + 1, dt.Hour(), dt.Minute(), dt.Second());
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   219
    TheTest.Printf(_L("Universal date&time=\"%S\"\n"), &dtstr1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   220
    TheTest.Printf(_L("SQLite    date&time=\"%S\"\n"), &dtstr2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   221
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   222
    //Comapare and fail if dates are not equal (+- 1 second)
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   223
    TLex lex;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   224
    lex = dtstr2.Mid(0, 4);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   225
    TInt sqlyear;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   226
    err = lex.Val(sqlyear);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   227
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   228
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   229
    lex = dtstr2.Mid(5, 2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   230
    TInt sqlmonth;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   231
    err = lex.Val(sqlmonth);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   232
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   233
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   234
    lex = dtstr2.Mid(8, 2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   235
    TInt sqlday;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   236
    err = lex.Val(sqlday);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   237
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   238
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   239
    lex = dtstr2.Mid(11, 2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   240
    TInt sqlhour;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   241
    err = lex.Val(sqlhour);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   242
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   243
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   244
    lex = dtstr2.Mid(14, 2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   245
    TInt sqlminute;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   246
    err = lex.Val(sqlminute);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   247
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   248
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   249
    lex = dtstr2.Mid(17, 2);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   250
    TInt sqlsecond;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   251
    err = lex.Val(sqlsecond);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   252
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   253
    
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   254
    TDateTime sqldt(sqlyear, (TMonth)(sqlmonth - 1), sqlday - 1, sqlhour, sqlminute, sqlsecond, 0);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   255
    TTime sqltime(sqldt);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   256
    TTimeIntervalSeconds diff;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   257
    err = sqltime.SecondsFrom(time, diff);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   258
    TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   259
    TEST(diff.Int() <= 1);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   260
    }
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   261
31
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   262
static TInt KillProcess(const TDesC& aProcessName)
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   263
    {
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   264
    TFullName name;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   265
    TBuf<64> pattern(aProcessName);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   266
    TInt length = pattern.Length();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   267
    pattern += _L("*");
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   268
    TFindProcess procFinder(pattern);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   269
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   270
    while (procFinder.Next(name) == KErrNone)
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   271
        {
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   272
        if (name.Length() > length)
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   273
            {//If found name is a string containing aProcessName string.
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   274
            TChar c(name[length]);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   275
            if (c.IsAlphaDigit() ||
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   276
                c == TChar('_') ||
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   277
                c == TChar('-'))
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   278
                {
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   279
                // If the found name is other valid application name
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   280
                // starting with aProcessName string.
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   281
                continue;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   282
                }
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   283
            }
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   284
        RProcess proc;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   285
        if (proc.Open(name) == KErrNone)
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   286
            {
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   287
            proc.Kill(0);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   288
            }
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   289
        proc.Close();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   290
        }
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   291
    return KErrNone;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   292
    }
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   293
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   294
/**
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   295
@SYMTestCaseID          PDS-SQL-CT-4210
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   296
@SYMTestCaseDesc        Test for the change "Temp files created during sql operations are not deleted after rebooting the phone" 
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   297
@SYMTestPriority        High
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   298
@SYMTestActions         Kill the sql server
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   299
                        Create two temp files in sql server's private directory
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   300
                        Start the sql server
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   301
                        Test that the temp files do not exist.
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   302
@SYMTestExpectedResults Test must not fail
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   303
*/
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   304
void DeleteTempFile()
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   305
    {   
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   306
    _LIT(KSqlSrvName, "sqlsrv.exe");
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   307
    _LIT(KTempFile1, "TMP00052.$$$");
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   308
    _LIT(KTempFile2, "TMP00044.$$$");
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   309
    
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   310
    KillProcess(KSqlSrvName);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   311
 
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   312
    //Create two temp file in c:\\private\\10281e17\\temp\\ folder
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   313
    TInt err = TheFs.MkDir(KServerTempDir);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   314
    TEST(err == KErrNone || err == KErrAlreadyExists);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   315
    RFile file;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   316
    TFileName filename1(KServerTempDir);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   317
    TFileName filename2(KServerTempDir);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   318
    filename1.Append(KTempFile1);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   319
    filename2.Append(KTempFile2);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   320
    err = file.Replace(TheFs, filename1, 0);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   321
    file.Close();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   322
    TEST2(err, KErrNone);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   323
    err = file.Replace(TheFs, filename2, 0);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   324
    file.Close();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   325
    TEST2(err, KErrNone);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   326
    
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   327
    //Create a database that should start sql server
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   328
    err = TheDb1.Create(KTestDatabase1);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   329
    TEST(err == KErrNone || err == KErrAlreadyExists);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   330
    //Test that the temp files have been deleted during server's start-up
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   331
    TUint dummy;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   332
    err = TheFs.Att(filename1, dummy);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   333
    TEST2(err, KErrNotFound);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   334
    err = TheFs.Att(filename2, dummy);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   335
    TEST2(err, KErrNotFound);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   336
    
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   337
    TheDb1.Close();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   338
    err = RSqlDatabase::Delete(KTestDatabase1);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   339
    TEST2(err, KErrNone);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   340
    }
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   341
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   342
TInt TempFilesCount()
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   343
	{
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   344
    _LIT(KServerTempDirMask, "c:\\private\\10281e17\\temp\\*.*");
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   345
	CDir* dir = NULL;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   346
	TInt err = TheFs.GetDir(KServerTempDirMask, KEntryAttNormal, ESortNone, dir);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   347
	TEST2(err, KErrNone);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   348
	TInt tmpFileCount = dir->Count();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   349
	delete dir;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   350
	return tmpFileCount;
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   351
	}
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   352
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   353
/**
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   354
@SYMTestCaseID          PDS-SQL-CT-4211
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   355
@SYMTestCaseDesc        Test for the change "Temp files created during sql operations are not deleted after rebooting the phone" 
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   356
@SYMTestPriority        High
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   357
@SYMTestActions         The test creates a database and runs a set of statements that
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   358
						will lead to a delayed creation of a temp file.
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   359
						At the end the test checks that the temp file was created.
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   360
@SYMTestExpectedResults Test must not fail
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   361
*/
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   362
void TempFileTest()
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   363
	{
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   364
    (void)RSqlDatabase::Delete(KTestDatabase1);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   365
    TInt err = TheDb1.Create(KTestDatabase1);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   366
    TEST2(err, KErrNone);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   367
    //Get the number of the files in the SQL temp directory 
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   368
	TInt tmpFileCount = TempFilesCount();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   369
    //    
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   370
    err = TheDb1.Exec(_L("CREATE TABLE t1(x UNIQUE); INSERT INTO t1 VALUES(1)"));
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   371
    TEST(err >= 0);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   372
    err = TheDb1.Exec(_L("BEGIN; UPDATE t1 SET x = 2; UPDATE t1 SET x = 3; COMMIT"));
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   373
    TEST(err >= 0);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   374
    //Check that a temp file really was created
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   375
	TInt tmpFileCount2 = TempFilesCount();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   376
	TEST(tmpFileCount2 > tmpFileCount);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   377
    //
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   378
    TheDb1.Close();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   379
    err = RSqlDatabase::Delete(KTestDatabase1);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   380
    TEST2(err, KErrNone);
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   381
	}
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   382
40
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   383
/**
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   384
@SYMTestCaseID          PDS-SQL-CT-4213
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   385
@SYMTestCaseDesc        Tests the ability of the SQL server to store empty strings and retrieve them as 
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   386
						text column values, not NULLs.
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   387
						Change: ou1cimx1#504388. 
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   388
@SYMTestPriority        High
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   389
@SYMTestActions         The test creates a database and a table and stores there empty strings.
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   390
						Then the test retrieves the stored column values and verifies that the column type is
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   391
						"text", not "null".
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   392
@SYMTestExpectedResults Test must not fail
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   393
*/
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   394
void EmptyTextColumnTest()
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   395
	{
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   396
	_LIT8(KEncUtf16, "encoding=\"UTF-16\"");
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   397
	_LIT8(KEncUtf8, "encoding=\"UTF-8\"");
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   398
	TPtrC8 enc[] = {KEncUtf16(), KEncUtf8()};
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   399
	for(TInt i=0;i<(sizeof(enc)/sizeof(enc[0]));++i)
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   400
		{
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   401
		(void)RSqlDatabase::Delete(KTestDatabase1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   402
		TInt err = TheDb1.Create(KTestDatabase1, &enc[i]);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   403
		TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   404
		//Insert records with empty text column values using RSqlDatabase::Exec()
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   405
	    err = TheDb1.Exec(_L("CREATE TABLE A(ID INTEGER, T TEXT)"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   406
	    TEST(err >= 0);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   407
	    err = TheDb1.Exec(_L("INSERT INTO A VALUES(1, '')"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   408
	    TEST2(err, 1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   409
	    err = TheDb1.Exec(_L8("INSERT INTO A VALUES(2, '')"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   410
	    TEST2(err, 1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   411
		//Insert a record with empty text column value using RSqlParamWriteStream
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   412
	    RSqlStatement stmt;
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   413
	    err = stmt.Prepare(TheDb1, _L("INSERT INTO A(ID, T) VALUES(:P1, :P2)"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   414
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   415
		err = stmt.BindInt(0, 3);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   416
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   417
	    RSqlParamWriteStream strm;
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   418
	    err = strm.BindText(stmt, 1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   419
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   420
	    TRAP(err, strm.WriteL(KNullDesC));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   421
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   422
	    strm.Close();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   423
	    err = stmt.Exec();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   424
	    TEST2(err, 1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   425
	    stmt.Close();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   426
		//Insert records with empty text column values using RSqlStatement::Bind()
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   427
	    err = stmt.Prepare(TheDb1, _L("INSERT INTO A(ID, T) VALUES(:P1, :P2)"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   428
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   429
		err = stmt.BindInt(0, 4);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   430
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   431
		err = stmt.BindText(1, KNullDesC);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   432
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   433
	    err = stmt.Exec();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   434
	    TEST2(err, 1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   435
	    //
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   436
	    err = stmt.Reset();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   437
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   438
		err = stmt.BindInt(0, 5);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   439
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   440
	    _LIT(KEmptyStr, "");
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   441
		err = stmt.BindText(1, KEmptyStr);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   442
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   443
	    err = stmt.Exec();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   444
	    TEST2(err, 1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   445
	    stmt.Close();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   446
	    //Read the empty text column values
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   447
	    err = stmt.Prepare(TheDb1, _L("SELECT T FROM A"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   448
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   449
	    TInt cnt = 0;
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   450
	    while((err = stmt.Next()) == KSqlAtRow)
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   451
	    	{
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   452
			++cnt;
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   453
			TPtrC val;
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   454
			err = stmt.ColumnText(0, val);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   455
			TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   456
			TEST2(val.Length(), 0);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   457
			TSqlColumnType type = stmt.ColumnType(0);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   458
			TEST2(type, ESqlText);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   459
	    	}
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   460
	    stmt.Close();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   461
	    TEST2(err, KSqlAtEnd);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   462
	    TEST2(cnt, 5);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   463
	    //
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   464
	    TheDb1.Close();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   465
	    err = RSqlDatabase::Delete(KTestDatabase1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   466
	    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   467
		}
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   468
	}
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   469
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   470
/**
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   471
@SYMTestCaseID          PDS-SQL-CT-4214
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   472
@SYMTestCaseDesc        Test for the change "After *#7370# Java apps are not preinstalled again" 
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   473
@SYMTestPriority        High
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   474
@SYMTestActions         The test makes sure there are no issues if the temp folder is removed after the server 
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   475
                        has already started. The test performs the following actions - 
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   476
                        1. Delete the 'temp' directory.
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   477
                        2. Create a transaction which creates temp files.
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   478
                        3. Check 'temp' folder exists at the end
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   479
@SYMTestExpectedResults Test must not fail
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   480
*/
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   481
void DeleteTempFolder()
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   482
    {
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   483
    //1. Delete 'temp' folder
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   484
    TInt err = TheFs.RmDir(KServerTempDir);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   485
    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   486
	
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   487
    //2. Create a transaction which creates temp files.
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   488
    (void)RSqlDatabase::Delete(KTestDatabase1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   489
    err = TheDb1.Create(KTestDatabase1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   490
    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   491
    
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   492
    err = TheDb1.Exec(_L("CREATE TABLE t1(x UNIQUE); INSERT INTO t1 VALUES(1)"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   493
    TEST(err >= 0);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   494
    err = TheDb1.Exec(_L("BEGIN; UPDATE t1 SET x = 2; UPDATE t1 SET x = 3; COMMIT"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   495
    TEST(err >= 0);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   496
    
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   497
    TheDb1.Close();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   498
    err = RSqlDatabase::Delete(KTestDatabase1);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   499
    TEST2(err, KErrNone);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   500
    
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   501
    //3. Check 'temp' folder exists
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   502
    err = TheFs.MkDir(KServerTempDir);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   503
    TEST2(err, KErrAlreadyExists);
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   504
    }	
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   505
	
0
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   506
void DoTestsL()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   507
	{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   508
	TheTest.Start(_L(" @SYMTestCaseID:SYSLIB-SQL-CT-4154 DEF143062: SQL, \"CREATE INDEX\" sql crashes SQL server"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   509
	DEF143062();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   510
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   511
    TheTest.Next(_L(" @SYMTestCaseID:SYSLIB-SQL-CT-4155 DEF143061: SQL, SQLITE_DEFAULT_JOURNAL_SIZE_LIMIT value is too big"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   512
    DEF143061();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   513
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   514
    TheTest.Next(_L(" @SYMTestCaseID:SYSLIB-SQL-CT-4156 DEF143150: SQL, strftime() returns incorrect result"));
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   515
    DEF143150();
31
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   516
    
40
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   517
    TheTest.Next(_L(" @SYMTestCaseID:PDS-SQL-CT-4210 Temp files created during sql operations are not deleted after rebooting the phone - 1"));
31
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   518
    DeleteTempFile();
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   519
    
40
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   520
    TheTest.Next(_L(" @SYMTestCaseID:PDS-SQL-CT-4211 Temp files created during sql operations are not deleted after rebooting the phone - 2"));
31
ba1c4f4a893f 201025_02
hgs
parents: 0
diff changeset
   521
    TempFileTest();
40
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   522
    
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   523
    TheTest.Next(_L(" @SYMTestCaseID:PDS-SQL-CT-4213 No support to store an empty string in symbian's sqlite."));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   524
    EmptyTextColumnTest();
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   525
	
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   526
	TheTest.Next(_L(" @SYMTestCaseID:PDS-SQL-CT-4214 After *#7370# Java apps are not preinstalled again"));
b8bdbc8f59c7 201031_02
hgs
parents: 31
diff changeset
   527
    DeleteTempFolder();
0
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   528
	}
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   529
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   530
TInt E32Main()
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   531
	{
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   532
	TheTest.Title();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   533
	
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   534
	CTrapCleanup* tc = CTrapCleanup::New();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   535
	
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   536
	__UHEAP_MARK;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   537
	
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   538
	CreateTestEnv();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   539
	TRAPD(err, DoTestsL());
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   540
	DestroyTestEnv();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   541
	TEST2(err, KErrNone);
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   542
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   543
	__UHEAP_MARKEND;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   544
	
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   545
	TheTest.End();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   546
	TheTest.Close();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   547
	
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   548
	delete tc;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   549
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   550
	User::Heap().Check();
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   551
	return KErrNone;
08ec8eefde2f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   552
	}