HashEntriesTest.java
/*
* Copyright (C) 2014 Robert Stupp, Koeln, Germany, robert-stupp.de
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.caffinitas.ohc.linked;
import org.caffinitas.ohc.HashAlgorithm;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.Test;
import java.nio.ByteBuffer;
import static org.testng.Assert.*;
public class HashEntriesTest
{
@AfterMethod(alwaysRun = true)
public void deinit()
{
Uns.clearUnsDebugForTest();
}
static final long MIN_ALLOC_LEN = 128;
@Test
public void testInit() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
boolean ok = false;
try
{
HashEntries.init(0x98765432abcddeafL, 5, 10, adr, 0, 0L);
assertEquals(Uns.getLong(adr, Util.ENTRY_OFF_HASH), 0x98765432abcddeafL);
assertEquals(Uns.getInt(adr, Util.ENTRY_OFF_KEY_LENGTH), 5L);
assertEquals(Uns.getInt(adr, Util.ENTRY_OFF_VALUE_LENGTH), 10L);
assertEquals(HashEntries.getHash(adr), 0x98765432abcddeafL);
assertEquals(HashEntries.getKeyLen(adr), 5L);
assertEquals(HashEntries.getValueLen(adr), 10L);
assertTrue(HashEntries.dereference(adr));
ok = true;
}
finally
{
if (!ok)
Uns.free(adr);
}
}
@Test
public void testCompareKey() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
KeyBuffer key = new KeyBuffer(11);
try
{
HashEntries.init(0L, 11, 0, adr, Util.SENTINEL_NOT_PRESENT, 0L);
ByteBuffer keyBuffer = key.byteBuffer();
keyBuffer.putInt(0x98765432);
keyBuffer.putInt(0xabcdabba);
keyBuffer.put((byte)(0x44 & 0xff));
keyBuffer.put((byte)(0x55 & 0xff));
keyBuffer.put((byte)(0x88 & 0xff));
key.finish(Hasher.create(HashAlgorithm.MURMUR3));
Uns.setMemory(adr, Util.ENTRY_OFF_DATA, 11, (byte) 0);
assertFalse(key.sameKey(adr));
Uns.copyMemory(key.buffer, 0, adr, Util.ENTRY_OFF_DATA, 11);
HashEntries.init(key.hash(), 11, 0, adr, Util.SENTINEL_NOT_PRESENT, 0L);
assertTrue(key.sameKey(adr));
}
finally
{
Uns.free(adr);
}
}
@Test
public void testGetSetLRUNext() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
try
{
Uns.setMemory(adr, 0, MIN_ALLOC_LEN, (byte) 0);
HashEntries.init(0x98765432abcddeafL, 5, 10, adr, 0, 0L);
Uns.putLong(adr, Util.ENTRY_OFF_LRU_NEXT, 0x98765432abdffeedL);
assertEquals(HashEntries.getLRUNext(adr), 0x98765432abdffeedL);
HashEntries.setLRUNext(adr, 0xfafefcfb23242526L);
assertEquals(Uns.getLong(adr, Util.ENTRY_OFF_LRU_NEXT), 0xfafefcfb23242526L);
}
finally
{
Uns.free(adr);
}
}
@Test
public void testGetSetLRUPrev() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
try
{
Uns.setMemory(adr, 0, MIN_ALLOC_LEN, (byte) 0);
HashEntries.init(0x98765432abcddeafL, 5, 10, adr, 0, 0L);
Uns.putLong(adr, Util.ENTRY_OFF_LRU_PREV, 0x98765432abdffeedL);
assertEquals(HashEntries.getLRUPrev(adr), 0x98765432abdffeedL);
HashEntries.setLRUPrev(adr, 0xfafefcfb23242526L);
assertEquals(Uns.getLong(adr, Util.ENTRY_OFF_LRU_PREV), 0xfafefcfb23242526L);
}
finally
{
Uns.free(adr);
}
}
@Test
public void testGetHash() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
try
{
Uns.setMemory(adr, 0, MIN_ALLOC_LEN, (byte) 0);
HashEntries.init(0x98765432abcddeafL, 5, 10, adr, 0, 0L);
assertEquals(HashEntries.getHash(adr), 0x98765432abcddeafL);
assertEquals(Uns.getLong(adr, Util.ENTRY_OFF_HASH), 0x98765432abcddeafL);
}
finally
{
Uns.free(adr);
}
}
@Test
public void testGetSetNext() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
try
{
Uns.setMemory(adr, 0, MIN_ALLOC_LEN, (byte) 0);
HashEntries.init(0x98765432abcddeafL, 5, 10, adr, 0, 0L);
Uns.putLong(adr, Util.ENTRY_OFF_NEXT, 0x98765432abdffeedL);
assertEquals(HashEntries.getNext(adr), 0x98765432abdffeedL);
HashEntries.setNext(adr, 0xfafefcfb23242526L);
assertEquals(Uns.getLong(adr, Util.ENTRY_OFF_NEXT), 0xfafefcfb23242526L);
}
finally
{
Uns.free(adr);
}
}
@Test
public void testGetAllocLen() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
try
{
HashEntries.init(0x98765432abcddeafL, 0, 10, adr, 0, 0L);
assertEquals(HashEntries.getAllocLen(adr), Util.ENTRY_OFF_DATA + 10L);
HashEntries.init(0x98765432abcddeafL, 5, 10, adr, 0, 0L);
assertEquals(HashEntries.getAllocLen(adr), Util.ENTRY_OFF_DATA + 8L + 10L);
HashEntries.init(0x98765432abcddeafL, 8, 10, adr, 0, 0L);
assertEquals(HashEntries.getAllocLen(adr), Util.ENTRY_OFF_DATA + 8L + 10L);
HashEntries.init(0x98765432abcddeafL, 9, 10, adr, 0, 0L);
assertEquals(HashEntries.getAllocLen(adr), Util.ENTRY_OFF_DATA + 16L + 10L);
HashEntries.init(0x98765432abcddeafL, 15, 10, adr, 0, 0L);
assertEquals(HashEntries.getAllocLen(adr), Util.ENTRY_OFF_DATA + 16L + 10L);
HashEntries.init(0x98765432abcddeafL, 16, 10, adr, 0, 0L);
assertEquals(HashEntries.getAllocLen(adr), Util.ENTRY_OFF_DATA + 16L + 10L);
}
finally
{
Uns.free(adr);
}
}
@Test
public void testReferenceDereference() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
boolean ok = false;
try
{
HashEntries.init(0x98765432abcddeafL, 0, 10, adr, 0, 0L);
HashEntries.reference(adr); // to 2
HashEntries.reference(adr); // to 3
HashEntries.reference(adr); // to 4
assertEquals(Uns.getInt(adr, Util.ENTRY_OFF_REFCOUNT), 4);
assertFalse(HashEntries.dereference(adr)); // to 3
assertFalse(HashEntries.dereference(adr)); // to 2
assertFalse(HashEntries.dereference(adr)); // to 1
assertTrue(HashEntries.dereference(adr)); // to 0
ok = true;
}
finally
{
if (!ok)
Uns.free(adr);
}
}
@Test
public void testDereferenceFail() throws Exception
{
long adr = Uns.allocate(MIN_ALLOC_LEN);
boolean ok = false;
try
{
HashEntries.init(0x98765432abcddeafL, 0, 10, adr, Util.SENTINEL_NOT_PRESENT, 0L);
assertTrue(HashEntries.dereference(adr)); // to 0
ok = true;
// must NOT dereference another time - memory has been free()'d !!!!
//HashEntries.dereference(adr);
}
finally
{
if (!ok)
Uns.free(adr);
}
}
}