Merge branch 'master' of ssh://git.indexdata.com/home/git/pub/yaz
authorDennis Schafroth <dennis@indexdata.com>
Mon, 23 Sep 2013 07:27:39 +0000 (09:27 +0200)
committerDennis Schafroth <dennis@indexdata.com>
Mon, 23 Sep 2013 07:27:39 +0000 (09:27 +0200)
1  2 
test/test_rpn2solr.c

diff --combined test/test_rpn2solr.c
@@@ -39,10 -39,7 +39,10 @@@ static int compare(solr_transform_t ct
              if (solr && !strcmp(wrbuf_cstr(w), solr))
                  ret = 1;
              else
 -                yaz_log(YLOG_LOG, "Exp: %s", solr);
 +            {
 +                yaz_log(YLOG_WARN, " expected: %s", solr ? solr : "null");
 +                yaz_log(YLOG_WARN, " got:      %s", wrbuf_cstr(w));
 +            }
          }
      }
      wrbuf_destroy(w);
@@@ -54,17 -51,13 +54,18 @@@ static void tst1(void
  {
      solr_transform_t ct = solr_transform_create();
  
+     YAZ_CHECK(compare(ct, "@or a @and b c", "a OR (b AND c)"));
      YAZ_CHECK(compare(ct, "abc", "abc"));
      YAZ_CHECK(compare(ct, "\"a b c\"", "\"a b c\""));
      YAZ_CHECK(compare(ct, "@not a b", "a AND NOT b"));
      YAZ_CHECK(compare(ct, "@and @or a b c", "(a OR b) AND c"));
      YAZ_CHECK(compare(ct, "@and a b", "a AND b"));
      YAZ_CHECK(compare(ct, "@or a b", "a OR b"));
 +    YAZ_CHECK(compare(ct, "@or a @and b c", "a OR (b AND c)"));
 +    YAZ_CHECK(compare(ct, "@or @and a b @and c d", "(a AND b) OR (c AND d)"));
 +    YAZ_CHECK(compare(ct, "@or @or a b @or c d", "(a OR b) OR (c OR d)"));
 +    YAZ_CHECK(compare(ct, "@or @or @or a b @or c d @or e f", "(a OR b) OR (c OR d)"));
 +    YAZ_CHECK(compare(ct, "@and @and a b @and c d", "(a AND b) AND (c AND d)"));
      YAZ_CHECK(compare(ct, "@attr 1=field abc", "field:abc"));
      YAZ_CHECK(compare(ct, "@attr 1=field \"a b c\"", "field:\"a b c\""));
      YAZ_CHECK(compare(ct, "@attr 1=4 abc", 0)); /* should fail */
@@@ -142,6 -135,7 +143,6 @@@ static void tst2(void
      YAZ_CHECK(compare(ct, "@attr 1=4 @attr 4=1 @attr 6=1 abc", "dc.title:abc"));
  
      YAZ_CHECK(compare(ct, "@attr 1=1016 abc", "abc"));
 -
      /* Date check */ 
      YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=1 1980", "dc.date:[* TO 1980}"));
      YAZ_CHECK(compare(ct, "@attr 1=30 @attr 2=2 1980", "dc.date:[* TO 1980]"));