@Test
public void testForward() {
// Test for IntValue
@SuppressWarnings("unchecked")
final RecordComparator intComp = new RecordComparator(new int[] {0}, new Class[] {IntValue.class});
final ChannelSelector<Record> oe1 = new RecordOutputEmitter(ShipStrategyType.FORWARD, intComp);
int numChannels = 100;
int numRecords = 50000;
int[] hit = new int[numChannels];
for (int i = 0; i < numRecords; i++) {
IntValue k = new IntValue(i);
Record rec = new Record(k);
int[] chans = oe1.selectChannels(rec, hit.length);
for(int j=0; j < chans.length; j++) {
hit[chans[j]]++;
}
}
int cnt = 0;
for (int i = 0; i < hit.length; i++) {
assertTrue(hit[i] == (numRecords/numChannels) || hit[i] == (numRecords/numChannels)-1);
cnt += hit[i];
}
assertTrue(cnt == numRecords);
// Test for StringValue
@SuppressWarnings("unchecked")
final RecordComparator stringComp = new RecordComparator(new int[] {0}, new Class[] {StringValue.class});
final ChannelSelector<Record> oe2 = new RecordOutputEmitter(ShipStrategyType.FORWARD, stringComp);
numChannels = 100;
numRecords = 10000;
hit = new int[numChannels];
for (int i = 0; i < numRecords; i++) {
StringValue k = new StringValue(i + "");
Record rec = new Record(k);
int[] chans = oe2.selectChannels(rec, hit.length);
for(int j=0; j < chans.length; j++) {
hit[chans[j]]++;
}
}