diff --git a/src/main/scala/org/kiji/testing/fakehtable/FakeHTable.scala b/src/main/scala/org/kiji/testing/fakehtable/FakeHTable.scala index 4be7bcf..2df8837 100644 --- a/src/main/scala/org/kiji/testing/fakehtable/FakeHTable.scala +++ b/src/main/scala/org/kiji/testing/fakehtable/FakeHTable.scala @@ -845,7 +845,7 @@ class FakeHTable( } } if (!scan.getStopRow.isEmpty - && (BytesComparator.compare(key, scan.getStopRow) >= 0)) { + && (key == null || BytesComparator.compare(key, scan.getStopRow) >= 0)) { key = null } diff --git a/src/test/scala/org/kiji/testing/fakehtable/TestFakeHTable.scala b/src/test/scala/org/kiji/testing/fakehtable/TestFakeHTable.scala index 651abe6..ff1642e 100644 --- a/src/test/scala/org/kiji/testing/fakehtable/TestFakeHTable.scala +++ b/src/test/scala/org/kiji/testing/fakehtable/TestFakeHTable.scala @@ -288,6 +288,14 @@ class TestFakeHTable extends FunSuite { expect(null)(iterator.next()) } + test("ResultScanner with stop key on empty table ") { + val table = new FakeHTable(name = "table", desc = null) + val scanner = table.getScanner(new Scan().setStopRow("stop")) + val iterator = scanner.iterator() + expect(false)(iterator.hasNext()) + expect(null)(iterator.next()) + } + test("ResultScanner.hasNext") { val table = new FakeHTable(name = "table", desc = null) table.put(new Put("key")