runDiff(bumpedSlab());
}
private void runDiff(Allocator allocator)
{
ContextState left = ContextState.allocate(3, 0, allocator);
ContextState right;
// equality: equal nodes, all counts same
left.writeElement(CounterId.fromInt(3), 3L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
right = new ContextState(ByteBufferUtil.clone(left.context), left.headerLength);
assert ContextRelationship.EQUAL ==
cc.diff(left.context, right.context);
// greater than: left has superset of nodes (counts equal)
left = ContextState.allocate(4, 0, allocator);
left.writeElement(CounterId.fromInt(3), 3L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
left.writeElement(CounterId.fromInt(12), 0L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 3L, 0L);
right.writeElement(CounterId.fromInt(6), 2L, 0L);
right.writeElement(CounterId.fromInt(9), 1L, 0L);
assert ContextRelationship.GREATER_THAN ==
cc.diff(left.context, right.context);
// less than: left has subset of nodes (counts equal)
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 3L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
right = ContextState.allocate(4, 0, allocator);
right.writeElement(CounterId.fromInt(3), 3L, 0L);
right.writeElement(CounterId.fromInt(6), 2L, 0L);
right.writeElement(CounterId.fromInt(9), 1L, 0L);
right.writeElement(CounterId.fromInt(12), 0L, 0L);
assert ContextRelationship.LESS_THAN ==
cc.diff(left.context, right.context);
// greater than: equal nodes, but left has higher counts
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 3L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 3L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 3L, 0L);
right.writeElement(CounterId.fromInt(6), 2L, 0L);
right.writeElement(CounterId.fromInt(9), 1L, 0L);
assert ContextRelationship.GREATER_THAN ==
cc.diff(left.context, right.context);
// less than: equal nodes, but right has higher counts
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 3L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 3L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 3L, 0L);
right.writeElement(CounterId.fromInt(6), 9L, 0L);
right.writeElement(CounterId.fromInt(9), 3L, 0L);
assert ContextRelationship.LESS_THAN ==
cc.diff(left.context, right.context);
// disjoint: right and left have disjoint node sets
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 1L, 0L);
left.writeElement(CounterId.fromInt(4), 1L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 1L, 0L);
right.writeElement(CounterId.fromInt(6), 1L, 0L);
right.writeElement(CounterId.fromInt(9), 1L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 1L, 0L);
left.writeElement(CounterId.fromInt(4), 1L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(2), 1L, 0L);
right.writeElement(CounterId.fromInt(6), 1L, 0L);
right.writeElement(CounterId.fromInt(12), 1L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
// disjoint: equal nodes, but right and left have higher counts in differing nodes
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 1L, 0L);
left.writeElement(CounterId.fromInt(6), 3L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 1L, 0L);
right.writeElement(CounterId.fromInt(6), 1L, 0L);
right.writeElement(CounterId.fromInt(9), 5L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 2L, 0L);
left.writeElement(CounterId.fromInt(6), 3L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 1L, 0L);
right.writeElement(CounterId.fromInt(6), 9L, 0L);
right.writeElement(CounterId.fromInt(9), 5L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
// disjoint: left has more nodes, but lower counts
left = ContextState.allocate(4, 0, allocator);
left.writeElement(CounterId.fromInt(3), 2L, 0L);
left.writeElement(CounterId.fromInt(6), 3L, 0L);
left.writeElement(CounterId.fromInt(9), 1L, 0L);
left.writeElement(CounterId.fromInt(12), 1L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 4L, 0L);
right.writeElement(CounterId.fromInt(6), 9L, 0L);
right.writeElement(CounterId.fromInt(9), 5L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
// disjoint: left has less nodes, but higher counts
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 5L, 0L);
left.writeElement(CounterId.fromInt(6), 3L, 0L);
left.writeElement(CounterId.fromInt(9), 2L, 0L);
right = ContextState.allocate(4, 0, allocator);
right.writeElement(CounterId.fromInt(3), 4L, 0L);
right.writeElement(CounterId.fromInt(6), 3L, 0L);
right.writeElement(CounterId.fromInt(9), 2L, 0L);
right.writeElement(CounterId.fromInt(12), 1L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
// disjoint: mixed nodes and counts
left = ContextState.allocate(3, 0, allocator);
left.writeElement(CounterId.fromInt(3), 5L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 2L, 0L);
right = ContextState.allocate(4, 0, allocator);
right.writeElement(CounterId.fromInt(3), 4L, 0L);
right.writeElement(CounterId.fromInt(6), 3L, 0L);
right.writeElement(CounterId.fromInt(9), 2L, 0L);
right.writeElement(CounterId.fromInt(12), 1L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
left = ContextState.allocate(4, 0, allocator);
left.writeElement(CounterId.fromInt(3), 5L, 0L);
left.writeElement(CounterId.fromInt(6), 2L, 0L);
left.writeElement(CounterId.fromInt(7), 2L, 0L);
left.writeElement(CounterId.fromInt(9), 2L, 0L);
right = ContextState.allocate(3, 0, allocator);
right.writeElement(CounterId.fromInt(3), 4L, 0L);
right.writeElement(CounterId.fromInt(6), 3L, 0L);
right.writeElement(CounterId.fromInt(9), 2L, 0L);
assert ContextRelationship.DISJOINT ==
cc.diff(left.context, right.context);
}