1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/os/graphics/printingservices/printerdriversupport/tps/T_PDRMEM.CPP Fri Jun 15 03:10:57 2012 +0200
1.3 @@ -0,0 +1,271 @@
1.4 +// Copyright (c) 1996-2010 Nokia Corporation and/or its subsidiary(-ies).
1.5 +// All rights reserved.
1.6 +// This component and the accompanying materials are made available
1.7 +// under the terms of "Eclipse Public License v1.0"
1.8 +// which accompanies this distribution, and is available
1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
1.10 +//
1.11 +// Initial Contributors:
1.12 +// Nokia Corporation - initial contribution.
1.13 +//
1.14 +// Contributors:
1.15 +//
1.16 +// Description:
1.17 +//
1.18 +
1.19 +#include "T_PDRMEM.H"
1.20 +
1.21 +_LIT( KDriveName, "z:" );
1.22 +_LIT( KEpsonFileName, "epson.pdr" );
1.23 +
1.24 +
1.25 +class CTPdrMem : public CTGraphicsBase
1.26 + {
1.27 +public:
1.28 + CTPdrMem(CTestStep* aStep);
1.29 +protected:
1.30 +//from CTGraphicsStep
1.31 + virtual void RunTestCaseL(TInt aCurTestCase);
1.32 +private:
1.33 + void TestNewL();
1.34 + void TestOpenPdrL();
1.35 + void TestCreatePrinterDeviceL();
1.36 + };
1.37 +
1.38 +CTPdrMem::CTPdrMem(CTestStep* aStep) :
1.39 + CTGraphicsBase(aStep)
1.40 + {
1.41 +
1.42 + }
1.43 +
1.44 +void CTPdrMem::RunTestCaseL(TInt aCurTestCase)
1.45 + {
1.46 + TInt ret;
1.47 + ((CTPdrMemStep*)iStep)->SetTestStepID(KUnknownSYMTestCaseIDName);
1.48 + switch(aCurTestCase)
1.49 + {
1.50 + case 1:
1.51 +/**
1.52 +@SYMTestCaseID GRAPHICS-PDRMEM-0001
1.53 +*/
1.54 + ((CTPdrMemStep*)iStep)->SetTestStepID(_L("GRAPHICS-PDRMEM-0001"));
1.55 + TRAP(ret,TestNewL());
1.56 + TEST(ret==KErrNone);
1.57 + break;
1.58 + case 2:
1.59 +/**
1.60 +@SYMTestCaseID GRAPHICS-PDRMEM-0002
1.61 +*/
1.62 + ((CTPdrMemStep*)iStep)->SetTestStepID(_L("GRAPHICS-PDRMEM-0002"));
1.63 + TRAP(ret,TestOpenPdrL());
1.64 + TEST(ret==KErrNone);
1.65 + break;
1.66 + case 3:
1.67 +/**
1.68 +@SYMTestCaseID GRAPHICS-PDRMEM-0003
1.69 +*/
1.70 + ((CTPdrMemStep*)iStep)->SetTestStepID(_L("GRAPHICS-PDRMEM-0003"));
1.71 + TRAP(ret,TestCreatePrinterDeviceL());
1.72 + TEST(ret==KErrNone);
1.73 + break;
1.74 + case 4:
1.75 + ((CTPdrMemStep*)iStep)->SetTestStepID(KNotATestSYMTestCaseIDName);
1.76 +// TRAP(ret,testGetNearestFontToDesignHeightInTwips());
1.77 +// TEST(ret==KErrNone);
1.78 + break;
1.79 + case 5:
1.80 + ((CTPdrMemStep*)iStep)->SetTestStepID(KNotATestSYMTestCaseIDName);
1.81 + ((CTPdrMemStep*)iStep)->CloseTMSGraphicsStep();
1.82 + TestComplete();
1.83 + break;
1.84 + }
1.85 + ((CTPdrMemStep*)iStep)->RecordTestResultL();
1.86 + }
1.87 +
1.88 +void CTPdrMem::TestNewL()
1.89 + {
1.90 + INFO_PRINTF1(_L("NewL"));
1.91 +
1.92 + TInt ret=KErrGeneral;
1.93 + CPrinterDriver *driver=NULL;
1.94 + TInt failRate=1;
1.95 +
1.96 + while (ret!=KErrNone)
1.97 + {
1.98 + __UHEAP_RESET;
1.99 + __UHEAP_SETFAIL(RHeap::EDeterministic,failRate);
1.100 + __UHEAP_MARK;
1.101 + TRAP(ret,driver=CPrinterDriver::NewL());
1.102 + RDebug::Print(_L("driver %d failrate %d\n"),driver,failRate);
1.103 + if (ret==KErrNoMemory)
1.104 + {
1.105 + __UHEAP_MARKEND;
1.106 + __UHEAP_RESET;
1.107 + TEST(driver==NULL);
1.108 + }
1.109 + else if(ret==KErrNone)
1.110 + {
1.111 + delete driver;
1.112 + __UHEAP_MARKEND;
1.113 + __UHEAP_RESET;
1.114 + __UHEAP_SETFAIL(RHeap::ENone,failRate);
1.115 + }
1.116 + else
1.117 + User::Panic(_L("Unknown error"),ret);
1.118 + failRate++;
1.119 + }
1.120 + }
1.121 +
1.122 +void CTPdrMem::TestOpenPdrL()
1.123 + {
1.124 + INFO_PRINTF1(_L("OpenPdrL"));
1.125 + TInt failRate=1;
1.126 + CPrinterDriver* driver=CPrinterDriver::NewL();
1.127 + TFileName filename( KDriveName );
1.128 + filename.Append( KDefaultPrinterDriverPath );
1.129 + filename.Append( KEpsonFileName );
1.130 + driver->OpenPdrL( filename );
1.131 + driver->Close();
1.132 + TInt ret=KErrGeneral;
1.133 +
1.134 + while (ret!=KErrNone)
1.135 + {
1.136 + __UHEAP_RESET;
1.137 + __UHEAP_SETFAIL(RHeap::EDeterministic,failRate);
1.138 + __UHEAP_MARK;
1.139 + TRAP(ret,driver->OpenPdrL( filename ));
1.140 + RDebug::Print(_L("NumModels %d failrate %d\n"),driver->NumModels(), failRate);
1.141 + if (ret==KErrNoMemory)
1.142 + {
1.143 + driver->Close();
1.144 + __UHEAP_MARKEND;
1.145 + __UHEAP_RESET;
1.146 + TEST(driver->NumModels()==0);
1.147 + }
1.148 + else if(ret==KErrNone)
1.149 + {
1.150 + driver->Close();
1.151 + __UHEAP_MARKEND;
1.152 + __UHEAP_RESET;
1.153 + __UHEAP_SETFAIL(RHeap::ENone,failRate);
1.154 + }
1.155 + else
1.156 + User::Panic(_L("Unknown error"),ret);
1.157 + failRate++;
1.158 + }
1.159 +
1.160 + delete driver;
1.161 +
1.162 + }
1.163 +
1.164 +void CTPdrMem::TestCreatePrinterDeviceL()
1.165 + {
1.166 +
1.167 + INFO_PRINTF1(_L("CreatePrinterDeviceL"));
1.168 + TInt failRate=1;
1.169 + CPrinterDriver* driver=CPrinterDriver::NewL();
1.170 + TFileName filename( KDriveName );
1.171 + filename.Append( KDefaultPrinterDriverPath );
1.172 + filename.Append( KEpsonFileName );
1.173 + driver->OpenPdrL( filename );
1.174 + TPrinterModelEntry entry;
1.175 + entry=driver->Model(0);
1.176 + RDebug::Print(_L("Drivers: %d\r\n"), driver->NumModels());
1.177 + RDebug::Print(_L("Model %d: %d\r\n"), 0, entry.iUid.iUid);
1.178 + CPrinterDevice* device=NULL;
1.179 + TInt ret=KErrGeneral;
1.180 +
1.181 + while(ret!=KErrNone)
1.182 + {
1.183 + __UHEAP_RESET;
1.184 + __UHEAP_SETFAIL(RHeap::EDeterministic,failRate);
1.185 + __UHEAP_MARK;
1.186 + TRAP(ret,device=driver->CreatePrinterDeviceL(entry.iUid));
1.187 + RDebug::Print(_L("device %d failrate %d\n"),device, failRate);
1.188 + if (ret==KErrNoMemory)
1.189 + {
1.190 + __UHEAP_MARKEND;
1.191 + __UHEAP_RESET;
1.192 + TEST(device==NULL);
1.193 + }
1.194 + else if (ret==KErrNone)
1.195 + {
1.196 + __UHEAP_RESET;
1.197 + __UHEAP_SETFAIL(RHeap::ENone,failRate);
1.198 + }
1.199 + else
1.200 + User::Panic(_L("Unknown error"),ret);
1.201 + failRate++;
1.202 + }
1.203 +
1.204 + delete driver;
1.205 +
1.206 + }
1.207 +
1.208 +//This test is useless.
1.209 +//It fails every time when calling device->GetNearestFontToDesignHeightInTwips().
1.210 +//device->GetNearestFontToDesignHeightInTwips() calls CFbsDrvDevice::LoadTypeFaceList()
1.211 +//which allocates additional memory for iGenTypefaceFontsType between
1.212 +//__UHEAP_MARK and __UHEAP_MARKEND macros.
1.213 +//CFbsDrvDevice takes care of deleting iGenTypefaceFontsType in its destructor.
1.214 +/*
1.215 +LOCAL_C void testGetNearestFontToDesignHeightInTwips()
1.216 + {
1.217 +
1.218 + INFO_PRINTF1(_L("GetNearestFontToDesignHeightInTwips"));
1.219 + CPrinterDriver* driver=CPrinterDriver::NewL();
1.220 + driver->OpenPdrL(_L("z:\\system\\printers\\epson.pdr"));
1.221 + TInt failRate=1;
1.222 + CFont *font;
1.223 + TFontSpec spec;
1.224 + spec.iTypeface.iName=_L("NewCourier");
1.225 + spec.iHeight=100;
1.226 + spec.iFontStyle.SetPosture(EPostureUpright);
1.227 + spec.iFontStyle.SetStrokeWeight(EStrokeWeightNormal);
1.228 + spec.iFontStyle.SetPrintPosition(EPrintPosNormal);
1.229 + TPrinterModelEntry entry;
1.230 + entry=driver->Model(0);
1.231 + CPrinterDevice* device=NULL;
1.232 + TRAPD(ret,device=driver->CreatePrinterDeviceL(entry.iUid));
1.233 + TEST(ret==KErrNone);
1.234 + ret=device->GetNearestFontToDesignHeightInTwips((CFont *&) font,spec);
1.235 + TEST(ret==KErrNone);
1.236 + device->ReleaseFont(font);
1.237 +
1.238 + ret=KErrGeneral;
1.239 +
1.240 + while(ret!=KErrNone)
1.241 + {
1.242 + __UHEAP_RESET;
1.243 + __UHEAP_SETFAIL(RHeap::EDeterministic,failRate);
1.244 + __UHEAP_MARK;
1.245 + font=NULL;
1.246 + ret = device->GetNearestFontToDesignHeightInTwips((CFont *&) font,spec);
1.247 + INFO_PRINTF2(_L("Font %d failrate %d\n"),font,failRate);
1.248 + if (ret==KErrNoMemory)
1.249 + {
1.250 + __UHEAP_MARKEND;
1.251 + __UHEAP_RESET;
1.252 + TEST(font==NULL);
1.253 + }
1.254 + else if (ret==KErrNone)
1.255 + {
1.256 +// device->ReleaseFont(font);
1.257 + font=NULL;
1.258 + __UHEAP_RESET;
1.259 + }
1.260 + else
1.261 + User::Panic(_L("Unknown error"),ret);
1.262 + failRate++;
1.263 + }
1.264 +
1.265 +
1.266 + delete driver;
1.267 +
1.268 + test.End();
1.269 + }
1.270 +*/
1.271 +
1.272 +//--------------
1.273 +__CONSTRUCT_STEP__(PdrMem)
1.274 +