예제 #1
0
void MemoryContextTestCase::testMemoryContext() {
	MemoryContext *mc = new MemoryContext(4096, 1);

	u64 firstSavepoint = mc->setSavepoint();

	int chunkSize = 700;
	void *first = mc->alloc(chunkSize);
	memset(first, 0, chunkSize);	// 便于valgrind检测有无越界写问题
	for (int i = 0; i < 12; i++) {
		void *chunk = mc->alloc(chunkSize);
		memset(chunk, 0, chunkSize);
	}
	u64 savepoint = mc->setSavepoint();
	void *firstAfterSavepoint = mc->alloc(chunkSize);
	for (int i = 0; i < 12; i++) {
		void *chunk = mc->alloc(chunkSize);
		memset(chunk, 0, chunkSize);
	}
	// 分配超出页面大小的块
	for (int i = 0; i < 3; i++)
		mc->alloc(8000);
	mc->resetToSavepoint(savepoint);
	CPPUNIT_ASSERT(mc->setSavepoint() == savepoint);
	CPPUNIT_ASSERT(mc->alloc(chunkSize) == firstAfterSavepoint);

	mc->reset();
	CPPUNIT_ASSERT(mc->setSavepoint() == firstSavepoint);
	CPPUNIT_ASSERT(mc->alloc(chunkSize) == first);	// 第一页始终保持因此地址不变
	mc->resetToSavepoint(0);
	CPPUNIT_ASSERT(mc->setSavepoint() == firstSavepoint);
	CPPUNIT_ASSERT(mc->alloc(chunkSize) == first);

	// 测试getMemUsage
	{
		mc->reset();
		for (int i = 0; i < 12; i++)
			mc->alloc(chunkSize);
		CPPUNIT_ASSERT(mc->getMemUsage() > chunkSize * 12);
		u64 muBak = mc->getMemUsage();
		u64 savepoint = mc->setSavepoint();
		for (int i = 0; i < 12; i++)
			mc->alloc(chunkSize);
		CPPUNIT_ASSERT(mc->getMemUsage() > chunkSize * 24);
		mc->resetToSavepoint(savepoint);
		CPPUNIT_ASSERT(mc->getMemUsage() == muBak);
		mc->reset();
		CPPUNIT_ASSERT(mc->getMemUsage() < muBak);
	}
	delete mc;
}
예제 #2
0
void MemoryContextTestCase::testMemoryContext() {
	MemoryContext *mc = new MemoryContext(4096, 1);

	CPPUNIT_ASSERT(mc->setSavepoint() == 0);
	int chunkSize = 700;
	for (int i = 0; i < 12; i++) {
		void *chunk = mc->alloc(chunkSize);
		memset(chunk, 0, chunkSize);
	}
	u64 savepoint = mc->setSavepoint();
	CPPUNIT_ASSERT(savepoint == 12);

	for (int i = 0; i < 12; i++) {
		void *chunk = mc->alloc(chunkSize);
		memset(chunk, 0, chunkSize);
	}

	mc->resetToSavepoint(savepoint);
	CPPUNIT_ASSERT(mc->setSavepoint() == savepoint);

	mc->reset();
	CPPUNIT_ASSERT(mc->setSavepoint() == 0);
	mc->alloc(chunkSize);
	mc->resetToSavepoint(0);
	CPPUNIT_ASSERT(mc->setSavepoint() == 0);

	// 测试getMemUsage
	{
		mc->reset();
		for (int i = 0; i < 12; i++)
			mc->alloc(chunkSize);
		CPPUNIT_ASSERT(mc->getMemUsage() == chunkSize * 12);
		u64 muBak = mc->getMemUsage();
		u64 savepoint = mc->setSavepoint();
		for (int i = 0; i < 12; i++)
			mc->alloc(chunkSize);
		CPPUNIT_ASSERT(mc->getMemUsage() == chunkSize * 24);
		mc->resetToSavepoint(savepoint);
		CPPUNIT_ASSERT(mc->getMemUsage() == muBak);
		mc->reset();
		CPPUNIT_ASSERT(mc->getMemUsage() == 0);
	}
	delete mc;
}
예제 #3
0
LsnType MRecords::writeRemoveLog(Session *session, LogType logType, TrxId txnId, LsnType preLsn, RowId rid, RowId rollBackId, u8 tableIndex) {
	LsnType lsn = 0;
	MemoryContext *ctx = session->getMemoryContext();
	McSavepoint msp(ctx);
	size_t size = sizeof(txnId) + sizeof(preLsn) + sizeof(rid) + sizeof(rollBackId) + sizeof(tableIndex);
	byte *buf = (byte *)ctx->alloc(size);
	Stream s(buf, size);
	s.write(txnId);
	s.write(preLsn);
	s.writeRid(rid);
	s.writeRid(rollBackId);
	s.write(tableIndex);
	lsn = session->getTrans()->writeTNTLog(logType, (*m_tableDef)->m_id, buf, s.getSize());
	return lsn;
}
예제 #4
0
LsnType MRecords::writeUpdateLog(Session *session, LogType logType, TrxId txnId, LsnType preLsn, RowId rid, RowId rollBackId, u8 tableIndex, SubRecord *update) {
	LsnType lsn = 0;
	MemoryContext *ctx = session->getMemoryContext();
	McSavepoint msp(ctx);
	size_t size = sizeof(txnId) + sizeof(preLsn) + sizeof(rid) + sizeof(rollBackId) + sizeof(tableIndex);
	size += RecordOper::getSubRecordSerializeSize(*m_tableDef, update, false);
	byte *buf = (byte *)ctx->alloc(size);
	Stream s(buf, size);
	s.write(txnId);
	s.write(preLsn);
	s.writeRid(rid);
	s.writeRid(rollBackId);
	s.write(tableIndex);
	RecordOper::serializeSubRecordMNR(&s, *m_tableDef, update, false);
	lsn = session->getTrans()->writeTNTLog(logType, (*m_tableDef)->m_id, buf, s.getSize());
	return lsn;
}
예제 #5
0
void MemoryContextTestCase::testMemoryContextUsePool() {
	uint poolSize = 4096;
	uint reservedPages = 1;
	PagePool pool(1, NTSE_PAGE_SIZE);
	CommonMemPool commonMemPool(poolSize, &pool);
	pool.registerUser(&commonMemPool);
	pool.init();

	MemoryContext *mc = new MemoryContext(&commonMemPool, reservedPages);

	u64 firstSavepoint = mc->setSavepoint();

	int chunkSize = 700;
	void *first = mc->alloc(chunkSize);
	memset(first, 0, chunkSize);	// 便于valgrind检测有无越界写问题
	for (int i = 0; i < 12; i++) {
		void *chunk = mc->alloc(chunkSize);
		memset(chunk, 0, chunkSize);
	}
	u64 savepoint = mc->setSavepoint();
	void *firstAfterSavepoint = mc->alloc(chunkSize);
	for (int i = 0; i < 12; i++) {
		void *chunk = mc->alloc(chunkSize);
		memset(chunk, 0, chunkSize);
	}
	// 分配超出页面大小的块
	for (int i = 0; i < 3; i++)
		NTSE_ASSERT(NULL == mc->alloc(NTSE_PAGE_SIZE + 1));
	mc->resetToSavepoint(savepoint);
	CPPUNIT_ASSERT(mc->setSavepoint() == savepoint);
	CPPUNIT_ASSERT(mc->alloc(chunkSize) == firstAfterSavepoint);

	// 测试内存池内存不足
	mc->reset();
	for (int i = 0; i < poolSize; i++) {
		int cs = NTSE_PAGE_SIZE / 2 + 100;
		void *data = mc->alloc(cs);
		NTSE_ASSERT(NULL != data);
		memset(data, 0, cs);
	}

	NTSE_ASSERT(poolSize == commonMemPool.getCurrentSize());
	for (int i = 0; i < 10; i++) {
		int cs = NTSE_PAGE_SIZE / 2 + 100;
		void *data = mc->alloc(cs);
		NTSE_ASSERT(NULL == data);
		NTSE_ASSERT(poolSize == commonMemPool.getCurrentSize());
	}

	mc->reset();
	CPPUNIT_ASSERT(mc->setSavepoint() == firstSavepoint);
	CPPUNIT_ASSERT(mc->alloc(chunkSize) == first);	// 第一页始终保持因此地址不变
	mc->resetToSavepoint(0);
	CPPUNIT_ASSERT(mc->setSavepoint() == firstSavepoint);
	CPPUNIT_ASSERT(mc->alloc(chunkSize) == first);

	// 测试getMemUsage
	{
		mc->reset();
		for (int i = 0; i < 12; i++)
			mc->alloc(chunkSize);
		CPPUNIT_ASSERT(mc->getMemUsage() > chunkSize * 12);
		u64 muBak = mc->getMemUsage();
		u64 savepoint = mc->setSavepoint();
		for (int i = 0; i < 12; i++)
			mc->alloc(chunkSize);
		CPPUNIT_ASSERT(mc->getMemUsage() > chunkSize * 24);
		mc->resetToSavepoint(savepoint);
		CPPUNIT_ASSERT(mc->getMemUsage() == muBak);
		mc->reset();
		CPPUNIT_ASSERT(mc->getMemUsage() < muBak);
	}
	delete mc;
	mc = NULL;

	// 测试预留页面数
	for (uint i = 1; i <= 10; i++) {	
		mc = new MemoryContext(&commonMemPool, i);

		uint lastUsedPages = commonMemPool.getCurrentSize();
		
		for (uint j = 0; j < i; j++) {
			int cs = NTSE_PAGE_SIZE / 2 + 100;
			void *data = mc->alloc(cs);
			memset(data, 0, cs);
		}

		NTSE_ASSERT(lastUsedPages == commonMemPool.getCurrentSize());

		mc->reset();
		delete mc;
		mc = NULL;
	}
}