Inheritance diagram for BackupRestoreTest:
Public Types | |
enum | OpType { OP_READ_SEQ, OP_WRITE_SEQ, OP_READ_RAND, OP_WRITE_RAND, OP_READ_NOWAIT, OP_WRITE_NOWAIT, OP_WRITE_SKIP, OP_SCRATCH, OP_PREFETCH, OP_PREFETCH_BATCH, OP_ALLOCATE, OP_DEALLOCATE, OP_CHECKPOINT, OP_RESIZE_CACHE, OP_MAX } |
The various operations that can be run in the multi-threaded test. More... | |
Public Member Functions | |
BackupRestoreTest () | |
void | testHeaderBackupRestore () |
Tests backup and restore of the database header pages. | |
void | testBackupCleanup () |
Tests that backup properly cleans up after either an error or an abort. | |
void | testBackupRestoreUncompressed () |
Tests backup and restore of data pages, without compression. | |
void | testBackupRestoreCompressed () |
Tests backup and restore of data pages, with compression. | |
virtual void | testCaseSetUp () |
Equivalent to JUnit TestCase.setUp; this is called before each test case method is invoked. | |
virtual void | openSegmentStorage (DeviceMode openMode) |
virtual void | closeStorage () |
virtual void | testAllocateAll () |
Initializes all disk pages, filling them with information based on their block numbers. | |
virtual void | verifyPage (CachePage &page, uint x) |
Verifies that the page contents are correct (based on the parameter x). | |
virtual void | fillPage (CachePage &page, uint x) |
Scribbles on the contents of a page. | |
virtual void | openStorage (DeviceMode openMode) |
virtual CachePage * | lockPage (OpType opType, uint iPage) |
virtual void | unlockPage (CachePage &page, LockMode lockMode) |
virtual void | prefetchPage (uint iPage) |
virtual void | prefetchBatch (uint, uint) |
virtual void | testAllocate () |
virtual void | testDeallocate () |
virtual void | testCheckpoint () |
Performs a periodic checkpoint. | |
void | testSingleThread () |
virtual void | openRandomSegment () |
SharedSegment | createLinearDeviceSegment (DeviceId deviceId, uint nPages) |
void | closeLinearSegment () |
void | closeRandomSegment () |
void | closeVersionedRandomSegment () |
void | closeSnapshotRandomSegment () |
Cache & | getCache () |
virtual SharedCache | newCache () |
SharedRandomAccessDevice | openDevice (std::string devName, DeviceMode openMode, uint nDevicePages, DeviceId deviceId) |
virtual void | testCaseTearDown () |
Equivalent to JUnit TestCase.tearDown; this is called after each test case method is invoked. | |
void | closeDevice (DeviceId deviceId, SharedRandomAccessDevice &pDevice) |
TestSuite * | releaseTestSuite () |
void | beforeTestCase (std::string testCaseName) |
void | afterTestCase (std::string testCaseName) |
virtual void | notifyTrace (std::string source, TraceLevel level, std::string message) |
Receives notification when a trace event occurs. | |
virtual TraceLevel | getSourceTraceLevel (std::string source) |
Gets the level at which a particular source should be traced. | |
bool | testOp (OpType opType, uint iPage, bool bNice) |
Carries out one operation on a page. | |
char const * | getOpName (OpType opType) |
Makes up an operation name based on an OpType. | |
LockMode | getLockMode (OpType opType) |
Gets the LockMode corresponding to an OpType. | |
void | testSequentialOp (OpType opType) |
Carries out an operation on each disk page in order from 0 to nDiskPages-1. | |
void | testRandomOp (OpType opType) |
Carries out an operation on nRandomOps pages selected at random. | |
void | testSkipOp (OpType opType, uint n) |
Carries out an operation on every "n" pages, starting at page 0. | |
void | testScratch () |
Performs nRandomOps scratch operations. | |
void | testPrefetch () |
Performs a limited number of prefetch operations. | |
void | testPrefetchBatch () |
Performs a limited number of batch prefetch operations. | |
void | testSequentialRead () |
Carries out one sequential read pass over the entire device. | |
void | testSequentialWrite () |
Carries out one sequential write pass over the entire device. | |
void | testRandomRead () |
Carries out nRandomOps read operations on pages selected at random. | |
void | testRandomWrite () |
Carries out nRandomOps write operations on pages selected at random. | |
void | testSkipWrite (uint n) |
Carries out write operations every n pages. | |
void | testCheckpointGuarded () |
void | testCacheResize () |
void | testMultipleThreads () |
Carries out specified tests in multi-threaded mode. | |
virtual void | threadInit () |
virtual void | threadTerminate () |
virtual bool | testThreadedOp (int iOp) |
Test implementation must be supplied by derived test class. | |
Static Public Member Functions | |
static void | readParams (int argc, char **argv) |
Parses the command line. | |
Static Public Attributes | |
static ParamName | paramTestSuiteName |
static ParamName | paramTraceFileName |
static ParamName | paramDictionaryFileName |
static ParamName | paramTraceLevel |
static ParamName | paramStatsFileName |
static ParamName | paramTraceStdout |
static ParamName | paramDegreeOfParallelism |
static ConfigMap | configMap |
Configuration parameters. | |
Protected Types | |
enum | VictimPolicy { victimTwoQ, victimLRU, victimRandom } |
The available victim policy implementations. More... | |
Protected Member Functions | |
void | setForceCacheUnmap (SharedSegment pSegment) |
Forces the underlying snapshot segment to always execute its checkpoints during a cache flush and unmap. | |
void | commitChanges (TxnId commitCsn) |
Commits transactions associated with a specified csn. | |
void | snooze (uint nSeconds) |
uint | generateRandomNumber (uint iMax) |
void | runThreadedTestCase () |
Executes specified test threads. | |
Protected Attributes | |
uint | nDiskPagesTotal |
PageId | firstPageId |
DeviceId | tempDeviceId |
SharedRandomAccessDevice | pTempDevice |
SharedSegment | pTempSegment |
TxnId | currCsn |
std::vector< TxnId > | updatedCsns |
bool | commit |
SharedSegment | pSnapshotRandomSegment2 |
std::vector< PageId > | freeablePages |
Queue of allocated pages waiting to be freed. | |
StrictMutex | freeablePagesMutex |
Mutex protecting freeablePages. | |
PageOwnerId | objId |
PageOwnerId to use when allocating pages. | |
SharedSegmentFactory | pSegmentFactory |
SharedSegment | pLinearSegment |
Segment supporting linear page allocation. | |
SharedSegment | pRandomSegment |
(Optional) segment supporting random page allocation. | |
SharedSegment | pVersionedRandomSegment |
(Optional) segment supporting versioned random page allocation. | |
SharedSegment | pSnapshotRandomSegment |
(Optional) segment supporting snapshot random page allocation. | |
VictimPolicy | victimPolicy |
VictimPolicy to instantiate. | |
CacheParams | cacheParams |
Parameters for cache initialization. | |
SharedCache | pCache |
Cache instance being tested. | |
SharedRandomAccessDevice | pRandomAccessDevice |
The default cached device. | |
uint | nMemPages |
Size of cache in memory pages. | |
uint | nDiskPages |
Size of device in disk pages. | |
uint | cbPageFull |
Disk page size. | |
DeviceId | dataDeviceId |
Fixed ID to assign to data device. | |
TestSuite * | pTestSuite |
Boost test suite. | |
boost::shared_ptr< TestBase > | pTestObj |
std::ofstream | traceStream |
Output file stream for tracing. | |
StrictMutex | traceMutex |
Protects traceStream. | |
std::string | testName |
Name of test. | |
TraceLevel | traceLevel |
Level at which to trace test execution. | |
FileStatsTarget | statsTarget |
Output for stats. | |
StatsTimer | statsTimer |
Timer for stats collection. | |
bool | traceStdout |
Copy trace output to stdout. | |
bool | traceFile |
Copy trace output to file. | |
TestCaseGroup | defaultTests |
TestCaseGroup | extraTests |
uint | cbPageUsable |
Portion of each page that should be scribbled on. | |
uint | nRandomOps |
Number of random access operations to run per pass. | |
uint | nSecondsBetweenCheckpoints |
Checkpoint interval during multi-threaded test. | |
StrictMutex | logMutex |
Protects output stream. | |
SXMutex | checkpointMutex |
SXMutex used to synchronize checkpoints with write actions. | |
bool | bTestResize |
Flag indicating that the cache should be dynamically resized during the multi-threaded portion of the test. | |
uint | nSeconds |
Duration of multi-threaded test. | |
std::vector< int > | threadCounts |
Number of threads to run for each type of operation. | |
Static Protected Attributes | |
static bool | runAll |
Run all test cases, including the extra tests. | |
static std::string | runSingle |
Run only the test case of this name. | |
Private Types | |
typedef SegNodeLock< TestNode > | TestPageLock |
Private Member Functions | |
void | createSnapshotData () |
void | executeSnapshotTxn (int i) |
void | verifySnapshotData (uint x) |
void | testBackupRestore (bool isCompressed) |
void | backup (std::string backupFileName, TxnId lowerBoundCsn, TxnId upperBoundCsn, bool isCompressed) |
void | restore (std::string backupFileName, TxnId lowerBoundCsn, TxnId upperBoundCsn, bool isCompressed) |
std::string | getCompressionProgram (bool isCompressed) |
void | verifyData () |
Private Attributes | |
SharedDatabase | pDatabase |
PageId | persistentPageId |
Classes | |
struct | TestNode |
Definition at line 43 of file BackupRestoreTest.cpp.
typedef SegNodeLock<TestNode> BackupRestoreTest::TestPageLock [private] |
Definition at line 52 of file BackupRestoreTest.cpp.
enum CacheTestBase::VictimPolicy [protected, inherited] |
The available victim policy implementations.
Definition at line 44 of file CacheTestBase.h.
00044 { 00045 victimTwoQ, 00046 victimLRU, 00047 victimRandom 00048 };
enum PagingTestBase::OpType [inherited] |
The various operations that can be run in the multi-threaded test.
Definition at line 83 of file PagingTestBase.h.
00083 { 00084 OP_READ_SEQ, 00085 OP_WRITE_SEQ, 00086 OP_READ_RAND, 00087 OP_WRITE_RAND, 00088 OP_READ_NOWAIT, 00089 OP_WRITE_NOWAIT, 00090 OP_WRITE_SKIP, 00091 OP_SCRATCH, 00092 OP_PREFETCH, 00093 OP_PREFETCH_BATCH, 00094 OP_ALLOCATE, 00095 OP_DEALLOCATE, 00096 OP_CHECKPOINT, 00097 OP_RESIZE_CACHE, 00098 OP_MAX 00099 };
BackupRestoreTest::BackupRestoreTest | ( | ) | [inline, explicit] |
Definition at line 76 of file BackupRestoreTest.cpp.
References testBackupCleanup(), testBackupRestoreCompressed(), testBackupRestoreUncompressed(), and testHeaderBackupRestore().
00077 { 00078 FENNEL_UNIT_TEST_CASE(BackupRestoreTest, testHeaderBackupRestore); 00079 FENNEL_UNIT_TEST_CASE(BackupRestoreTest, testBackupCleanup); 00080 FENNEL_UNIT_TEST_CASE(BackupRestoreTest, testBackupRestoreUncompressed); 00081 FENNEL_UNIT_TEST_CASE(BackupRestoreTest, testBackupRestoreCompressed); 00082 }
void BackupRestoreTest::createSnapshotData | ( | ) | [private] |
Definition at line 115 of file BackupRestoreTest.cpp.
References SegNodeLock< Node >::allocatePage(), Segment::checkpoint(), CHECKPOINT_FLUSH_ALL, SnapshotRandomAllocationSegment::commitChanges(), TestBase::configMap, DeviceMode::createNew, executeSnapshotTxn(), SegNodeLock< Node >::getNodeForWrite(), Database::newDatabase(), CacheTestBase::pCache, pDatabase, persistentPageId, and SegPageLock::unlock().
Referenced by testBackupCleanup(), and testHeaderBackupRestore().
00116 { 00117 // Create a database with a single data page with an initial value of 0. 00118 pDatabase = Database::newDatabase( 00119 pCache, 00120 configMap, 00121 DeviceMode::createNew, 00122 shared_from_this()); 00123 00124 SharedLogicalTxn pTxn = pDatabase->getTxnLog()->newLogicalTxn(pCache); 00125 SharedSegment pSegment = 00126 pDatabase->getSegmentFactory()->newSnapshotRandomAllocationSegment( 00127 pDatabase->getDataSegment(), 00128 pDatabase->getDataSegment(), 00129 pTxn->getTxnId()); 00130 SnapshotRandomAllocationSegment *pSnapshotSegment = 00131 SegmentFactory::dynamicCast<SnapshotRandomAllocationSegment *>( 00132 pSegment); 00133 SegmentAccessor segmentAccessor(pSegment,pCache); 00134 00135 TestPageLock pageLock(segmentAccessor); 00136 persistentPageId = pageLock.allocatePage(); 00137 pageLock.getNodeForWrite().x = 0; 00138 pageLock.unlock(); 00139 pTxn->commit(); 00140 pTxn = pDatabase->getTxnLog()->newLogicalTxn(pCache); 00141 pSnapshotSegment->commitChanges(pTxn->getTxnId()); 00142 pSnapshotSegment->checkpoint(CHECKPOINT_FLUSH_ALL); 00143 pTxn->commit(); 00144 pDatabase->checkpointImpl(); 00145 00146 // Update the value to 5. 00147 executeSnapshotTxn(5); 00148 }
void BackupRestoreTest::executeSnapshotTxn | ( | int | i | ) | [private] |
Definition at line 376 of file BackupRestoreTest.cpp.
References Segment::checkpoint(), CHECKPOINT_FLUSH_ALL, SnapshotRandomAllocationSegment::commitChanges(), SegNodeLock< Node >::getNodeForWrite(), SegPageLock::lockExclusive(), CacheTestBase::pCache, pDatabase, persistentPageId, and SegPageLock::unlock().
Referenced by createSnapshotData(), testBackupCleanup(), and testHeaderBackupRestore().
00377 { 00378 SharedLogicalTxn pTxn = pDatabase->getTxnLog()->newLogicalTxn(pCache); 00379 SharedSegment pSegment = 00380 pDatabase->getSegmentFactory()->newSnapshotRandomAllocationSegment( 00381 pDatabase->getDataSegment(), 00382 pDatabase->getDataSegment(), 00383 pTxn->getTxnId()); 00384 SnapshotRandomAllocationSegment *pSnapshotSegment = 00385 SegmentFactory::dynamicCast<SnapshotRandomAllocationSegment *>( 00386 pSegment); 00387 00388 // Update the value, which will version the page. 00389 SegmentAccessor segmentAccessor(pSegment, pCache); 00390 TestPageLock pageLock(segmentAccessor); 00391 pageLock.lockExclusive(persistentPageId); 00392 pageLock.getNodeForWrite().x += i; 00393 pageLock.unlock(); 00394 pTxn->commit(); 00395 00396 // Commit the changes through the snapshot segment. 00397 pTxn = pDatabase->getTxnLog()->newLogicalTxn(pCache); 00398 pSnapshotSegment->commitChanges(pTxn->getTxnId()); 00399 pSnapshotSegment->checkpoint(CHECKPOINT_FLUSH_ALL); 00400 pTxn->commit(); 00401 pDatabase->checkpointImpl(); 00402 }
void BackupRestoreTest::verifySnapshotData | ( | uint | x | ) | [private] |
Definition at line 404 of file BackupRestoreTest.cpp.
References SegNodeLock< Node >::getNodeForRead(), SegPageLock::lockShared(), CacheTestBase::pCache, pDatabase, and persistentPageId.
Referenced by testBackupCleanup(), and testHeaderBackupRestore().
00405 { 00406 // Lock the original page, but because we're accessing the segment 00407 // through a snapshot segment with the csn set to that of the last 00408 // committed transaction, we'll pick up the latest version of the page. 00409 SharedSegment pSegment = 00410 pDatabase->getSegmentFactory()->newSnapshotRandomAllocationSegment( 00411 pDatabase->getDataSegment(), 00412 pDatabase->getDataSegment(), 00413 pDatabase->getLastCommittedTxnId()); 00414 SegmentAccessor segmentAccessor(pSegment,pCache); 00415 TestPageLock pageLock(segmentAccessor); 00416 pageLock.lockShared(persistentPageId); 00417 BOOST_CHECK_EQUAL(pageLock.getNodeForRead().x,x); 00418 }
void BackupRestoreTest::testBackupRestore | ( | bool | isCompressed | ) | [private] |
Definition at line 420 of file BackupRestoreTest.cpp.
References backup(), SnapshotSegmentTestBase::closeStorage(), DeviceMode::createNew, SnapshotSegmentTestBase::currCsn, DeviceMode::load, NULL_TXN_ID, SegmentTestBase::openStorage(), restore(), SnapshotSegmentTestBase::testAllocateAll(), PagingTestBase::testSkipWrite(), SnapshotSegmentTestBase::updatedCsns, and verifyData().
Referenced by testBackupRestoreCompressed(), and testBackupRestoreUncompressed().
00421 { 00422 // Create and initialize a VersionedRandomAllocationSegment using 00423 // a snapshot with TxnId(0) 00424 currCsn = TxnId(0); 00425 openStorage(DeviceMode::createNew); 00426 testAllocateAll(); 00427 closeStorage(); 00428 00429 // Update every 5 pages 00430 currCsn = TxnId(5); 00431 updatedCsns.push_back(currCsn); 00432 openStorage(DeviceMode::load); 00433 testSkipWrite(5); 00434 closeStorage(); 00435 00436 // Do a backup of all pages as of TxnId 5 00437 std::string backup5 = "backupTxnId5.dat"; 00438 backup(backup5, NULL_TXN_ID, TxnId(5), isCompressed); 00439 00440 // Update every 7 pages 00441 currCsn = TxnId(7); 00442 updatedCsns.push_back(currCsn); 00443 openStorage(DeviceMode::load); 00444 testSkipWrite(7); 00445 closeStorage(); 00446 00447 // Do another backup of all pages between TxnId's 5 and 7 00448 std::string backup5to7 = "backupTxnId5to7.dat"; 00449 backup(backup5to7, TxnId(5), TxnId(7), isCompressed); 00450 00451 // Update every 11 pages 00452 currCsn = TxnId(11); 00453 updatedCsns.push_back(currCsn); 00454 openStorage(DeviceMode::load); 00455 testSkipWrite(11); 00456 closeStorage(); 00457 00458 // Do a backup of all pages between TxnId's 7 and 11 00459 std::string backup7to11 = "backupTxnId7to11.dat"; 00460 backup(backup7to11, TxnId(7), TxnId(11), isCompressed); 00461 00462 // Do a backup of all pages between TxnId's 5 and 11 00463 std::string backup5to11 = "backupTxnId5to11.dat"; 00464 backup(backup5to11, TxnId(5), TxnId(11), isCompressed); 00465 00466 // Restore the backup as of TxnId 5 00467 restore(backup5, NULL_TXN_ID, TxnId(5), isCompressed); 00468 00469 // Make sure the data only reflects up to TxnId 5. Leave the currCsn 00470 // set to the larger value, but have updatedCsn's reflect only the 00471 // updates up to TxnId 5. 00472 updatedCsns.clear(); 00473 updatedCsns.push_back(TxnId(5)); 00474 verifyData(); 00475 00476 // Restore the backup as of TxnId 7 and verify that it only includes 00477 // updates up to TxnId 7 00478 restore(backup5to7, TxnId(5), TxnId(7), isCompressed); 00479 updatedCsns.push_back(TxnId(7)); 00480 verifyData(); 00481 00482 // Restore the backup as of TxnId 11 and verify that it includes all 00483 // updates 00484 restore(backup7to11, TxnId(7), TxnId(11), isCompressed); 00485 updatedCsns.push_back(TxnId(11)); 00486 verifyData(); 00487 00488 // Go back and do restores of the backup at TxnId5 followed by the 00489 // backup of TxnId's 5 through 11. 00490 restore(backup5, NULL_TXN_ID, TxnId(5), isCompressed); 00491 updatedCsns.clear(); 00492 updatedCsns.push_back(TxnId(5)); 00493 verifyData(); 00494 restore(backup5to11, TxnId(5), TxnId(11), isCompressed); 00495 updatedCsns.push_back(TxnId(7)); 00496 updatedCsns.push_back(TxnId(11)); 00497 verifyData(); 00498 }
void BackupRestoreTest::backup | ( | std::string | backupFileName, | |
TxnId | lowerBoundCsn, | |||
TxnId | upperBoundCsn, | |||
bool | isCompressed | |||
) | [private] |
Definition at line 500 of file BackupRestoreTest.cpp.
References VersionedRandomAllocationSegment::backupAllocationNodes(), VersionedRandomAllocationSegment::backupDataPages(), SnapshotSegmentTestBase::closeStorage(), getCompressionProgram(), DeviceMode::load, SegPageBackupRestoreDevice::newSegPageBackupRestoreDevice(), SegmentTestBase::openStorage(), CacheTestBase::pCache, CacheTestBase::pRandomAccessDevice, SegStorageTestBase::pSegmentFactory, and SegStorageTestBase::pVersionedRandomSegment.
Referenced by testBackupRestore().
00505 { 00506 openStorage(DeviceMode::load); 00507 VersionedRandomAllocationSegment *pVRSegment = 00508 SegmentFactory::dynamicCast<VersionedRandomAllocationSegment *>( 00509 pVersionedRandomSegment); 00510 SegmentAccessor scratchAccessor = 00511 pSegmentFactory->newScratchSegment(pCache, 12); 00512 00513 if (isCompressed) { 00514 backupFileName.append(".gz"); 00515 } 00516 SharedSegPageBackupRestoreDevice pBackupDevice = 00517 SegPageBackupRestoreDevice::newSegPageBackupRestoreDevice( 00518 backupFileName, 00519 "w", 00520 getCompressionProgram(isCompressed), 00521 10, 00522 2, 00523 scratchAccessor, 00524 pCache->getDeviceAccessScheduler(*pRandomAccessDevice), 00525 pRandomAccessDevice); 00526 bool abortFlag = false; 00527 pVRSegment->backupAllocationNodes( 00528 pBackupDevice, 00529 false, 00530 lowerBoundCsn, 00531 upperBoundCsn, 00532 abortFlag); 00533 pVRSegment->backupDataPages( 00534 pBackupDevice, 00535 lowerBoundCsn, 00536 upperBoundCsn, 00537 abortFlag); 00538 00539 assert(pBackupDevice.unique()); 00540 pBackupDevice.reset(); 00541 00542 scratchAccessor.reset(); 00543 closeStorage(); 00544 }
void BackupRestoreTest::restore | ( | std::string | backupFileName, | |
TxnId | lowerBoundCsn, | |||
TxnId | upperBoundCsn, | |||
bool | isCompressed | |||
) | [private] |
Definition at line 546 of file BackupRestoreTest.cpp.
References CHECKPOINT_FLUSH_AND_UNMAP, SnapshotSegmentTestBase::closeStorage(), getCompressionProgram(), DeviceMode::load, SegPageBackupRestoreDevice::newSegPageBackupRestoreDevice(), SegmentTestBase::openStorage(), CacheTestBase::pCache, CacheTestBase::pRandomAccessDevice, SegStorageTestBase::pSegmentFactory, SegStorageTestBase::pVersionedRandomSegment, and VersionedRandomAllocationSegment::restoreFromBackup().
Referenced by testBackupRestore().
00551 { 00552 openStorage(DeviceMode::load); 00553 VersionedRandomAllocationSegment *pVRSegment = 00554 SegmentFactory::dynamicCast<VersionedRandomAllocationSegment *>( 00555 pVersionedRandomSegment); 00556 SegmentAccessor scratchAccessor = 00557 pSegmentFactory->newScratchSegment(pCache, 10); 00558 00559 // Flush and unmap any pages currently in the cache so the restore 00560 // avoids reading out-of-date pages 00561 MappedPageListenerPredicate pagePredicate(*pVRSegment); 00562 pCache->checkpointPages(pagePredicate, CHECKPOINT_FLUSH_AND_UNMAP); 00563 00564 if (isCompressed) { 00565 backupFileName.append(".gz"); 00566 } 00567 SharedSegPageBackupRestoreDevice pBackupDevice = 00568 SegPageBackupRestoreDevice::newSegPageBackupRestoreDevice( 00569 backupFileName, 00570 "r", 00571 getCompressionProgram(isCompressed), 00572 10, 00573 0, 00574 scratchAccessor, 00575 pCache->getDeviceAccessScheduler(*pRandomAccessDevice), 00576 pRandomAccessDevice); 00577 bool abortFlag = false; 00578 pVRSegment->restoreFromBackup( 00579 pBackupDevice, 00580 lowerBoundCsn, 00581 upperBoundCsn, 00582 abortFlag); 00583 00584 assert(pBackupDevice.unique()); 00585 pBackupDevice.reset(); 00586 00587 scratchAccessor.reset(); 00588 closeStorage(); 00589 }
std::string BackupRestoreTest::getCompressionProgram | ( | bool | isCompressed | ) | [private] |
Definition at line 591 of file BackupRestoreTest.cpp.
Referenced by backup(), restore(), and testBackupCleanup().
00592 { 00593 if (!isCompressed) { 00594 return ""; 00595 } else { 00596 return "gzip"; 00597 } 00598 }
void BackupRestoreTest::verifyData | ( | ) | [private] |
Definition at line 600 of file BackupRestoreTest.cpp.
References SnapshotSegmentTestBase::closeStorage(), DeviceMode::load, SegmentTestBase::openStorage(), and PagingTestBase::testSequentialRead().
Referenced by testBackupRestore().
00601 { 00602 openStorage(DeviceMode::load); 00603 testSequentialRead(); 00604 closeStorage(); 00605 }
void BackupRestoreTest::testHeaderBackupRestore | ( | ) |
Tests backup and restore of the database header pages.
Definition at line 150 of file BackupRestoreTest.cpp.
References CacheTestBase::cacheParams, TestBase::configMap, createSnapshotData(), executeSnapshotTxn(), Cache::newCache(), NULL_TXN_ID, Database::paramDatabaseDir, CacheTestBase::pCache, pDatabase, CacheParams::readConfig(), ConfigMap::setStringParam(), and verifySnapshotData().
Referenced by BackupRestoreTest().
00151 { 00152 configMap.setStringParam( 00153 Database::paramDatabaseDir,"."); 00154 configMap.setStringParam( 00155 "databaseInitSize","1000"); 00156 configMap.setStringParam( 00157 "tempInitSize","1000"); 00158 configMap.setStringParam( 00159 "databaseShadowLogInitSize","1000"); 00160 configMap.setStringParam( 00161 "databaseTxnLogInitSize","1000"); 00162 configMap.setStringParam( 00163 "forceTxns","true"); 00164 configMap.setStringParam( 00165 "disableSnapshots","false"); 00166 00167 CacheParams cacheParams; 00168 cacheParams.readConfig(configMap); 00169 pCache = Cache::newCache(cacheParams); 00170 00171 // Create a single data page in the database with an initial value, 00172 // and then update the value to 5. Doing the update will version 00173 // the data page. 00174 createSnapshotData(); 00175 pDatabase->checkpointImpl(); 00176 verifySnapshotData(5); 00177 00178 // Backup the data with value 5. 00179 std::string fullBackup = "fullBackup.dat"; 00180 FileSize dataDeviceSize; 00181 bool aborted = false; 00182 TxnId fullTxnId = 00183 pDatabase->initiateBackup( 00184 fullBackup, 00185 false, 00186 0, 00187 NULL_TXN_ID, 00188 "", 00189 dataDeviceSize, 00190 aborted); 00191 pDatabase->completeBackup(NULL_TXN_ID, fullTxnId, aborted); 00192 00193 // Update the value to 15. 00194 executeSnapshotTxn(10); 00195 verifySnapshotData(15); 00196 00197 // Do an incremental backup of value 15. 00198 std::string incrBackup1 = "incrBackup1.dat"; 00199 TxnId incrTxnId1 = 00200 pDatabase->initiateBackup( 00201 incrBackup1, 00202 true, 00203 0, 00204 fullTxnId, 00205 "", 00206 dataDeviceSize, 00207 aborted); 00208 00209 // Make sure ALTER SYSTEM DEALLOCATE OLD is disabled 00210 uint nPagesBefore = 00211 pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00212 pDatabase->deallocateOldPages(incrTxnId1); 00213 uint nPagesAfter = 00214 pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00215 BOOST_REQUIRE(nPagesBefore == nPagesAfter); 00216 00217 pDatabase->completeBackup(fullTxnId, incrTxnId1, aborted); 00218 00219 // Make sure ALTER SYSTEM DEALLOCATE OLD is reenabled 00220 pDatabase->deallocateOldPages(incrTxnId1); 00221 nPagesAfter = pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00222 BOOST_REQUIRE(nPagesBefore > nPagesAfter); 00223 00224 // Update the value to 35. 00225 executeSnapshotTxn(20); 00226 verifySnapshotData(35); 00227 00228 // Do a second incremental backup with value 35. 00229 std::string incrBackup2 = "incrBackup2.dat"; 00230 TxnId incrTxnId2 = 00231 pDatabase->initiateBackup( 00232 incrBackup2, 00233 true, 00234 4096, 00235 incrTxnId1, 00236 "", 00237 dataDeviceSize, 00238 aborted); 00239 pDatabase->completeBackup(incrTxnId1, incrTxnId2, aborted); 00240 00241 // Restore the full backup. The value should be 5. 00242 pDatabase->restoreFromBackup( 00243 fullBackup, 00244 1002 * pCache->getPageSize(), 00245 "", 00246 NULL_TXN_ID, 00247 fullTxnId, 00248 aborted); 00249 verifySnapshotData(5); 00250 00251 // Restore the first incremental backup. The value should be 15. 00252 pDatabase->restoreFromBackup( 00253 incrBackup1, 00254 1002 * pCache->getPageSize(), 00255 "", 00256 fullTxnId, 00257 incrTxnId1, 00258 aborted); 00259 verifySnapshotData(15); 00260 00261 // Restore the second incremental backup. The value should be 35. 00262 pDatabase->restoreFromBackup( 00263 incrBackup2, 00264 1002 * pCache->getPageSize(), 00265 "", 00266 incrTxnId1, 00267 incrTxnId2, 00268 aborted); 00269 verifySnapshotData(35); 00270 00271 pDatabase.reset(); 00272 }
void BackupRestoreTest::testBackupCleanup | ( | ) |
Tests that backup properly cleans up after either an error or an abort.
Definition at line 274 of file BackupRestoreTest.cpp.
References CacheTestBase::cacheParams, TestBase::configMap, createSnapshotData(), executeSnapshotTxn(), getCompressionProgram(), FileSystem::getDiskFreeSpace(), FennelExcn::getMessage(), Cache::newCache(), NULL_TXN_ID, Database::paramDatabaseDir, CacheTestBase::pCache, pDatabase, CacheParams::readConfig(), FileSystem::remove(), ConfigMap::setStringParam(), and verifySnapshotData().
Referenced by BackupRestoreTest().
00275 { 00276 configMap.setStringParam( 00277 Database::paramDatabaseDir,"."); 00278 configMap.setStringParam( 00279 "databaseInitSize","1000"); 00280 configMap.setStringParam( 00281 "tempInitSize","1000"); 00282 configMap.setStringParam( 00283 "databaseShadowLogInitSize","1000"); 00284 configMap.setStringParam( 00285 "databaseTxnLogInitSize","1000"); 00286 configMap.setStringParam( 00287 "forceTxns","true"); 00288 configMap.setStringParam( 00289 "disableSnapshots","false"); 00290 00291 CacheParams cacheParams; 00292 cacheParams.readConfig(configMap); 00293 pCache = Cache::newCache(cacheParams); 00294 00295 // Create a single data page in the database with an initial value, 00296 // and then update the value to 5. Doing the update will version 00297 // the data page. 00298 createSnapshotData(); 00299 pDatabase->checkpointImpl(); 00300 verifySnapshotData(5); 00301 00302 // Update the value to 15. 00303 executeSnapshotTxn(10); 00304 verifySnapshotData(15); 00305 00306 std::string fullBackup = "fullBackup.dat"; 00307 00308 // Set the space padding to the amount of space currently available 00309 // multipled by 1000. This should result in a failure unless some other 00310 // user is using this filesystem and either: 00311 // A) that user is freeing up a large amount of space, or 00312 // B) that user is freeing up space and the filesystem is short on space, 00313 // in which case, multiplying by 1000 doesn't yield a large enough value 00314 // to offset the amount that the user has freed 00315 FileSystem::remove(fullBackup.c_str()); 00316 FileSize spaceAvailable; 00317 FileSystem::getDiskFreeSpace(".", spaceAvailable); 00318 FileSize dataDeviceSize; 00319 bool aborted = false; 00320 try { 00321 pDatabase->initiateBackup( 00322 fullBackup, 00323 true, 00324 spaceAvailable * 1000, 00325 NULL_TXN_ID, 00326 "", 00327 dataDeviceSize, 00328 aborted); 00329 BOOST_FAIL("Out of space exception not returned"); 00330 } catch (FennelExcn &ex) { 00331 std::string errMsg = ex.getMessage(); 00332 if (errMsg.find("Insufficient space") != 0) { 00333 BOOST_FAIL("Wrong exception returned"); 00334 } 00335 } 00336 00337 // Make sure ALTER SYSTEM DEALLOCATE OLD is enabled, even after the 00338 // exception 00339 uint nPagesBefore = 00340 pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00341 pDatabase->deallocateOldPages(pDatabase->getLastCommittedTxnId()); 00342 uint nPagesAfter = 00343 pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00344 BOOST_REQUIRE(nPagesBefore > nPagesAfter); 00345 00346 // Do another update so a new page is allocated 00347 executeSnapshotTxn(20); 00348 verifySnapshotData(35); 00349 00350 // Initiate a new backup and then abort it. 00351 pDatabase->initiateBackup( 00352 fullBackup, 00353 false, 00354 0, 00355 NULL_TXN_ID, 00356 getCompressionProgram(true), 00357 dataDeviceSize, 00358 aborted); 00359 pDatabase->abortBackup(); 00360 00361 // Make sure ALTER SYSTEM DEALLOCATE OLD is enabled, even after the 00362 // backup was aborted 00363 nPagesBefore = 00364 pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00365 pDatabase->deallocateOldPages(pDatabase->getLastCommittedTxnId()); 00366 nPagesAfter = 00367 pDatabase->getDataSegment()->getAllocatedSizeInPages(); 00368 BOOST_REQUIRE(nPagesBefore > nPagesAfter); 00369 00370 // Abort a backup that was never initiated; should be a no-op 00371 pDatabase->abortBackup(); 00372 00373 pDatabase.reset(); 00374 }
void BackupRestoreTest::testBackupRestoreUncompressed | ( | ) |
Tests backup and restore of data pages, without compression.
Definition at line 105 of file BackupRestoreTest.cpp.
References testBackupRestore().
Referenced by BackupRestoreTest().
00106 { 00107 testBackupRestore(false); 00108 }
void BackupRestoreTest::testBackupRestoreCompressed | ( | ) |
Tests backup and restore of data pages, with compression.
Definition at line 110 of file BackupRestoreTest.cpp.
References testBackupRestore().
Referenced by BackupRestoreTest().
00111 { 00112 testBackupRestore(true); 00113 }
void SnapshotSegmentTestBase::setForceCacheUnmap | ( | SharedSegment | pSegment | ) | [protected, inherited] |
Forces the underlying snapshot segment to always execute its checkpoints during a cache flush and unmap.
Definition at line 87 of file SnapshotSegmentTestBase.cpp.
References SnapshotRandomAllocationSegment::setForceCacheUnmap().
Referenced by SnapshotSegmentTestBase::openSegmentStorage(), LcsClusterReplaceExecStreamTest::testClusterReplace(), and SnapshotSegmentTest::testUncommittedReads().
00088 { 00089 // Force the snapshot segment to always execute its checkpoints during 00090 // a cache flush and unmap, in order to unmap these page from the cache 00091 if (pSegment) { 00092 SnapshotRandomAllocationSegment *pSnapshotSegment = 00093 SegmentFactory::dynamicCast<SnapshotRandomAllocationSegment *>( 00094 pSegment); 00095 pSnapshotSegment->setForceCacheUnmap(); 00096 } 00097 }
void SnapshotSegmentTestBase::commitChanges | ( | TxnId | commitCsn | ) | [protected, inherited] |
Commits transactions associated with a specified csn.
commitCsn | the specified csn |
Definition at line 161 of file SnapshotSegmentTestBase.cpp.
References SnapshotSegmentTestBase::commit, SnapshotRandomAllocationSegment::commitChanges(), SegStorageTestBase::pSnapshotRandomSegment, and SnapshotRandomAllocationSegment::rollbackChanges().
Referenced by SnapshotSegmentTestBase::closeStorage().
00162 { 00163 if (pSnapshotRandomSegment) { 00164 SnapshotRandomAllocationSegment *pSnapshotSegment = 00165 SegmentFactory::dynamicCast<SnapshotRandomAllocationSegment *>( 00166 pSnapshotRandomSegment); 00167 if (commit) { 00168 pSnapshotSegment->commitChanges(commitCsn); 00169 } else { 00170 pSnapshotSegment->rollbackChanges(); 00171 } 00172 } 00173 }
void SnapshotSegmentTestBase::testCaseSetUp | ( | ) | [virtual, inherited] |
Equivalent to JUnit TestCase.setUp; this is called before each test case method is invoked.
Default is no-op.
Reimplemented from TestBase.
Reimplemented in LcsClusterReplaceExecStreamTest.
Definition at line 40 of file SnapshotSegmentTestBase.cpp.
References SnapshotSegmentTestBase::commit, SnapshotSegmentTestBase::currCsn, and SnapshotSegmentTestBase::updatedCsns.
Referenced by LcsClusterReplaceExecStreamTest::testCaseSetUp().
00041 { 00042 currCsn = TxnId(0); 00043 commit = true; 00044 updatedCsns.clear(); 00045 }
void SnapshotSegmentTestBase::openSegmentStorage | ( | DeviceMode | openMode | ) | [virtual, inherited] |
Reimplemented from SegStorageTestBase.
Definition at line 47 of file SnapshotSegmentTestBase.cpp.
References DeviceMode::create, SegStorageTestBase::createLinearDeviceSegment(), SnapshotSegmentTestBase::currCsn, CacheTestBase::dataDeviceId, SnapshotSegmentTestBase::firstPageId, CacheTestBase::nDiskPages, SnapshotSegmentTestBase::nDiskPagesTotal, NULL_PAGE_ID, CacheTestBase::openDevice(), SegStorageTestBase::pLinearSegment, SegStorageTestBase::pRandomSegment, SegStorageTestBase::pSegmentFactory, SegStorageTestBase::pSnapshotRandomSegment, SnapshotSegmentTestBase::pTempDevice, SnapshotSegmentTestBase::pTempSegment, SegStorageTestBase::pVersionedRandomSegment, SnapshotSegmentTestBase::setForceCacheUnmap(), and SnapshotSegmentTestBase::tempDeviceId.
00048 { 00049 nDiskPages = nDiskPagesTotal; 00050 if (openMode.create) { 00051 firstPageId = NULL_PAGE_ID; 00052 } 00053 00054 pTempDevice = 00055 openDevice("temp.dat", openMode, nDiskPages / 50, tempDeviceId); 00056 SharedSegment pTempDeviceSegment = 00057 createLinearDeviceSegment(tempDeviceId, nDiskPages / 50); 00058 pTempSegment = 00059 pSegmentFactory->newRandomAllocationSegment( 00060 pTempDeviceSegment, 00061 openMode.create); 00062 00063 SharedSegment pDeviceSegment = 00064 createLinearDeviceSegment(dataDeviceId, nDiskPages); 00065 pVersionedRandomSegment = 00066 pSegmentFactory->newVersionedRandomAllocationSegment( 00067 pDeviceSegment, 00068 pTempSegment, 00069 openMode.create); 00070 pSnapshotRandomSegment = 00071 pSegmentFactory->newSnapshotRandomAllocationSegment( 00072 pVersionedRandomSegment, 00073 pVersionedRandomSegment, 00074 currCsn); 00075 setForceCacheUnmap(pSnapshotRandomSegment); 00076 00077 pRandomSegment = pSnapshotRandomSegment; 00078 00079 nDiskPages /= 2; 00080 SharedSegment pLinearViewSegment = 00081 pSegmentFactory->newLinearViewSegment( 00082 pSnapshotRandomSegment, 00083 firstPageId); 00084 pLinearSegment = pLinearViewSegment; 00085 }
void SnapshotSegmentTestBase::closeStorage | ( | ) | [virtual, inherited] |
Reimplemented from SegStorageTestBase.
Definition at line 99 of file SnapshotSegmentTestBase.cpp.
References CacheTestBase::closeDevice(), SegStorageTestBase::closeLinearSegment(), SegStorageTestBase::closeSnapshotRandomSegment(), SegStorageTestBase::closeStorage(), SegStorageTestBase::closeVersionedRandomSegment(), SnapshotSegmentTestBase::commitChanges(), SnapshotSegmentTestBase::currCsn, VersionedRandomAllocationSegment::freeTempPages(), SegStorageTestBase::pRandomSegment, SnapshotSegmentTestBase::pSnapshotRandomSegment2, SnapshotSegmentTestBase::pTempDevice, SnapshotSegmentTestBase::pTempSegment, SegStorageTestBase::pVersionedRandomSegment, and SnapshotSegmentTestBase::tempDeviceId.
Referenced by backup(), SnapshotSegmentTest::deallocateOldPages(), restore(), testBackupRestore(), SnapshotSegmentTest::testDeallocateOld(), SnapshotSegmentTest::testRollback(), SnapshotSegmentTest::testSnapshotReads(), SnapshotSegmentTest::testUncommittedReads(), and verifyData().
00100 { 00101 commitChanges(currCsn); 00102 closeLinearSegment(); 00103 pRandomSegment.reset(); 00104 closeSnapshotRandomSegment(); 00105 if (pSnapshotRandomSegment2) { 00106 assert(pSnapshotRandomSegment2.unique()); 00107 pSnapshotRandomSegment2.reset(); 00108 } 00109 // Free leftover temp pages used during page versioning 00110 if (pVersionedRandomSegment) { 00111 VersionedRandomAllocationSegment *pVRSegment = 00112 SegmentFactory::dynamicCast<VersionedRandomAllocationSegment *>( 00113 pVersionedRandomSegment); 00114 pVRSegment->freeTempPages(); 00115 } 00116 closeVersionedRandomSegment(); 00117 if (pTempSegment) { 00118 // Confirm that all temp pages have been freed. 00119 BOOST_REQUIRE(pTempSegment->getAllocatedSizeInPages() == 0); 00120 assert(pTempSegment.unique()); 00121 pTempSegment.reset(); 00122 } 00123 if (pTempDevice) { 00124 closeDevice(tempDeviceId, pTempDevice); 00125 } 00126 SegmentTestBase::closeStorage(); 00127 }
void SnapshotSegmentTestBase::testAllocateAll | ( | ) | [virtual, inherited] |
Initializes all disk pages, filling them with information based on their block numbers.
Reimplemented from PagingTestBase.
Definition at line 129 of file SnapshotSegmentTestBase.cpp.
References SnapshotSegmentTestBase::firstPageId, LinearViewSegment::getFirstPageId(), NULL_PAGE_ID, SegStorageTestBase::pLinearSegment, and PagingTestBase::testAllocateAll().
Referenced by testBackupRestore(), SnapshotSegmentTest::testDeallocateOld(), SnapshotSegmentTest::testRollback(), SnapshotSegmentTest::testSnapshotReads(), and SnapshotSegmentTest::testUncommittedReads().
00130 { 00131 SegmentTestBase::testAllocateAll(); 00132 assert(firstPageId == NULL_PAGE_ID); 00133 LinearViewSegment *pLinearViewSegment = 00134 SegmentFactory::dynamicCast<LinearViewSegment *>(pLinearSegment); 00135 assert(pLinearViewSegment); 00136 firstPageId = pLinearViewSegment->getFirstPageId(); 00137 }
Verifies that the page contents are correct (based on the parameter x).
Reimplemented from PagingTestBase.
Definition at line 139 of file SnapshotSegmentTestBase.cpp.
References SnapshotSegmentTestBase::currCsn, opaqueToInt(), SnapshotSegmentTestBase::updatedCsns, and PagingTestBase::verifyPage().
00140 { 00141 // If the pageId is a multiple of one of the csn's smaller than the 00142 // current csn, then the page should reflect the update made by 00143 // that smaller csn 00144 uint update = 0; 00145 for (int i = updatedCsns.size() - 1; i >= 0; i--) { 00146 if (updatedCsns[i] <= currCsn && 00147 x % opaqueToInt(updatedCsns[i]) == 0) 00148 { 00149 update = opaqueToInt(updatedCsns[i]); 00150 break; 00151 } 00152 } 00153 SegmentTestBase::verifyPage(page, x + update); 00154 }
Scribbles on the contents of a page.
The data written is derived from the parameter x.
Reimplemented from PagingTestBase.
Definition at line 156 of file SnapshotSegmentTestBase.cpp.
References SnapshotSegmentTestBase::currCsn, PagingTestBase::fillPage(), and opaqueToInt().
00157 { 00158 SegmentTestBase::fillPage(page, x + opaqueToInt(currCsn)); 00159 }
void SegmentTestBase::openStorage | ( | DeviceMode | openMode | ) | [virtual, inherited] |
Reimplemented from SegStorageTestBase.
Definition at line 37 of file SegmentTestBase.cpp.
References PagingTestBase::cbPageUsable, PagingTestBase::OP_ALLOCATE, PagingTestBase::OP_DEALLOCATE, SegStorageTestBase::openStorage(), SegStorageTestBase::pLinearSegment, SegStorageTestBase::pRandomSegment, and ThreadedTestBase::threadCounts.
Referenced by backup(), SnapshotSegmentTest::deallocateOldPages(), restore(), RandomAllocationSegmentTest::testAllocateAndDeallocate(), testBackupRestore(), SnapshotSegmentTest::testDeallocateOld(), VersionedSegmentTest::testRecovery(), SnapshotSegmentTest::testRollback(), SegmentTestBase::testSingleThread(), SnapshotSegmentTest::testSnapshotReads(), SnapshotSegmentTest::testUncommittedReads(), and verifyData().
00038 { 00039 SegStorageTestBase::openStorage(openMode); 00040 cbPageUsable = pLinearSegment->getUsablePageSize(); 00041 if (!pRandomSegment) { 00042 threadCounts[OP_ALLOCATE] = 0; 00043 threadCounts[OP_DEALLOCATE] = 0; 00044 } 00045 }
Implements PagingTestBase.
Definition at line 47 of file SegmentTestBase.cpp.
References SegPageLock::allocatePage(), SegPageLock::dontUnlock(), PagingTestBase::fillPage(), Segment::getLinearBlockNum(), Segment::getLinearPageId(), PagingTestBase::getLockMode(), SegPageLock::getPage(), SegPageLock::isLocked(), SegPageLock::lockPage(), SegmentTestBase::objId, PagingTestBase::OP_ALLOCATE, PagingTestBase::OP_WRITE_RAND, PagingTestBase::OP_WRITE_SEQ, PagingTestBase::OP_WRITE_SKIP, CacheTestBase::pCache, and SegStorageTestBase::pLinearSegment.
00048 { 00049 SegmentAccessor segmentAccessor(pLinearSegment,pCache); 00050 SegPageLock pageLock(segmentAccessor); 00051 if (opType == OP_ALLOCATE) { 00052 PageId pageId = pageLock.allocatePage(objId); 00053 assert(Segment::getLinearBlockNum(pageId) == iPage); 00054 CachePage &page = pageLock.getPage(); 00055 fillPage(page,iPage); 00056 pageLock.dontUnlock(); 00057 return &page; 00058 } else { 00059 PageId pageId = Segment::getLinearPageId(iPage); 00060 // Prepare the page for update before locking it 00061 if (opType == OP_WRITE_SEQ || opType == OP_WRITE_RAND || 00062 opType == OP_WRITE_SKIP) 00063 { 00064 pLinearSegment->updatePage(pageId, true); 00065 } 00066 pageLock.lockPage(pageId,getLockMode(opType)); 00067 CachePage *pPage = pageLock.isLocked() ? &(pageLock.getPage()) : NULL; 00068 pageLock.dontUnlock(); 00069 return pPage; 00070 } 00071 }
Implements PagingTestBase.
Definition at line 73 of file SegmentTestBase.cpp.
References CacheTestBase::getCache(), and CacheAccessor::unlockPage().
00074 { 00075 getCache().unlockPage(page,lockMode); 00076 }
void SegmentTestBase::prefetchPage | ( | uint | iPage | ) | [virtual, inherited] |
Implements PagingTestBase.
Definition at line 78 of file SegmentTestBase.cpp.
References CacheTestBase::getCache(), Segment::getLinearPageId(), SegStorageTestBase::pLinearSegment, and CacheAccessor::prefetchPage().
00079 { 00080 PageId pageId = Segment::getLinearPageId(iPage); 00081 BlockId blockId = pLinearSegment->translatePageId(pageId); 00082 getCache().prefetchPage(blockId,pLinearSegment.get()); 00083 }
void SegmentTestBase::testAllocate | ( | ) | [virtual, inherited] |
Reimplemented from PagingTestBase.
Definition at line 90 of file SegmentTestBase.cpp.
References SegmentTestBase::freeablePages, SegmentTestBase::freeablePagesMutex, PagingTestBase::logMutex, PagingTestBase::nRandomOps, NULL_PAGE_ID, SegmentTestBase::objId, CacheTestBase::pCache, SegStorageTestBase::pRandomSegment, SegPageLock::tryAllocatePage(), and SegPageLock::unlock().
00091 { 00092 assert(pRandomSegment); 00093 00094 uint i; 00095 SegmentAccessor segmentAccessor(pRandomSegment,pCache); 00096 for (i = 0; i < nRandomOps; ++i) { 00097 #ifdef HAVE_SCHED_H 00098 sched_yield(); 00099 #else 00100 // TODO: call Mingw equivalent 00101 #endif 00102 SegPageLock pageLock(segmentAccessor); 00103 PageId pageId = pageLock.tryAllocatePage(objId); 00104 if (pageId == NULL_PAGE_ID) { 00105 break; 00106 } 00107 pageLock.unlock(); 00108 StrictMutexGuard freeablePagesGuard(freeablePagesMutex); 00109 freeablePages.push_back(pageId); 00110 } 00111 if (i) { 00112 StrictMutexGuard logGuard(logMutex); 00113 BOOST_MESSAGE("completed " << i << " allocate ops"); 00114 } 00115 }
void SegmentTestBase::testDeallocate | ( | ) | [virtual, inherited] |
Reimplemented from PagingTestBase.
Definition at line 117 of file SegmentTestBase.cpp.
References SegPageLock::deallocateLockedPage(), SegmentTestBase::freeablePages, SegmentTestBase::freeablePagesMutex, PagingTestBase::generateRandomNumber(), SegPageLock::lockShared(), PagingTestBase::logMutex, PagingTestBase::nRandomOps, CacheTestBase::pCache, and SegStorageTestBase::pRandomSegment.
00118 { 00119 assert(pRandomSegment); 00120 00121 uint i; 00122 SegmentAccessor segmentAccessor(pRandomSegment,pCache); 00123 for (i = 0; i < nRandomOps; ++i) { 00124 #ifdef HAVE_SCHED_H 00125 sched_yield(); 00126 #else 00127 // TODO: call Mingw equivalent 00128 #endif 00129 StrictMutexGuard freeablePagesGuard(freeablePagesMutex); 00130 if (freeablePages.empty()) { 00131 break; 00132 } 00133 uint i = generateRandomNumber(freeablePages.size()); 00134 PageId pageId = freeablePages[i]; 00135 freeablePages.erase(freeablePages.begin() + i); 00136 freeablePagesGuard.unlock(); 00137 SegPageLock pageLock(segmentAccessor); 00138 pageLock.lockShared(pageId); 00139 pageLock.deallocateLockedPage(); 00140 } 00141 if (i) { 00142 StrictMutexGuard logGuard(logMutex); 00143 BOOST_MESSAGE("completed " << i << " deallocate ops"); 00144 } 00145 }
void SegmentTestBase::testCheckpoint | ( | ) | [virtual, inherited] |
Performs a periodic checkpoint.
Reimplemented from PagingTestBase.
Reimplemented in VersionedSegmentTest.
Definition at line 147 of file SegmentTestBase.cpp.
References CHECKPOINT_FLUSH_ALL, and SegStorageTestBase::pLinearSegment.
00148 { 00149 pLinearSegment->checkpoint(CHECKPOINT_FLUSH_ALL); 00150 }
void SegmentTestBase::testSingleThread | ( | ) | [inherited] |
Definition at line 161 of file SegmentTestBase.cpp.
References SegStorageTestBase::closeStorage(), DeviceMode::createNew, SegmentTestBase::freeablePages, DeviceMode::load, SegmentTestBase::openStorage(), PagingTestBase::testAllocateAll(), PagingTestBase::testRandomRead(), PagingTestBase::testRandomWrite(), PagingTestBase::testSequentialRead(), and PagingTestBase::testSequentialWrite().
Referenced by LinearDeviceSegmentTest::LinearDeviceSegmentTest(), LinearViewSegmentTest::LinearViewSegmentTest(), SnapshotSegmentTest::SnapshotSegmentTest(), and VersionedSegmentTest::VersionedSegmentTest().
00162 { 00163 openStorage(DeviceMode::createNew); 00164 testAllocateAll(); 00165 testSequentialRead(); 00166 testSequentialWrite(); 00167 testRandomRead(); 00168 closeStorage(); 00169 openStorage(DeviceMode::load); 00170 testRandomRead(); 00171 testRandomWrite(); 00172 testSequentialRead(); 00173 closeStorage(); 00174 freeablePages.clear(); 00175 }
void SegStorageTestBase::openRandomSegment | ( | ) | [virtual, inherited] |
Reimplemented in LcsClusterReplaceExecStreamTest.
Definition at line 45 of file SegStorageTestBase.cpp.
References SegStorageTestBase::closeStorage(), DeviceMode::load, SegStorageTestBase::openStorage(), SegStorageTestBase::pLinearSegment, SegStorageTestBase::pRandomSegment, and SegStorageTestBase::pSegmentFactory.
Referenced by RandomAllocationSegmentTest::testAllocateAndDeallocate(), LhxHashTableTest::testCaseSetUp(), ExecStreamUnitTestBase::testCaseSetUp(), BTreeTest::testCaseSetUp(), and BTreeReadersTest::testCaseSetUp().
00046 { 00047 // reopen will interpret pages as already allocated, which 00048 // is what RandomAllocationSegment expects 00049 closeStorage(); 00050 openStorage(DeviceMode::load); 00051 pRandomSegment = pSegmentFactory->newRandomAllocationSegment( 00052 pLinearSegment, true); 00053 pLinearSegment.reset(); 00054 }
SharedSegment SegStorageTestBase::createLinearDeviceSegment | ( | DeviceId | deviceId, | |
uint | nPages | |||
) | [inherited] |
Definition at line 56 of file SegStorageTestBase.cpp.
References LinearDeviceSegmentParams::firstBlockId, LinearDeviceSegmentParams::nPagesAllocated, LinearDeviceSegmentParams::nPagesMin, CacheTestBase::pCache, SegStorageTestBase::pSegmentFactory, CompoundId::setBlockNum(), and CompoundId::setDeviceId().
Referenced by VersionedSegmentTest::openSegmentStorage(), SnapshotSegmentTestBase::openSegmentStorage(), SegStorageTestBase::openSegmentStorage(), and LinearViewSegmentTest::openSegmentStorage().
00058 { 00059 BlockId blockId(0); 00060 CompoundId::setDeviceId(blockId,deviceId); 00061 CompoundId::setBlockNum(blockId,0); 00062 LinearDeviceSegmentParams deviceParams; 00063 deviceParams.firstBlockId = blockId; 00064 deviceParams.nPagesMin = nPages; 00065 deviceParams.nPagesAllocated = nPages; 00066 return pSegmentFactory->newLinearDeviceSegment( 00067 pCache,deviceParams); 00068 }
void SegStorageTestBase::closeLinearSegment | ( | ) | [inherited] |
Definition at line 70 of file SegStorageTestBase.cpp.
References SegStorageTestBase::pLinearSegment.
Referenced by VersionedSegmentTest::closeStorage(), SnapshotSegmentTestBase::closeStorage(), SegStorageTestBase::closeStorage(), and SnapshotSegmentTest::testUncommittedReads().
00071 { 00072 if (pLinearSegment) { 00073 assert(pLinearSegment.unique()); 00074 pLinearSegment.reset(); 00075 } 00076 }
void SegStorageTestBase::closeRandomSegment | ( | ) | [inherited] |
Definition at line 78 of file SegStorageTestBase.cpp.
References SegStorageTestBase::pRandomSegment.
Referenced by VersionedSegmentTest::closeStorage(), and SegStorageTestBase::closeStorage().
00079 { 00080 if (pRandomSegment) { 00081 assert(pRandomSegment.unique()); 00082 pRandomSegment.reset(); 00083 } 00084 }
void SegStorageTestBase::closeVersionedRandomSegment | ( | ) | [inherited] |
Definition at line 86 of file SegStorageTestBase.cpp.
References SegStorageTestBase::pVersionedRandomSegment.
Referenced by SnapshotSegmentTestBase::closeStorage(), and SegStorageTestBase::closeStorage().
00087 { 00088 if (pVersionedRandomSegment) { 00089 assert(pVersionedRandomSegment.unique()); 00090 pVersionedRandomSegment.reset(); 00091 } 00092 }
void SegStorageTestBase::closeSnapshotRandomSegment | ( | ) | [inherited] |
Definition at line 94 of file SegStorageTestBase.cpp.
References SegStorageTestBase::pSnapshotRandomSegment.
Referenced by SnapshotSegmentTestBase::closeStorage().
00095 { 00096 if (pSnapshotRandomSegment) { 00097 assert(pSnapshotRandomSegment.unique()); 00098 pSnapshotRandomSegment.reset(); 00099 } 00100 }
Cache & CacheTestBase::getCache | ( | ) | [inherited] |
Definition at line 42 of file CacheTestBase.cpp.
References CacheTestBase::pCache.
Referenced by CacheTest::lockPage(), CacheTest::prefetchBatch(), SegmentTestBase::prefetchPage(), CacheTest::prefetchPage(), PagingTestBase::testCacheResize(), PagingTestBase::testCheckpoint(), PagingTestBase::testOp(), PagingTestBase::testScratch(), SegmentTestBase::unlockPage(), and CacheTest::unlockPage().
00043 { 00044 return *pCache; 00045 }
SharedCache CacheTestBase::newCache | ( | ) | [virtual, inherited] |
Definition at line 66 of file CacheTestBase.cpp.
References CacheTestBase::cacheParams, Cache::newCache(), CacheTestBase::victimLRU, CacheTestBase::victimPolicy, CacheTestBase::victimRandom, and CacheTestBase::victimTwoQ.
Referenced by CacheTestBase::openStorage().
00067 { 00068 switch (victimPolicy) { 00069 case victimRandom: 00070 return SharedCache( 00071 new RandomCache(cacheParams), 00072 ClosableObjectDestructor()); 00073 case victimLRU: 00074 return SharedCache( 00075 new LRUCache(cacheParams), 00076 ClosableObjectDestructor()); 00077 case victimTwoQ: 00078 return Cache::newCache(cacheParams); 00079 default: 00080 permAssert(false); 00081 } 00082 }
SharedRandomAccessDevice CacheTestBase::openDevice | ( | std::string | devName, | |
DeviceMode | openMode, | |||
uint | nDevicePages, | |||
DeviceId | deviceId | |||
) | [inherited] |
Definition at line 84 of file CacheTestBase.cpp.
References CacheTestBase::cbPageFull, DeviceMode::create, CacheTestBase::pCache, and FileSystem::remove().
Referenced by VersionedSegmentTest::openSegmentStorage(), SnapshotSegmentTestBase::openSegmentStorage(), and CacheTestBase::openStorage().
00087 { 00088 if (openMode.create) { 00089 FileSystem::remove(devName.c_str()); 00090 } 00091 SharedRandomAccessDevice pDevice( 00092 new RandomAccessFileDevice(devName,openMode)); 00093 if (openMode.create) { 00094 pDevice->setSizeInBytes(nDevicePages*cbPageFull); 00095 } 00096 pCache->registerDevice(deviceId,pDevice); 00097 return pDevice; 00098 }
void CacheTestBase::testCaseTearDown | ( | ) | [virtual, inherited] |
Equivalent to JUnit TestCase.tearDown; this is called after each test case method is invoked.
Default is no-op.
Reimplemented from TestBase.
Reimplemented in LbmEntryTest, LbmLoadBitmapTest, LbmSearchTest, LcsClusterAppendExecStreamTest, LcsClusterReplaceExecStreamTest, LcsMultiClusterAppendTest, LcsRowScanExecStreamTest, BTreeReadersTest, BTreeTest, ExecStreamTestBase, and LhxHashTableTest.
Definition at line 125 of file CacheTestBase.cpp.
References CacheTestBase::closeStorage().
Referenced by LhxHashTableTest::testCaseTearDown(), ExecStreamTestBase::testCaseTearDown(), BTreeTest::testCaseTearDown(), BTreeReadersTest::testCaseTearDown(), and LbmEntryTest::testCaseTearDown().
00126 { 00127 closeStorage(); 00128 }
void CacheTestBase::closeDevice | ( | DeviceId | deviceId, | |
SharedRandomAccessDevice & | pDevice | |||
) | [inherited] |
Definition at line 130 of file CacheTestBase.cpp.
References CHECKPOINT_FLUSH_AND_UNMAP, and CacheTestBase::pCache.
Referenced by VersionedSegmentTest::closeStorage(), SnapshotSegmentTestBase::closeStorage(), and CacheTestBase::closeStorage().
00132 { 00133 if (!pDevice) { 00134 return; 00135 } 00136 DeviceIdPagePredicate pagePredicate(deviceId); 00137 pCache->checkpointPages(pagePredicate,CHECKPOINT_FLUSH_AND_UNMAP); 00138 pCache->unregisterDevice(deviceId); 00139 assert(pDevice.unique()); 00140 pDevice.reset(); 00141 }
void TestBase::snooze | ( | uint | nSeconds | ) | [protected, inherited] |
Definition at line 263 of file TestBase.cpp.
Referenced by DatabaseTest::executeForceTxn(), ThreadedTestBase::runThreadedTestCase(), PagingTestBase::testCacheResize(), BTreeTxnTest::testCheckpoint(), PagingTestBase::testCheckpointGuarded(), PagingTestBase::testPrefetch(), and PagingTestBase::testPrefetchBatch().
00264 { 00265 #ifdef __MSVC__ 00266 ::_sleep(nSeconds*1000); 00267 #else 00268 ::sleep(nSeconds); 00269 #endif 00270 }
void TestBase::readParams | ( | int | argc, | |
char ** | argv | |||
) | [static, inherited] |
Parses the command line.
format: [-v] [-t TEST | -all] {param=val}* [CONFIGFILE | -] Normally, the test program runs the default test cases. With the option "-all", runs the extra test cases as well. With the option "-t TEST", runs only the single test case named TEST. CONFIGFILE is read to load configuration parameters. Configuration parameters can also be set ad hoc, from the command line, as pairs name=val. These take precedence.
Definition at line 108 of file TestBase.cpp.
References TestBase::configMap, ConfigMap::dumpParams(), ConfigMap::isParamSet(), ConfigMap::mergeFrom(), TestBase::paramDictionaryFileName, ConfigMap::readParams(), TestBase::runAll, TestBase::runSingle, ConfigMap::setStringParam(), and verbose.
00109 { 00110 bool verbose = false; 00111 ConfigMap adhocMap; 00112 00113 for (int i = 1; i < argc; ++i) { 00114 std::string arg = argv[i]; 00115 if (argv[i][0] == '-') { 00116 if (arg == "-v") { 00117 verbose = true; 00118 } else if (arg == "-") { 00119 configMap.readParams(std::cin); 00120 } else if (arg == "-all") { 00121 runAll = true; 00122 } else if (arg == "-t") { // -t TEST 00123 permAssert(i + 1 < argc); 00124 runSingle = argv[++i]; 00125 } else if (arg[1] == 't') { // allow -tTEST 00126 runSingle = arg.substr(2); 00127 } 00128 } else { 00129 int i = arg.find("="); 00130 if ((0 < i) && (i < arg.size())) { 00131 // an ad hoc parameter 00132 std::string key = arg.substr(0,i); 00133 std::string val = arg.substr(i + 1); 00134 adhocMap.setStringParam(key,val); 00135 } else { 00136 // a config file name 00137 std::ifstream configFile(arg.c_str()); 00138 assert(configFile.good()); 00139 configMap.readParams(configFile); 00140 } 00141 } 00142 } 00143 configMap.mergeFrom(adhocMap); 00144 00145 // set a default dictionary file location for use by tests that need a 00146 // small non-random sorted data set 00147 if (!configMap.isParamSet(paramDictionaryFileName)) { 00148 std::string dictFileName = "dictWords"; 00149 configMap.setStringParam(paramDictionaryFileName,dictFileName); 00150 } 00151 00152 if (verbose) { 00153 configMap.dumpParams(std::cout); 00154 } 00155 }
TestSuite * TestBase::releaseTestSuite | ( | ) | [inherited] |
Definition at line 157 of file TestBase.cpp.
References TestBase::TestCaseGroup::addAllToTestSuite(), TestBase::defaultTests, TestBase::extraTests, TestBase::TestCaseGroup::findTest(), TestBase::pTestObj, TestBase::pTestSuite, TestBase::runAll, TestBase::runSingle, and TestBase::testName.
00158 { 00159 assert(pTestObj); 00160 assert(pTestObj.use_count() > 1); 00161 00162 // release self-reference now that all test cases have been registered 00163 pTestObj.reset(); 00164 00165 TestSuite* pTestSuite = BOOST_TEST_SUITE(testName.c_str()); 00166 00167 if (runSingle.size()) { 00168 test_unit *p = defaultTests.findTest(runSingle); 00169 if (!p) { 00170 p = extraTests.findTest(runSingle); 00171 } 00172 if (!p) { 00173 std::cerr << "test " << runSingle << " not found\n"; 00174 exit(2); 00175 } 00176 pTestSuite->add(p); 00177 } else { 00178 defaultTests.addAllToTestSuite(pTestSuite); 00179 if (runAll) { 00180 extraTests.addAllToTestSuite(pTestSuite); 00181 } 00182 } 00183 return pTestSuite; 00184 }
void TestBase::beforeTestCase | ( | std::string | testCaseName | ) | [inherited] |
Definition at line 214 of file TestBase.cpp.
References TestBase::configMap, TraceSource::initTraceSource(), AutoBacktrace::install(), TestBase::notifyTrace(), AutoBacktrace::setOutputStream(), AutoBacktrace::setTraceTarget(), TestBase::testName, and TRACE_INFO.
00215 { 00216 notifyTrace(testName,TRACE_INFO,"ENTER: " + testCaseName); 00217 00218 // Install the AutoBacktrace signal handler now, after 00219 // boost::execution_monitor::catch_signals() has installed its own, so that 00220 // on SIGABRT AutoBacktrace goes first, prints the backtrace, then chains 00221 // to boost, which handles the error. 00222 AutoBacktrace::setOutputStream(); 00223 AutoBacktrace::setTraceTarget(shared_from_this()); 00224 AutoBacktrace::install(); 00225 configMap.initTraceSource(shared_from_this(), "testConfig"); 00226 }
void TestBase::afterTestCase | ( | std::string | testCaseName | ) | [inherited] |
Definition at line 228 of file TestBase.cpp.
References TestBase::configMap, TraceSource::disableTracing(), TestBase::notifyTrace(), AutoBacktrace::setTraceTarget(), TestBase::testName, and TRACE_INFO.
00229 { 00230 AutoBacktrace::setTraceTarget(); 00231 configMap.disableTracing(); 00232 notifyTrace(testName,TRACE_INFO,"LEAVE: " + testCaseName); 00233 }
void TestBase::notifyTrace | ( | std::string | source, | |
TraceLevel | level, | |||
std::string | message | |||
) | [virtual, inherited] |
Receives notification when a trace event occurs.
source | the facility from which the message originated | |
level | the trace event severity level | |
message | the text of the message |
Implements TraceTarget.
Definition at line 243 of file TestBase.cpp.
References TestBase::traceFile, TestBase::traceMutex, TestBase::traceStdout, and TestBase::traceStream.
Referenced by TestBase::afterTestCase(), and TestBase::beforeTestCase().
00244 { 00245 if (traceFile || traceStdout) { 00246 StrictMutexGuard traceMutexGuard(traceMutex); 00247 if (traceFile) { 00248 traceStream << "[" << source << "] " << message << std::endl; 00249 traceStream.flush(); 00250 } 00251 if (traceStdout) { 00252 std::cout << "[" << source << "] " << message << std::endl; 00253 std::cout.flush(); 00254 } 00255 } 00256 }
TraceLevel TestBase::getSourceTraceLevel | ( | std::string | source | ) | [virtual, inherited] |
Gets the level at which a particular source should be traced.
source | name of source to be traced |
Implements TraceTarget.
Definition at line 258 of file TestBase.cpp.
References TestBase::traceLevel.
Referenced by LbmExecStreamTestBase::generateBitmaps().
00259 { 00260 return traceLevel; 00261 }
Definition at line 53 of file PagingTestBase.cpp.
References g_pRNG.
Referenced by PagingTestBase::fillPage(), SegmentTestBase::testDeallocate(), PagingTestBase::testPrefetch(), PagingTestBase::testPrefetchBatch(), PagingTestBase::testRandomOp(), and PagingTestBase::testScratch().
00054 { 00055 return (*g_pRNG)(iMax); 00056 }
Carries out one operation on a page.
This involves locking the page, calling verifyPage or fillPage, and then unlocking the page.
opType | operation which will be attempted | |
iPage | block number of page | |
bNice | true if page should be marked as nice as part of access |
Definition at line 85 of file PagingTestBase.cpp.
References PagingTestBase::fillPage(), CacheTestBase::getCache(), PagingTestBase::getLockMode(), LOCKMODE_S, LOCKMODE_S_NOWAIT, LOCKMODE_X, LOCKMODE_X_NOWAIT, PagingTestBase::lockPage(), CacheAccessor::nicePage(), PagingTestBase::unlockPage(), and PagingTestBase::verifyPage().
Referenced by PagingTestBase::testRandomOp(), PagingTestBase::testSequentialOp(), and PagingTestBase::testSkipOp().
00086 { 00087 CachePage *pPage = lockPage(opType,iPage); 00088 LockMode lockMode = getLockMode(opType); 00089 if (!pPage) { 00090 // must be NoWait locking failed 00091 assert(lockMode >= LOCKMODE_S_NOWAIT); 00092 return false; 00093 } 00094 CachePage &page = *pPage; 00095 if (lockMode == LOCKMODE_S 00096 || lockMode == LOCKMODE_S_NOWAIT) 00097 { 00098 verifyPage(page,iPage); 00099 } else { 00100 fillPage(page,iPage); 00101 } 00102 switch (lockMode) { 00103 case LOCKMODE_X_NOWAIT: 00104 lockMode = LOCKMODE_X; 00105 break; 00106 case LOCKMODE_S_NOWAIT: 00107 lockMode = LOCKMODE_S; 00108 break; 00109 default: 00110 break; 00111 } 00112 if (bNice) { 00113 getCache().nicePage(page); 00114 } 00115 unlockPage(page,lockMode); 00116 return true; 00117 }
char const * PagingTestBase::getOpName | ( | OpType | opType | ) | [inherited] |
Makes up an operation name based on an OpType.
Definition at line 119 of file PagingTestBase.cpp.
References PagingTestBase::OP_ALLOCATE, PagingTestBase::OP_READ_NOWAIT, PagingTestBase::OP_READ_RAND, PagingTestBase::OP_READ_SEQ, PagingTestBase::OP_WRITE_NOWAIT, PagingTestBase::OP_WRITE_RAND, PagingTestBase::OP_WRITE_SEQ, and PagingTestBase::OP_WRITE_SKIP.
Referenced by PagingTestBase::testRandomOp(), PagingTestBase::testSequentialOp(), and PagingTestBase::testSkipOp().
00120 { 00121 switch (opType) { 00122 case OP_ALLOCATE: 00123 return "allocate"; 00124 case OP_READ_SEQ: 00125 return "sequential read"; 00126 case OP_WRITE_SEQ: 00127 return "sequential write"; 00128 case OP_READ_RAND: 00129 return "random read"; 00130 case OP_WRITE_RAND: 00131 return "random write"; 00132 case OP_READ_NOWAIT: 00133 return "read no-wait"; 00134 case OP_WRITE_NOWAIT: 00135 return "write no-wait"; 00136 case OP_WRITE_SKIP: 00137 return "write every n pages"; 00138 default: 00139 permAssert(false); 00140 } 00141 }
Gets the LockMode corresponding to an OpType.
Definition at line 143 of file PagingTestBase.cpp.
References LOCKMODE_S, LOCKMODE_S_NOWAIT, LOCKMODE_X, LOCKMODE_X_NOWAIT, PagingTestBase::OP_ALLOCATE, PagingTestBase::OP_READ_NOWAIT, PagingTestBase::OP_READ_RAND, PagingTestBase::OP_READ_SEQ, PagingTestBase::OP_WRITE_NOWAIT, PagingTestBase::OP_WRITE_RAND, PagingTestBase::OP_WRITE_SEQ, and PagingTestBase::OP_WRITE_SKIP.
Referenced by SegmentTestBase::lockPage(), CacheTest::lockPage(), and PagingTestBase::testOp().
00144 { 00145 switch (opType) { 00146 case OP_ALLOCATE: 00147 return LOCKMODE_X; 00148 case OP_READ_SEQ: 00149 return LOCKMODE_S; 00150 case OP_WRITE_SEQ: 00151 return LOCKMODE_X; 00152 case OP_READ_RAND: 00153 return LOCKMODE_S; 00154 case OP_WRITE_RAND: 00155 return LOCKMODE_X; 00156 case OP_READ_NOWAIT: 00157 return LOCKMODE_S_NOWAIT; 00158 case OP_WRITE_NOWAIT: 00159 return LOCKMODE_X_NOWAIT; 00160 case OP_WRITE_SKIP: 00161 return LOCKMODE_X; 00162 default: 00163 permAssert(false); 00164 } 00165 }
void PagingTestBase::testSequentialOp | ( | OpType | opType | ) | [inherited] |
Carries out an operation on each disk page in order from 0 to nDiskPages-1.
opType | see testOp |
Definition at line 167 of file PagingTestBase.cpp.
References PagingTestBase::getOpName(), PagingTestBase::logMutex, CacheTestBase::nDiskPages, and PagingTestBase::testOp().
Referenced by PagingTestBase::testAllocateAll(), PagingTestBase::testSequentialRead(), PagingTestBase::testSequentialWrite(), and PagingTestBase::testThreadedOp().
00168 { 00169 uint n = 0; 00170 for (uint i = 0; i < nDiskPages; i++) { 00171 if (testOp(opType,i,true)) { 00172 n++; 00173 } 00174 } 00175 StrictMutexGuard mutexGuard(logMutex); 00176 BOOST_MESSAGE( 00177 "completed " << n << " " << getOpName(opType) << " ops"); 00178 }
void PagingTestBase::testRandomOp | ( | OpType | opType | ) | [inherited] |
Carries out an operation on nRandomOps pages selected at random.
opType | see testOp |
Definition at line 180 of file PagingTestBase.cpp.
References PagingTestBase::generateRandomNumber(), PagingTestBase::getOpName(), PagingTestBase::logMutex, CacheTestBase::nDiskPages, PagingTestBase::nRandomOps, and PagingTestBase::testOp().
Referenced by PagingTestBase::testRandomRead(), PagingTestBase::testRandomWrite(), and PagingTestBase::testThreadedOp().
00181 { 00182 uint n = 0; 00183 for (uint i = 0; i < nRandomOps; i++) { 00184 uint iPage = generateRandomNumber(nDiskPages); 00185 bool bNice = (generateRandomNumber(nRandomOps) == 0); 00186 if (testOp(opType,iPage,bNice)) { 00187 n++; 00188 } 00189 } 00190 StrictMutexGuard mutexGuard(logMutex); 00191 BOOST_MESSAGE( 00192 "completed " << n << " " << getOpName(opType) << " ops"); 00193 00194 }
Carries out an operation on every "n" pages, starting at page 0.
opType | see testOp | |
n | the offset between each page |
Definition at line 196 of file PagingTestBase.cpp.
References PagingTestBase::getOpName(), PagingTestBase::logMutex, CacheTestBase::nDiskPages, and PagingTestBase::testOp().
Referenced by PagingTestBase::testSkipWrite(), and PagingTestBase::testThreadedOp().
00197 { 00198 uint numOps = 0; 00199 for (uint i = 0; i < nDiskPages; i += n) { 00200 if (testOp(opType,i,true)) { 00201 numOps++; 00202 } 00203 } 00204 StrictMutexGuard mutexGuard(logMutex); 00205 BOOST_MESSAGE( 00206 "completed " << numOps << " " << getOpName(opType) << " ops"); 00207 }
void PagingTestBase::testScratch | ( | ) | [inherited] |
Performs nRandomOps scratch operations.
A scratch operation consists of locking a scratch page, filling it with random data, and then unlocking it.
Definition at line 209 of file PagingTestBase.cpp.
References PagingTestBase::fillPage(), PagingTestBase::generateRandomNumber(), CacheTestBase::getCache(), LOCKMODE_X, PagingTestBase::logMutex, PagingTestBase::nRandomOps, and CacheAccessor::unlockPage().
Referenced by CacheTest::testSingleThread(), and PagingTestBase::testThreadedOp().
00210 { 00211 for (uint i = 0; i < nRandomOps; i++) { 00212 CachePage &page = getCache().lockScratchPage(); 00213 fillPage(page,generateRandomNumber(10000)); 00214 getCache().unlockPage(page,LOCKMODE_X); 00215 } 00216 StrictMutexGuard mutexGuard(logMutex); 00217 BOOST_MESSAGE("completed " << nRandomOps << " random scratch ops"); 00218 }
void PagingTestBase::testPrefetch | ( | ) | [inherited] |
Performs a limited number of prefetch operations.
Prefetches are not verified.
Definition at line 220 of file PagingTestBase.cpp.
References PagingTestBase::generateRandomNumber(), PagingTestBase::logMutex, CacheTestBase::nDiskPages, PagingTestBase::prefetchPage(), and TestBase::snooze().
Referenced by PagingTestBase::testThreadedOp().
00221 { 00222 // TODO: parameterize this 00223 uint n = 3; 00224 for (uint i = 0; i < n; i++) { 00225 uint iPage = generateRandomNumber(nDiskPages); 00226 prefetchPage(iPage); 00227 } 00228 // give the prefetches a chance to complete 00229 snooze(1); 00230 StrictMutexGuard mutexGuard(logMutex); 00231 BOOST_MESSAGE("completed " << n << " random prefetch ops"); 00232 }
void PagingTestBase::testPrefetchBatch | ( | ) | [inherited] |
Performs a limited number of batch prefetch operations.
Prefetches are not verified.
Definition at line 234 of file PagingTestBase.cpp.
References PagingTestBase::generateRandomNumber(), PagingTestBase::logMutex, CacheTestBase::nDiskPages, PagingTestBase::prefetchBatch(), and TestBase::snooze().
Referenced by PagingTestBase::testThreadedOp().
00235 { 00236 // TODO: parameterize this 00237 uint n = 2; 00238 uint nPagesPerBatch = 4; 00239 for (uint i = 0; i < n; i++) { 00240 uint iPage = generateRandomNumber(nDiskPages - nPagesPerBatch); 00241 prefetchBatch(iPage,nPagesPerBatch); 00242 } 00243 // give the prefetches a chance to complete 00244 snooze(1); 00245 StrictMutexGuard mutexGuard(logMutex); 00246 BOOST_MESSAGE("completed " << n << " random prefetch batch ops"); 00247 }
void PagingTestBase::testSequentialRead | ( | ) | [inherited] |
Carries out one sequential read pass over the entire device.
Definition at line 254 of file PagingTestBase.cpp.
References PagingTestBase::OP_READ_SEQ, and PagingTestBase::testSequentialOp().
Referenced by SnapshotSegmentTest::deallocateOldPages(), SnapshotSegmentTest::testDeallocateOld(), VersionedSegmentTest::testRecovery(), SnapshotSegmentTest::testRollback(), SegmentTestBase::testSingleThread(), CacheTest::testSingleThread(), SnapshotSegmentTest::testSnapshotReads(), SnapshotSegmentTest::testUncommittedReads(), and verifyData().
00255 { 00256 testSequentialOp(OP_READ_SEQ); 00257 }
void PagingTestBase::testSequentialWrite | ( | ) | [inherited] |
Carries out one sequential write pass over the entire device.
Definition at line 259 of file PagingTestBase.cpp.
References PagingTestBase::OP_WRITE_SEQ, and PagingTestBase::testSequentialOp().
Referenced by SegmentTestBase::testSingleThread(), and CacheTest::testSingleThread().
00260 { 00261 testSequentialOp(OP_WRITE_SEQ); 00262 }
void PagingTestBase::testRandomRead | ( | ) | [inherited] |
Carries out nRandomOps read operations on pages selected at random.
Definition at line 264 of file PagingTestBase.cpp.
References PagingTestBase::OP_READ_RAND, and PagingTestBase::testRandomOp().
Referenced by SegmentTestBase::testSingleThread(), and CacheTest::testSingleThread().
00265 { 00266 testRandomOp(OP_READ_RAND); 00267 }
void PagingTestBase::testRandomWrite | ( | ) | [inherited] |
Carries out nRandomOps write operations on pages selected at random.
Definition at line 269 of file PagingTestBase.cpp.
References PagingTestBase::OP_WRITE_RAND, and PagingTestBase::testRandomOp().
Referenced by SegmentTestBase::testSingleThread(), and CacheTest::testSingleThread().
00270 { 00271 testRandomOp(OP_WRITE_RAND); 00272 }
void PagingTestBase::testSkipWrite | ( | uint | n | ) | [inherited] |
Carries out write operations every n pages.
n | offset between pages |
Definition at line 274 of file PagingTestBase.cpp.
References PagingTestBase::OP_WRITE_SKIP, and PagingTestBase::testSkipOp().
Referenced by testBackupRestore(), SnapshotSegmentTest::testDeallocateOld(), SnapshotSegmentTest::testRollback(), SnapshotSegmentTest::testSnapshotReads(), and SnapshotSegmentTest::testUncommittedReads().
00275 { 00276 testSkipOp(OP_WRITE_SKIP, n); 00277 }
void PagingTestBase::testCheckpointGuarded | ( | ) | [inherited] |
Definition at line 295 of file PagingTestBase.cpp.
References PagingTestBase::checkpointMutex, PagingTestBase::logMutex, PagingTestBase::nSecondsBetweenCheckpoints, TestBase::snooze(), PagingTestBase::testCheckpoint(), and SXMutexGuard< lockMode >::unlock().
Referenced by PagingTestBase::testThreadedOp().
00296 { 00297 snooze(nSecondsBetweenCheckpoints); 00298 StrictMutexGuard logGuard(logMutex); 00299 BOOST_MESSAGE("checkpoint started"); 00300 logGuard.unlock(); 00301 SXMutexExclusiveGuard checkpointExclusiveGuard(checkpointMutex); 00302 testCheckpoint(); 00303 checkpointExclusiveGuard.unlock(); 00304 logGuard.lock(); 00305 BOOST_MESSAGE("checkpoint completed"); 00306 }
void PagingTestBase::testCacheResize | ( | ) | [inherited] |
Definition at line 308 of file PagingTestBase.cpp.
References CacheTestBase::getCache(), PagingTestBase::logMutex, CacheTestBase::nMemPages, ThreadedTestBase::nSeconds, Cache::setAllocatedPageCount(), and TestBase::snooze().
Referenced by PagingTestBase::testThreadedOp().
00309 { 00310 snooze(nSeconds / 3); 00311 getCache().setAllocatedPageCount(nMemPages / 2); 00312 StrictMutexGuard mutexGuard(logMutex); 00313 BOOST_MESSAGE("shrank cache"); 00314 mutexGuard.unlock(); 00315 snooze(nSeconds / 3); 00316 getCache().setAllocatedPageCount(nMemPages - 1); 00317 mutexGuard.lock(); 00318 BOOST_MESSAGE("expanded cache"); 00319 mutexGuard.unlock(); 00320 }
void PagingTestBase::testMultipleThreads | ( | ) | [inherited] |
Carries out specified tests in multi-threaded mode.
Definition at line 431 of file PagingTestBase.cpp.
References DeviceMode::createNew, CacheTestBase::openStorage(), ThreadedTestBase::runThreadedTestCase(), and PagingTestBase::testAllocateAll().
Referenced by CacheTest::CacheTest(), LinearDeviceSegmentTest::LinearDeviceSegmentTest(), LinearViewSegmentTest::LinearViewSegmentTest(), SnapshotSegmentTest::SnapshotSegmentTest(), and VersionedSegmentTest::VersionedSegmentTest().
00432 { 00433 openStorage(DeviceMode::createNew); 00434 testAllocateAll(); 00435 runThreadedTestCase(); 00436 }
void PagingTestBase::threadInit | ( | ) | [virtual, inherited] |
Reimplemented from ThreadedTestBase.
Definition at line 41 of file PagingTestBase.cpp.
References g_pRNG, and ThreadedTestBase::threadInit().
Referenced by PagingTestBase::PagingTestBase().
00042 { 00043 ThreadedTestBase::threadInit(); 00044 g_pRNG.reset(new std::subtractive_rng()); 00045 }
void PagingTestBase::threadTerminate | ( | ) | [virtual, inherited] |
Reimplemented from ThreadedTestBase.
Definition at line 47 of file PagingTestBase.cpp.
References g_pRNG, and ThreadedTestBase::threadTerminate().
Referenced by PagingTestBase::~PagingTestBase().
00048 { 00049 g_pRNG.reset(); 00050 ThreadedTestBase::threadTerminate(); 00051 }
bool PagingTestBase::testThreadedOp | ( | int | iOp | ) | [virtual, inherited] |
Test implementation must be supplied by derived test class.
iOp | operation type to test |
Implements ThreadedTestBase.
Definition at line 378 of file PagingTestBase.cpp.
References PagingTestBase::checkpointMutex, SXMutexGuard< lockMode >::lock(), PagingTestBase::OP_ALLOCATE, PagingTestBase::OP_CHECKPOINT, PagingTestBase::OP_DEALLOCATE, PagingTestBase::OP_MAX, PagingTestBase::OP_PREFETCH, PagingTestBase::OP_PREFETCH_BATCH, PagingTestBase::OP_READ_NOWAIT, PagingTestBase::OP_READ_RAND, PagingTestBase::OP_READ_SEQ, PagingTestBase::OP_RESIZE_CACHE, PagingTestBase::OP_SCRATCH, PagingTestBase::OP_WRITE_NOWAIT, PagingTestBase::OP_WRITE_RAND, PagingTestBase::OP_WRITE_SEQ, PagingTestBase::OP_WRITE_SKIP, PagingTestBase::testAllocate(), PagingTestBase::testCacheResize(), PagingTestBase::testCheckpointGuarded(), PagingTestBase::testDeallocate(), PagingTestBase::testPrefetch(), PagingTestBase::testPrefetchBatch(), PagingTestBase::testRandomOp(), PagingTestBase::testScratch(), PagingTestBase::testSequentialOp(), and PagingTestBase::testSkipOp().
00379 { 00380 SXMutexSharedGuard checkpointSharedGuard(checkpointMutex,false); 00381 assert(iOp < OP_MAX); 00382 OpType op = static_cast<OpType>(iOp); 00383 switch (op) { 00384 case PagingTestBase::OP_WRITE_SEQ: 00385 checkpointSharedGuard.lock(); 00386 // fall through 00387 case PagingTestBase::OP_READ_SEQ: 00388 testSequentialOp(op); 00389 break; 00390 case PagingTestBase::OP_WRITE_RAND: 00391 case PagingTestBase::OP_WRITE_NOWAIT: 00392 checkpointSharedGuard.lock(); 00393 // fall through 00394 case PagingTestBase::OP_READ_RAND: 00395 case PagingTestBase::OP_READ_NOWAIT: 00396 testRandomOp(op); 00397 break; 00398 case PagingTestBase::OP_WRITE_SKIP: 00399 checkpointSharedGuard.lock(); 00400 testSkipOp(op, 5); 00401 break; 00402 case PagingTestBase::OP_SCRATCH: 00403 testScratch(); 00404 break; 00405 case PagingTestBase::OP_PREFETCH: 00406 testPrefetch(); 00407 break; 00408 case PagingTestBase::OP_PREFETCH_BATCH: 00409 testPrefetchBatch(); 00410 break; 00411 case PagingTestBase::OP_ALLOCATE: 00412 checkpointSharedGuard.lock(); 00413 testAllocate(); 00414 break; 00415 case PagingTestBase::OP_DEALLOCATE: 00416 checkpointSharedGuard.lock(); 00417 testDeallocate(); 00418 break; 00419 case PagingTestBase::OP_CHECKPOINT: 00420 testCheckpointGuarded(); 00421 break; 00422 case PagingTestBase::OP_RESIZE_CACHE: 00423 testCacheResize(); 00424 return false; 00425 default: 00426 permAssert(false); 00427 } 00428 return true; 00429 }
void ThreadedTestBase::runThreadedTestCase | ( | ) | [protected, inherited] |
Executes specified test threads.
Definition at line 43 of file ThreadedTestBase.cpp.
References ThreadedTestBase::bDone, ThreadedTestBase::defaultThreadCount, ThreadedTestBase::nSeconds, ThreadedTestBase::pStartBarrier, TestBase::snooze(), ThreadPoolBase::start(), ThreadPoolBase::stop(), ThreadPool< Task >::submitTask(), and ThreadedTestBase::threadCounts.
Referenced by PagingTestBase::testMultipleThreads(), and BTreeTxnTest::testTxns().
00044 { 00045 bDone = false; 00046 00047 // materialize default thread counts 00048 std::replace_if( 00049 threadCounts.begin(), 00050 threadCounts.end(), 00051 std::bind2nd(std::equal_to<int>(),-1), 00052 defaultThreadCount); 00053 00054 // calculate how many threads are needed 00055 int nThreads = std::accumulate( 00056 threadCounts.begin(), 00057 threadCounts.end(), 00058 0); 00059 00060 // initialize a barrier to make sure they all start at once 00061 pStartBarrier.reset(new boost::barrier(nThreads)); 00062 00063 // fire 'em up 00064 ThreadPool<ThreadedTestBaseTask> threadPool; 00065 threadPool.start(nThreads); 00066 00067 // and distribute the tasks 00068 for (uint i = 0; i < threadCounts.size(); ++i) { 00069 for (int j = 0; j < threadCounts[i]; ++j) { 00070 ThreadedTestBaseTask task(*this,i); 00071 threadPool.submitTask(task); 00072 } 00073 } 00074 00075 // run the tests for the requested duration 00076 snooze(nSeconds); 00077 00078 // tell threads to quit and then wait for them to finish up 00079 bDone = true; 00080 threadPool.stop(); 00081 }
SharedDatabase BackupRestoreTest::pDatabase [private] |
Definition at line 54 of file BackupRestoreTest.cpp.
Referenced by createSnapshotData(), executeSnapshotTxn(), testBackupCleanup(), testHeaderBackupRestore(), and verifySnapshotData().
PageId BackupRestoreTest::persistentPageId [private] |
Definition at line 55 of file BackupRestoreTest.cpp.
Referenced by createSnapshotData(), executeSnapshotTxn(), and verifySnapshotData().
uint SnapshotSegmentTestBase::nDiskPagesTotal [protected, inherited] |
Definition at line 39 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::openSegmentStorage(), and SnapshotSegmentTestBase::SnapshotSegmentTestBase().
PageId SnapshotSegmentTestBase::firstPageId [protected, inherited] |
Definition at line 40 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::openSegmentStorage(), SnapshotSegmentTestBase::testAllocateAll(), SnapshotSegmentTest::testDeallocateOld(), and SnapshotSegmentTest::testUncommittedReads().
DeviceId SnapshotSegmentTestBase::tempDeviceId [protected, inherited] |
Definition at line 41 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::closeStorage(), SnapshotSegmentTestBase::openSegmentStorage(), and SnapshotSegmentTestBase::SnapshotSegmentTestBase().
SharedRandomAccessDevice SnapshotSegmentTestBase::pTempDevice [protected, inherited] |
Definition at line 42 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::closeStorage(), and SnapshotSegmentTestBase::openSegmentStorage().
SharedSegment SnapshotSegmentTestBase::pTempSegment [protected, inherited] |
Definition at line 43 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::closeStorage(), and SnapshotSegmentTestBase::openSegmentStorage().
TxnId SnapshotSegmentTestBase::currCsn [protected, inherited] |
Definition at line 44 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::closeStorage(), SnapshotSegmentTest::deallocateOldPages(), SnapshotSegmentTestBase::fillPage(), SnapshotSegmentTestBase::openSegmentStorage(), testBackupRestore(), SnapshotSegmentTestBase::testCaseSetUp(), LcsClusterReplaceExecStreamTest::testClusterReplace(), SnapshotSegmentTest::testDeallocateOld(), SnapshotSegmentTest::testRollback(), SnapshotSegmentTest::testSnapshotReads(), SnapshotSegmentTest::testUncommittedReads(), and SnapshotSegmentTestBase::verifyPage().
std::vector<TxnId> SnapshotSegmentTestBase::updatedCsns [protected, inherited] |
Definition at line 45 of file SnapshotSegmentTestBase.h.
Referenced by testBackupRestore(), SnapshotSegmentTestBase::testCaseSetUp(), SnapshotSegmentTest::testDeallocateOld(), SnapshotSegmentTest::testSnapshotReads(), SnapshotSegmentTest::testUncommittedReads(), and SnapshotSegmentTestBase::verifyPage().
bool SnapshotSegmentTestBase::commit [protected, inherited] |
Definition at line 46 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::commitChanges(), SnapshotSegmentTestBase::testCaseSetUp(), and SnapshotSegmentTest::testRollback().
SharedSegment SnapshotSegmentTestBase::pSnapshotRandomSegment2 [protected, inherited] |
Definition at line 47 of file SnapshotSegmentTestBase.h.
Referenced by SnapshotSegmentTestBase::closeStorage(), LcsClusterReplaceExecStreamTest::testClusterReplace(), and SnapshotSegmentTest::testUncommittedReads().
std::vector<PageId> SegmentTestBase::freeablePages [protected, inherited] |
Queue of allocated pages waiting to be freed.
Definition at line 44 of file SegmentTestBase.h.
Referenced by SegmentTestBase::testAllocate(), SegmentTestBase::testDeallocate(), and SegmentTestBase::testSingleThread().
StrictMutex SegmentTestBase::freeablePagesMutex [protected, inherited] |
Mutex protecting freeablePages.
Definition at line 49 of file SegmentTestBase.h.
Referenced by SegmentTestBase::testAllocate(), and SegmentTestBase::testDeallocate().
PageOwnerId SegmentTestBase::objId [protected, inherited] |
PageOwnerId to use when allocating pages.
Definition at line 54 of file SegmentTestBase.h.
Referenced by SegmentTestBase::lockPage(), SegmentTestBase::SegmentTestBase(), and SegmentTestBase::testAllocate().
SharedSegmentFactory SegStorageTestBase::pSegmentFactory [protected, inherited] |
Definition at line 40 of file SegStorageTestBase.h.
Referenced by backup(), SegStorageTestBase::createLinearDeviceSegment(), LogicalTxnTest::createRecoveryLog(), LbmSearchTest::initBTreeExecStreamParam(), LbmLoadBitmapTest::initBTreeExecStreamParam(), LcsClusterReplaceExecStreamTest::initClusterAppendParams(), LbmExecStreamTestBase::initSorterExecStream(), LcsMultiClusterAppendTest::loadClusters(), LcsRowScanExecStreamTest::loadOneCluster(), LbmSearchTest::loadTableAndIndex(), LbmMinusExecStreamTest::newMinusStream(), ExecStreamTestBase::newStreamGraphEmbryo(), SegStorageTestBase::openRandomSegment(), VersionedSegmentTest::openSegmentStorage(), SnapshotSegmentTestBase::openSegmentStorage(), LinearViewSegmentTest::openSegmentStorage(), restore(), SegStorageTestBase::SegStorageTestBase(), LbmSplicerExecStreamTest::spliceInput(), ExecStreamTestSuite::testBTreeInsertExecStream(), LhxHashTableTest::testCaseSetUp(), LcsClusterReplaceExecStreamTest::testClusterReplace(), LhxAggExecStreamTest::testCountImpl(), ExecStreamTestSuite::testDoubleBufferExecStream(), ExecStreamGovernorTest::testGovernor(), LhxAggExecStreamTest::testGroupCountImpl(), LhxJoinExecStreamTest::testImpl(), ExternalSortExecStreamTest::testImpl(), BTreeTest::testInserts(), LbmIntersectExecStreamTest::testIntersect(), LbmEntryTest::testldb35(), LbmEntryTest::testler5920(), LbmLoadBitmapTest::testLoad(), LcsClusterAppendExecStreamTest::testLoadMultiCol(), LcsClusterAppendExecStreamTest::testLoadSingleCol(), LbmEntryTest::testMergeEntry(), BTreeTest::testMultiKeySearches(), BTreeTest::testScan(), ExecStreamTestSuite::testScratchBufferExecStream(), LhxAggExecStreamTest::testSingleValueImpl(), FlatFileExecStreamTest::testStream(), LhxAggExecStreamTest::testSumImpl(), LogicalTxnTest::testTxn(), SnapshotSegmentTest::testUncommittedReads(), LbmUnionExecStreamTest::testUnion(), SegStreamTest::testWriteSpillAndRead(), and LbmEntryTest::testZeroBytes().
SharedSegment SegStorageTestBase::pLinearSegment [protected, inherited] |
Segment supporting linear page allocation.
Definition at line 45 of file SegStorageTestBase.h.
Referenced by SegStorageTestBase::closeLinearSegment(), LogicalTxnTest::createRecoveryLog(), SegmentTestBase::lockPage(), SegStorageTestBase::openRandomSegment(), VersionedSegmentTest::openSegmentStorage(), SnapshotSegmentTestBase::openSegmentStorage(), SegStorageTestBase::openSegmentStorage(), LinearViewSegmentTest::openSegmentStorage(), SegmentTestBase::openStorage(), SegmentTestBase::prefetchPage(), SnapshotSegmentTestBase::testAllocateAll(), LinearViewSegmentTest::testAllocateAll(), VersionedSegmentTest::testCheckpoint(), SegmentTestBase::testCheckpoint(), SegPageIterTest::testIter(), SegPageEntryIterTest::testIter(), SegStreamTest::testMarkReset(), SegStreamTest::testReadSeg(), VersionedSegmentTest::testRecovery(), LogicalTxnTest::testTxn(), SnapshotSegmentTest::testUncommittedReads(), SegStreamTest::testWriteSeg(), and VersionedSegmentTest::verifyPage().
SharedSegment SegStorageTestBase::pRandomSegment [protected, inherited] |
(Optional) segment supporting random page allocation.
Definition at line 50 of file SegStorageTestBase.h.
Referenced by SegStorageTestBase::closeRandomSegment(), SnapshotSegmentTestBase::closeStorage(), LbmSplicerExecStreamTest::createBTree(), LbmSplicerExecStreamTest::initBTreeParam(), LbmSearchTest::initBTreeParam(), LbmLoadBitmapTest::initBTreeParam(), LbmLoadBitmapTest::initBTreeTupleDesc(), LcsClusterReplaceExecStreamTest::initClusterAppendParams(), LbmExecStreamTestBase::initSorterExecStream(), LcsClusterReplaceExecStreamTest::loadCluster(), LcsMultiClusterAppendTest::loadClusters(), LcsRowScanExecStreamTest::loadOneCluster(), LbmSearchTest::loadTableAndIndex(), SegStorageTestBase::openRandomSegment(), SnapshotSegmentTestBase::openSegmentStorage(), LinearViewSegmentTest::openSegmentStorage(), SegmentTestBase::openStorage(), SegmentTestBase::testAllocate(), RandomAllocationSegmentTest::testAllocateAndDeallocate(), ExecStreamTestSuite::testBTreeInsertExecStream(), BTreeTest::testBulkLoad(), LhxHashTableTest::testCaseSetUp(), BTreeTest::testCaseSetUp(), BTreeReadersTest::testCaseSetUp(), LcsRowScanExecStreamTest::testCaseSetUp(), LcsMultiClusterAppendTest::testCaseSetUp(), LcsClusterReplaceExecStreamTest::testCaseSetUp(), LcsClusterAppendExecStreamTest::testCaseSetUp(), LbmExecStreamTestBase::testCaseSetUp(), LcsClusterReplaceExecStreamTest::testClusterReplace(), LhxAggExecStreamTest::testCountImpl(), SegmentTestBase::testDeallocate(), LhxAggExecStreamTest::testGroupCountImpl(), LhxJoinExecStreamTest::testImpl(), ExternalSortExecStreamTest::testImpl(), BTreeTest::testInserts(), LbmLoadBitmapTest::testLoad(), LcsClusterAppendExecStreamTest::testLoadMultiCol(), LcsClusterAppendExecStreamTest::testLoadSingleCol(), ExecStreamTestSuite::testMergeImplicitPullInputs(), BTreeTest::testMultiKeySearches(), BTreeReadersTest::testReaders(), LcsRowScanExecStreamTest::testScanOnEmptyCluster(), ExecStreamTestSuite::testSegBufferExecStream(), ExecStreamTestSuite::testSegBufferReaderWriterExecStream(), LhxAggExecStreamTest::testSingleValueImpl(), LhxAggExecStreamTest::testSumImpl(), and LbmUnionExecStreamTest::testUnion().
SharedSegment SegStorageTestBase::pVersionedRandomSegment [protected, inherited] |
(Optional) segment supporting versioned random page allocation.
Definition at line 55 of file SegStorageTestBase.h.
Referenced by backup(), SnapshotSegmentTestBase::closeStorage(), SegStorageTestBase::closeVersionedRandomSegment(), SnapshotSegmentTest::deallocateOldPages(), SnapshotSegmentTestBase::openSegmentStorage(), restore(), LcsClusterReplaceExecStreamTest::testClusterReplace(), SnapshotSegmentTest::testRollback(), and SnapshotSegmentTest::testUncommittedReads().
SharedSegment SegStorageTestBase::pSnapshotRandomSegment [protected, inherited] |
(Optional) segment supporting snapshot random page allocation.
Definition at line 60 of file SegStorageTestBase.h.
Referenced by SegStorageTestBase::closeSnapshotRandomSegment(), SnapshotSegmentTestBase::commitChanges(), SnapshotSegmentTestBase::openSegmentStorage(), LcsClusterReplaceExecStreamTest::testClusterReplace(), and SnapshotSegmentTest::testDeallocateOld().
VictimPolicy CacheTestBase::victimPolicy [protected, inherited] |
VictimPolicy to instantiate.
Definition at line 53 of file CacheTestBase.h.
Referenced by CacheTestBase::CacheTestBase(), and CacheTestBase::newCache().
CacheParams CacheTestBase::cacheParams [protected, inherited] |
Parameters for cache initialization.
Definition at line 58 of file CacheTestBase.h.
Referenced by CacheTestBase::CacheTestBase(), CacheTestBase::newCache(), testBackupCleanup(), testHeaderBackupRestore(), and SegPageEntryIterTest::testIter().
SharedCache CacheTestBase::pCache [protected, inherited] |
Cache instance being tested.
Definition at line 63 of file CacheTestBase.h.
Referenced by backup(), CacheTestBase::closeDevice(), CacheTestBase::closeStorage(), LbmSplicerExecStreamTest::createBTree(), SegStorageTestBase::createLinearDeviceSegment(), LogicalTxnTest::createRecoveryLog(), createSnapshotData(), executeSnapshotTxn(), CacheTestBase::getCache(), LbmSearchTest::initBTreeExecStreamParam(), LbmLoadBitmapTest::initBTreeExecStreamParam(), LbmSearchTest::initBTreeParam(), LbmLoadBitmapTest::initBTreeParam(), LcsClusterReplaceExecStreamTest::initClusterAppendParams(), LbmExecStreamTestBase::initSorterExecStream(), LcsClusterReplaceExecStreamTest::loadCluster(), LcsMultiClusterAppendTest::loadClusters(), LcsRowScanExecStreamTest::loadOneCluster(), LbmSearchTest::loadTableAndIndex(), SegmentTestBase::lockPage(), LbmMinusExecStreamTest::newMinusStream(), ExecStreamTestBase::newStreamGraphEmbryo(), CacheTestBase::openDevice(), CacheTestBase::openStorage(), LcsClusterReplaceExecStreamTest::replaceCluster(), restore(), LbmSplicerExecStreamTest::spliceInput(), SegmentTestBase::testAllocate(), RandomAllocationSegmentTest::testAllocateAndDeallocate(), testBackupCleanup(), ExecStreamTestSuite::testBTreeInsertExecStream(), BTreeTest::testBulkLoad(), LhxHashTableTest::testCaseSetUp(), ExecStreamUnitTestBase::testCaseSetUp(), BTreeTest::testCaseSetUp(), BTreeReadersTest::testCaseSetUp(), LhxAggExecStreamTest::testCountImpl(), SegmentTestBase::testDeallocate(), SnapshotSegmentTest::testDeallocateOld(), ExecStreamTestSuite::testDoubleBufferExecStream(), ExecStreamGovernorTest::testGovernor(), LhxAggExecStreamTest::testGroupCountImpl(), testHeaderBackupRestore(), LhxJoinExecStreamTest::testImpl(), ExternalSortExecStreamTest::testImpl(), BTreeTest::testInserts(), LbmIntersectExecStreamTest::testIntersect(), SegPageIterTest::testIter(), SegPageEntryIterTest::testIter(), CacheTest::testLargeCacheInit(), CacheTest::testLargeCacheRequest(), LbmEntryTest::testldb35(), LbmEntryTest::testler5920(), LbmLoadBitmapTest::testLoad(), LcsClusterAppendExecStreamTest::testLoadMultiCol(), LcsClusterAppendExecStreamTest::testLoadSingleCol(), SegStreamTest::testMarkReset(), LbmEntryTest::testMergeEntry(), BTreeTest::testMultiKeySearches(), CacheTest::testQuotaCacheAccessor(), BTreeReadersTest::testReaders(), SegStreamTest::testReadSeg(), BTreeTest::testScan(), LcsRowScanExecStreamTest::testScanOnEmptyCluster(), ExecStreamTestSuite::testScratchBufferExecStream(), LhxAggExecStreamTest::testSingleValueImpl(), FlatFileExecStreamTest::testStream(), LhxAggExecStreamTest::testSumImpl(), LogicalTxnTest::testTxn(), LogicalTxnTest::testTxnIdSequence(), LbmUnionExecStreamTest::testUnion(), SegStreamTest::testWriteSeg(), SegStreamTest::testWriteSpillAndRead(), LbmEntryTest::testZeroBytes(), and verifySnapshotData().
SharedRandomAccessDevice CacheTestBase::pRandomAccessDevice [protected, inherited] |
The default cached device.
Definition at line 68 of file CacheTestBase.h.
Referenced by backup(), CacheTestBase::closeStorage(), SegStorageTestBase::openSegmentStorage(), CacheTestBase::openStorage(), and restore().
uint CacheTestBase::nMemPages [protected, inherited] |
Size of cache in memory pages.
Definition at line 73 of file CacheTestBase.h.
Referenced by CacheTestBase::CacheTestBase(), PagingTestBase::testCacheResize(), and ExecStreamTestBase::testCaseSetUp().
uint CacheTestBase::nDiskPages [protected, inherited] |
Size of device in disk pages.
Definition at line 78 of file CacheTestBase.h.
Referenced by CacheTestBase::CacheTestBase(), LinearViewSegmentTest::LinearViewSegmentTest(), CacheTest::makeBlockId(), VersionedSegmentTest::openSegmentStorage(), SnapshotSegmentTestBase::openSegmentStorage(), LinearViewSegmentTest::openSegmentStorage(), CacheTestBase::openStorage(), SegStreamTest::SegStreamTest(), SnapshotSegmentTestBase::SnapshotSegmentTestBase(), SnapshotSegmentTest::testDeallocateOld(), PagingTestBase::testPrefetch(), PagingTestBase::testPrefetchBatch(), PagingTestBase::testRandomOp(), SnapshotSegmentTest::testRollback(), PagingTestBase::testSequentialOp(), and PagingTestBase::testSkipOp().
uint CacheTestBase::cbPageFull [protected, inherited] |
Disk page size.
Definition at line 83 of file CacheTestBase.h.
Referenced by CacheTest::CacheTest(), CacheTestBase::CacheTestBase(), CacheTestBase::openDevice(), and SegStorageTestBase::openSegmentStorage().
DeviceId CacheTestBase::dataDeviceId [protected, inherited] |
Fixed ID to assign to data device.
Definition at line 88 of file CacheTestBase.h.
Referenced by CacheTestBase::CacheTestBase(), CacheTestBase::closeStorage(), CacheTest::makeBlockId(), SnapshotSegmentTestBase::openSegmentStorage(), SegStorageTestBase::openSegmentStorage(), LinearViewSegmentTest::openSegmentStorage(), CacheTestBase::openStorage(), and PagingTestBase::testCheckpoint().
TestSuite* TestBase::pTestSuite [protected, inherited] |
Boost test suite.
Definition at line 59 of file TestBase.h.
Referenced by TestBase::releaseTestSuite().
boost::shared_ptr<TestBase> TestBase::pTestObj [protected, inherited] |
Definition at line 61 of file TestBase.h.
Referenced by TestBase::releaseTestSuite(), and TestBase::TestBase().
std::ofstream TestBase::traceStream [protected, inherited] |
Output file stream for tracing.
Definition at line 66 of file TestBase.h.
Referenced by TestBase::notifyTrace(), TestBase::TestBase(), and TestBase::~TestBase().
StrictMutex TestBase::traceMutex [protected, inherited] |
Protects traceStream.
Definition at line 71 of file TestBase.h.
Referenced by TestBase::notifyTrace().
std::string TestBase::testName [protected, inherited] |
Name of test.
Definition at line 76 of file TestBase.h.
Referenced by TestBase::afterTestCase(), TestBase::beforeTestCase(), TestBase::releaseTestSuite(), TestBase::TestBase(), LhxHashTableTest::testInsert1Ka(), and LhxHashTableTest::testInsert1Kb().
TraceLevel TestBase::traceLevel [protected, inherited] |
Level at which to trace test execution.
Definition at line 81 of file TestBase.h.
Referenced by TestBase::getSourceTraceLevel(), and TestBase::TestBase().
FileStatsTarget TestBase::statsTarget [protected, inherited] |
StatsTimer TestBase::statsTimer [protected, inherited] |
Timer for stats collection.
Definition at line 91 of file TestBase.h.
Referenced by CacheTestBase::closeStorage(), CacheTestBase::openStorage(), BTreeTxnTest::testCaseSetUp(), BTreeTxnTest::testCaseTearDown(), and BTreeTxnTest::testTxns().
bool TestBase::traceStdout [protected, inherited] |
Copy trace output to stdout.
Definition at line 99 of file TestBase.h.
Referenced by TestBase::notifyTrace(), and TestBase::TestBase().
bool TestBase::traceFile [protected, inherited] |
Copy trace output to file.
Definition at line 104 of file TestBase.h.
Referenced by TestBase::notifyTrace(), and TestBase::TestBase().
bool TestBase::runAll [static, protected, inherited] |
Run all test cases, including the extra tests.
(static, since set by readParams())
Definition at line 110 of file TestBase.h.
Referenced by TestBase::readParams(), and TestBase::releaseTestSuite().
std::string TestBase::runSingle [static, protected, inherited] |
Run only the test case of this name.
(static, since set by readParams())
Definition at line 116 of file TestBase.h.
Referenced by TestBase::readParams(), and TestBase::releaseTestSuite().
TestCaseGroup TestBase::defaultTests [protected, inherited] |
TestCaseGroup TestBase::extraTests [protected, inherited] |
ParamName TestBase::paramTestSuiteName [static, inherited] |
ParamName TestBase::paramTraceFileName [static, inherited] |
ParamName TestBase::paramDictionaryFileName [static, inherited] |
Definition at line 145 of file TestBase.h.
Referenced by TestBase::readParams(), SegStreamTest::testRead(), and SegStreamTest::testWrite().
ParamName TestBase::paramTraceLevel [static, inherited] |
ParamName TestBase::paramStatsFileName [static, inherited] |
Definition at line 147 of file TestBase.h.
ParamName TestBase::paramTraceStdout [static, inherited] |
ParamName TestBase::paramDegreeOfParallelism [static, inherited] |
Definition at line 149 of file TestBase.h.
Referenced by ParallelExecStreamSchedulerTest::ParallelExecStreamSchedulerTest().
ConfigMap TestBase::configMap [static, inherited] |
Configuration parameters.
The reason this is static is so that no constructor parameters (which burden virtual bases) are needed.
Definition at line 155 of file TestBase.h.
Referenced by TestBase::afterTestCase(), TestBase::beforeTestCase(), BTreeTxnTest::BTreeTxnTest(), CacheTestBase::CacheTestBase(), createSnapshotData(), DatabaseTest::DatabaseTest(), TestOptionsTest::extra(), DatabaseTest::loadDatabase(), SparseBitmapTest::openStorage(), PagingTestBase::PagingTestBase(), ParallelExecStreamSchedulerTest::ParallelExecStreamSchedulerTest(), RandomAccessFileDeviceTest::RandomAccessFileDeviceTest(), TestBase::readParams(), SegStorageTestBase::SegStorageTestBase(), TestOptionsTest::test1(), TestOptionsTest::test2(), testBackupCleanup(), TestBase::TestBase(), BTreeTxnTest::testCaseSetUp(), BTreeTxnTest::testCheckpoint(), DatabaseTest::testCreateEmpty(), DatabaseTest::testForceTxns(), testHeaderBackupRestore(), SegPageEntryIterTest::testIter(), SegStreamTest::testRead(), BTreeTxnTest::testTxns(), SegStreamTest::testWrite(), ThreadedTestBase::ThreadedTestBase(), and TestBase::~TestBase().
uint PagingTestBase::cbPageUsable [protected, inherited] |
Portion of each page that should be scribbled on.
Definition at line 49 of file PagingTestBase.h.
Referenced by CacheTest::CacheTest(), PagingTestBase::fillPage(), SegmentTestBase::openStorage(), PagingTestBase::PagingTestBase(), and PagingTestBase::verifyPage().
uint PagingTestBase::nRandomOps [protected, inherited] |
Number of random access operations to run per pass.
Definition at line 54 of file PagingTestBase.h.
Referenced by PagingTestBase::PagingTestBase(), SegmentTestBase::testAllocate(), SegmentTestBase::testDeallocate(), PagingTestBase::testRandomOp(), and PagingTestBase::testScratch().
uint PagingTestBase::nSecondsBetweenCheckpoints [protected, inherited] |
Checkpoint interval during multi-threaded test.
Definition at line 59 of file PagingTestBase.h.
Referenced by PagingTestBase::PagingTestBase(), and PagingTestBase::testCheckpointGuarded().
StrictMutex PagingTestBase::logMutex [protected, inherited] |
Protects output stream.
Definition at line 64 of file PagingTestBase.h.
Referenced by SegmentTestBase::testAllocate(), PagingTestBase::testCacheResize(), PagingTestBase::testCheckpointGuarded(), SegmentTestBase::testDeallocate(), PagingTestBase::testPrefetch(), PagingTestBase::testPrefetchBatch(), PagingTestBase::testRandomOp(), PagingTestBase::testScratch(), PagingTestBase::testSequentialOp(), and PagingTestBase::testSkipOp().
SXMutex PagingTestBase::checkpointMutex [protected, inherited] |
SXMutex used to synchronize checkpoints with write actions.
Definition at line 69 of file PagingTestBase.h.
Referenced by PagingTestBase::PagingTestBase(), PagingTestBase::testCheckpointGuarded(), and PagingTestBase::testThreadedOp().
bool PagingTestBase::bTestResize [protected, inherited] |
Flag indicating that the cache should be dynamically resized during the multi-threaded portion of the test.
Definition at line 75 of file PagingTestBase.h.
Referenced by PagingTestBase::PagingTestBase().
uint ThreadedTestBase::nSeconds [protected, inherited] |
Duration of multi-threaded test.
Definition at line 65 of file ThreadedTestBase.h.
Referenced by BTreeTxnTest::BTreeTxnTest(), PagingTestBase::PagingTestBase(), ThreadedTestBase::runThreadedTestCase(), PagingTestBase::testCacheResize(), and ThreadedTestBase::ThreadedTestBase().
std::vector<int> ThreadedTestBase::threadCounts [protected, inherited] |
Number of threads to run for each type of operation.
Definition at line 70 of file ThreadedTestBase.h.
Referenced by BTreeTxnTest::BTreeTxnTest(), CacheTest::CacheTest(), SegmentTestBase::openStorage(), PagingTestBase::PagingTestBase(), ThreadedTestBase::runThreadedTestCase(), and SegmentTestBase::SegmentTestBase().