Expose ZOOM query object
[yaz4j-moved-to-github.git] / src / test / org / yaz4j / ConnectionTest.java
index 056039b..38a4f3e 100644 (file)
@@ -6,7 +6,7 @@ import org.yaz4j.exception.*;
 import java.util.List;
 
 public class ConnectionTest {
-
+  
   @Test
   public void testConnection() {
     Connection con = new Connection("z3950.indexdata.dk:210/gils", 0);
@@ -15,6 +15,51 @@ public class ConnectionTest {
       con.setSyntax("sutrs");
       System.out.println("Open connection to z3950.indexdata.dk:210/gils...");
       con.connect();
+      ResultSet s = con.search(new PrefixQuery("@attr 1=4 utah"));
+      System.out.println("Search for 'utah'...");
+      assertNotNull(s);
+      assertEquals(s.getHitCount(), 9);
+      Record rec = s.getRecord(0);
+      assertNotNull(rec);
+      byte[] content = rec.getContent();
+      // first SUTRS record
+      assertEquals(content.length, 1940);
+      assertEquals(content[0], 103);
+      assertEquals(rec.getSyntax(), "SUTRS");
+      assertEquals(rec.getDatabase(), "gils");
+      System.out.println("Read all records..");
+      // read all records
+      int i = 0;
+      for (Record r : s) {
+        assertNotNull(r);
+        System.out.println("Got "+i+" record of type "+r.getSyntax());
+        i++;
+      }
+      System.out.println("Try sorting them...");
+      s.sort("yaz", "1=4 >i 1=21 >s");
+      System.out.println("Try fetching them all at once...");
+      i = 0;
+      List<Record> all = s.getRecords(0, (int) s.getHitCount());
+      for (Record r : all) {
+        System.out.println("getRecords, rec '"+i+"'"+r.getSyntax());
+        System.out.println(r.render());
+        i++;
+      }
+    } catch (ZoomException ze) {
+      fail(ze.getMessage());
+    } finally {
+      con.close();
+    }
+  }
+
+  @Test
+  public void testConnectionDeprecated() {
+    Connection con = new Connection("z3950.indexdata.dk:210/gils", 0);
+    assertNotNull(con);
+    try {
+      con.setSyntax("sutrs");
+      System.out.println("Open connection to z3950.indexdata.dk:210/gils...");
+      con.connect();
       ResultSet s = con.search("@attr 1=4 utah",
         Connection.QueryType.PrefixQuery);
       System.out.println("Search for 'utah'...");