@Test public void overflow_record() { File f = TT.tempDbFile(); f.delete(); File f0 = new File(f.getPath() + ".wal.0"); File f1 = new File(f.getPath() + ".wal.1"); WriteAheadLog wal = new WriteAheadLog(f.getPath()); wal.open(WriteAheadLog.NOREPLAY); long lastPos = 0; while (!f1.exists()) { lastPos = wal.fileOffset; wal.walPutRecord(111L, new byte[100], 0, 100); assertTrue(f0.exists()); } assertTrue(WriteAheadLog.MAX_FILE_SIZE - 1000 < lastPos); assertTrue(WriteAheadLog.MAX_FILE_SIZE + 120 > lastPos); wal.destroyWalFiles(); }
@Test public void replay_commit_over_file_edge() { String f = TT.tempDbFile().getPath(); WriteAheadLog wal = new WriteAheadLog(f); byte[] b = TT.randomByteArray(20 * 1024 * 1024); wal.walPutRecord(11L, b, 0, b.length); wal.walPutRecord(33L, b, 0, b.length); wal.commit(); wal.close(); wal = new WriteAheadLog(f); wal.open( new WALSequence( new Object[] {WALSequence.beforeReplayStart}, new Object[] {WALSequence.writeRecord, 11L, 16L, b}, new Object[] {WALSequence.writeRecord, 33L, 4294967312L, b}, new Object[] {WALSequence.commit})); }
@Test public void empty_commit() { String f = TT.tempDbFile().getPath(); WriteAheadLog wal = new WriteAheadLog(f); byte[] b = TT.randomByteArray(1024); wal.walPutRecord(33L, b, 0, b.length); wal.commit(); wal.commit(); wal.seal(); wal.close(); wal = new WriteAheadLog(f); wal.open( new WALSequence( new Object[] {WALSequence.beforeReplayStart}, new Object[] {WALSequence.writeRecord, 33L, 16L, b}, new Object[] {WALSequence.commit}, new Object[] {WALSequence.commit})); }
void testRecord(final long recid, final byte[] data) { WriteAheadLog wal = new WriteAheadLog(null); wal.open(WriteAheadLog.NOREPLAY); wal.startNextFile(); final AtomicBoolean called = new AtomicBoolean(); final long pointer = wal.walPutRecord(recid, data, 0, data == null ? 0 : data.length); for (int i = 0; i < 1; i++) { byte[] val = wal.walGetRecord(pointer, recid); if (data == null) assertNull(val); else assertTrue(Arrays.equals(data, val)); wal.seal(); } WriteAheadLog.WALReplay r = new WriteAheadLog.WALReplay() { @Override public void beforeReplayStart() {} @Override public void afterReplayFinished() {} @Override public void writeLong(long offset, long value) { fail(); } @Override public void writeRecord(long recid2, long walId, Volume vol, long volOffset, int length) { assertFalse(called.getAndSet(true)); assertEquals(recid, recid2); if (data == null) { assertNull(vol); assertEquals(walId, 0); assertEquals(volOffset, 0); assertEquals(length, 0); } else { byte[] data = new byte[length]; vol.getData(volOffset, data, 0, data.length); assertTrue(Arrays.equals(data, data)); assertEquals(pointer, walId); } } @Override public void writeByteArray( long offset2, long walId, Volume vol, long volOffset, int length) { fail(); } @Override public void commit() { fail(); } @Override public void rollback() { fail(); } @Override public void writeTombstone(long recid) { fail(); } @Override public void writePreallocate(long recid) { fail(); } }; wal.replayWAL(r); assertTrue(called.get()); }