|
17 | 17 | package com.mongodb; |
18 | 18 |
|
19 | 19 | import com.mongodb.util.TestCase; |
| 20 | +import org.junit.Assert; |
20 | 21 | import org.junit.Test; |
21 | 22 |
|
22 | 23 | import java.net.UnknownHostException; |
@@ -582,4 +583,133 @@ public void testMaxTimeForSize() { |
582 | 583 | disableMaxTimeFailPoint(); |
583 | 584 | } |
584 | 585 | } |
| 586 | + |
| 587 | + private void insertData() { |
| 588 | + for (int i = 0; i < 10; i++) { |
| 589 | + collection.insert(new BasicDBObject("_id", i).append("x", i)); |
| 590 | + } |
| 591 | + collection.ensureIndex("x"); |
| 592 | + } |
| 593 | + |
| 594 | + @Test |
| 595 | + public void testMaxScan() { |
| 596 | + insertData(); |
| 597 | + countResults(new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 598 | + .addSpecial("$maxScan", 4), 4); |
| 599 | + countResults(new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()).maxScan(4), 4); |
| 600 | + } |
| 601 | + |
| 602 | + @Test |
| 603 | + public void testMax() { |
| 604 | + insertData(); |
| 605 | + countResults(new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 606 | + .addSpecial("$max", new BasicDBObject("x", 4)), 4); |
| 607 | + countResults(new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 608 | + .max(new BasicDBObject("x", 4)), 4); |
| 609 | + } |
| 610 | + |
| 611 | + @Test |
| 612 | + public void testMin() { |
| 613 | + insertData(); |
| 614 | + countResults(new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 615 | + .addSpecial("$min", new BasicDBObject("x", 4)), 6); |
| 616 | + countResults(new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 617 | + .min(new BasicDBObject("x", 4)), 6); |
| 618 | + } |
| 619 | + |
| 620 | + @Test |
| 621 | + public void testReturnKey() { |
| 622 | + DBCursor cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 623 | + .addSpecial("$returnKey", true); |
| 624 | + try { |
| 625 | + while (cursor.hasNext()) { |
| 626 | + Assert.assertNull(cursor.next() |
| 627 | + .get("_id")); |
| 628 | + } |
| 629 | + } finally { |
| 630 | + cursor.close(); |
| 631 | + } |
| 632 | + cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 633 | + .returnKey(); |
| 634 | + try { |
| 635 | + while (cursor.hasNext()) { |
| 636 | + Assert.assertNull(cursor.next() |
| 637 | + .get("_id")); |
| 638 | + } |
| 639 | + } finally { |
| 640 | + cursor.close(); |
| 641 | + } |
| 642 | + } |
| 643 | + |
| 644 | + @Test |
| 645 | + public void testShowDiskLoc() { |
| 646 | + DBCursor cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 647 | + .addSpecial("$showDiskLoc", true); |
| 648 | + try { |
| 649 | + while (cursor.hasNext()) { |
| 650 | + DBObject next = cursor.next(); |
| 651 | + Assert.assertNotNull(next.toString(), next.get("$diskLoc")); |
| 652 | + } |
| 653 | + } finally { |
| 654 | + cursor.close(); |
| 655 | + } |
| 656 | + cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 657 | + .showDiskLoc(); |
| 658 | + try { |
| 659 | + while (cursor.hasNext()) { |
| 660 | + DBObject next = cursor.next(); |
| 661 | + Assert.assertNotNull(next.toString(), next.get("$diskLoc")); |
| 662 | + } |
| 663 | + } finally { |
| 664 | + cursor.close(); |
| 665 | + } |
| 666 | + } |
| 667 | + |
| 668 | + @Test(expected = MongoException.class) |
| 669 | + public void testSnapshotWithHint() { |
| 670 | + DBCursor cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 671 | + .hint("x") |
| 672 | + .addSpecial("$snapshot", true); |
| 673 | + try { |
| 674 | + while (cursor.hasNext()) { |
| 675 | + DBObject next = cursor.next(); |
| 676 | + } |
| 677 | + } finally { |
| 678 | + cursor.close(); |
| 679 | + } |
| 680 | + } |
| 681 | + |
| 682 | + @Test(expected = MongoException.class) |
| 683 | + public void testSnapshotWithSort() { |
| 684 | + DBCursor cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 685 | + .sort(new BasicDBObject("x", 1)) |
| 686 | + .addSpecial("$snapshot", true); |
| 687 | + try { |
| 688 | + while (cursor.hasNext()) { |
| 689 | + DBObject next = cursor.next(); |
| 690 | + } |
| 691 | + } finally { |
| 692 | + cursor.close(); |
| 693 | + } |
| 694 | + } |
| 695 | + |
| 696 | + private void countResults(final DBCursor cursor, final int expected) { |
| 697 | + int count = 0; |
| 698 | + while (cursor.hasNext()) { |
| 699 | + cursor.next(); |
| 700 | + count++; |
| 701 | + } |
| 702 | + cursor.close(); |
| 703 | + assertEquals(expected, count); |
| 704 | + } |
| 705 | + |
| 706 | + @Test |
| 707 | + public void testComment() { |
| 708 | + DBCursor cursor = new DBCursor(collection, new BasicDBObject(), new BasicDBObject(), ReadPreference.primary()) |
| 709 | + .addSpecial("$comment", "test comment"); |
| 710 | + while (cursor.hasNext()) { |
| 711 | + cursor.next(); |
| 712 | + } |
| 713 | + } |
| 714 | + |
585 | 715 | } |
0 commit comments