/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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.apache.accumulo.core.iterators; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; import java.util.Collection; import java.util.HashMap; import java.util.HashSet; import java.util.Map; import java.util.TreeMap; import org.apache.accumulo.core.data.ByteSequence; import org.apache.accumulo.core.data.Key; import org.apache.accumulo.core.data.Range; import org.apache.accumulo.core.data.Value; import org.apache.hadoop.io.Text; import org.junit.Test; public class FirstEntryInRowTest { private static final Map<String,String> EMPTY_MAP = new HashMap<>(); private static final Collection<ByteSequence> EMPTY_SET = new HashSet<>(); private Key newKey(String row, String cf, String cq, long time) { return new Key(new Text(row), new Text(cf), new Text(cq), time); } private Key newKey(int row, int cf, int cq, long time) { return newKey(String.format("%06d", row), String.format("%06d", cf), String.format("%06d", cq), time); } private void put(TreeMap<Key,Value> tm, String row, String cf, String cq, long time, Value val) { tm.put(newKey(row, cf, cq, time), val); } private void put(TreeMap<Key,Value> tm, String row, String cf, String cq, long time, String val) { put(tm, row, cf, cq, time, new Value(val.getBytes())); } private void put(TreeMap<Key,Value> tm, int row, int cf, int cq, long time, int val) { tm.put(newKey(row, cf, cq, time), new Value((val + "").getBytes())); } private void testAndCallNext(FirstEntryInRowIterator rdi, String row, String cf, String cq, long time, String val) throws Exception { assertTrue(rdi.hasTop()); assertEquals(newKey(row, cf, cq, time), rdi.getTopKey()); assertEquals(val, rdi.getTopValue().toString()); rdi.next(); } private void testAndCallNext(FirstEntryInRowIterator rdi, int row, int cf, int cq, long time, int val) throws Exception { assertTrue(rdi.hasTop()); assertEquals(newKey(row, cf, cq, time), rdi.getTopKey()); assertEquals(val, Integer.parseInt(rdi.getTopValue().toString())); rdi.next(); } @Test public void test1() throws Exception { TreeMap<Key,Value> tm1 = new TreeMap<>(); put(tm1, "r1", "cf1", "cq1", 5, "v1"); put(tm1, "r1", "cf1", "cq3", 5, "v2"); put(tm1, "r2", "cf1", "cq1", 5, "v3"); put(tm1, "r2", "cf2", "cq4", 5, "v4"); put(tm1, "r2", "cf2", "cq5", 5, "v5"); put(tm1, "r3", "cf3", "cq6", 5, "v6"); FirstEntryInRowIterator fei = new FirstEntryInRowIterator(); fei.init(new SortedMapIterator(tm1), EMPTY_MAP, null); fei.seek(new Range(), EMPTY_SET, false); testAndCallNext(fei, "r1", "cf1", "cq1", 5, "v1"); testAndCallNext(fei, "r2", "cf1", "cq1", 5, "v3"); testAndCallNext(fei, "r3", "cf3", "cq6", 5, "v6"); assertFalse(fei.hasTop()); } @Test public void test2() throws Exception { TreeMap<Key,Value> tm1 = new TreeMap<>(); for (int r = 0; r < 5; r++) { for (int cf = r; cf < 100; cf++) { for (int cq = 3; cq < 6; cq++) { put(tm1, r, cf, cq, 6, r * cf * cq); } } } FirstEntryInRowIterator fei = new FirstEntryInRowIterator(); fei.init(new SortedMapIterator(tm1), EMPTY_MAP, null); fei.seek(new Range(newKey(0, 10, 0, 0), null), EMPTY_SET, false); testAndCallNext(fei, 1, 1, 3, 6, 1 * 1 * 3); testAndCallNext(fei, 2, 2, 3, 6, 2 * 2 * 3); testAndCallNext(fei, 3, 3, 3, 6, 3 * 3 * 3); testAndCallNext(fei, 4, 4, 3, 6, 4 * 4 * 3); assertFalse(fei.hasTop()); fei.seek(new Range(newKey(1, 1, 3, 6), newKey(3, 3, 3, 6)), EMPTY_SET, false); testAndCallNext(fei, 1, 1, 3, 6, 1 * 1 * 3); testAndCallNext(fei, 2, 2, 3, 6, 2 * 2 * 3); testAndCallNext(fei, 3, 3, 3, 6, 3 * 3 * 3); assertFalse(fei.hasTop()); fei.seek(new Range(newKey(1, 1, 3, 6), false, newKey(3, 3, 3, 6), false), EMPTY_SET, false); testAndCallNext(fei, 2, 2, 3, 6, 2 * 2 * 3); assertFalse(fei.hasTop()); } }