test_term.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. #include "test.h"
  2. static int test_iriref()
  3. {
  4. char *uri1_data = "http://example.org/term#12345";
  5. char *uri2_data = "ns1:12345";
  6. char *uri3_data = "ns2:12345";
  7. LSUP_NSMap *nsm1 = LSUP_nsmap_new();
  8. LSUP_nsmap_add (nsm1, "ns1", "http://example.org/term#");
  9. LSUP_NSMap *nsm2 = LSUP_nsmap_new();
  10. LSUP_nsmap_add (nsm2, "ns2", "http://example.org/term#");
  11. LSUP_Term *uri1 = LSUP_iriref_new (uri1_data, NULL);
  12. ASSERT (uri1, "IRI is NULL!");
  13. ASSERT (LSUP_iriref_nsm (uri1) == NULL, "Wrong NSMap!");
  14. char *pfx = LSUP_iriref_prefix (uri1);
  15. char *path = LSUP_iriref_path (uri1);
  16. char *frag = LSUP_iriref_frag (uri1);
  17. EXPECT_STR_EQ (pfx, "http://example.org");
  18. EXPECT_STR_EQ (path, "/term#12345");
  19. EXPECT_STR_EQ (frag, "12345");
  20. free (pfx);
  21. free (path);
  22. free (frag);
  23. LSUP_Term *uri2 = LSUP_iriref_new (uri2_data, nsm1);
  24. ASSERT (uri2, "IRI is NULL!");
  25. ASSERT (LSUP_iriref_nsm (uri2) == nsm1, "Wrong NSMap!");
  26. LSUP_Term *uri3 = LSUP_iriref_new (uri3_data, nsm2);
  27. ASSERT (uri3, "IRI is NULL!");
  28. ASSERT (LSUP_iriref_nsm (uri3) == nsm2, "Wrong NSMap!");
  29. LSUP_Term *uri4 = LSUP_iriref_new (NULL, NULL);
  30. ASSERT (uri4, "IRI is NULL!");
  31. LSUP_Term *uri5 = LSUP_iriref_new (NULL, NULL);
  32. ASSERT (uri5, "IRI is NULL!");
  33. EXPECT_INT_EQ (uri1->type, LSUP_TERM_IRIREF);
  34. EXPECT_INT_EQ (uri2->type, LSUP_TERM_NS_IRIREF);
  35. EXPECT_INT_EQ (uri3->type, LSUP_TERM_NS_IRIREF);
  36. EXPECT_INT_EQ (uri4->type, LSUP_TERM_IRIREF);
  37. EXPECT_INT_EQ (uri5->type, LSUP_TERM_IRIREF);
  38. ASSERT (LSUP_term_equals (uri1, uri2), "IRIs don't match!");
  39. ASSERT (LSUP_term_equals (uri2, uri3), "IRIs don't match!");
  40. ASSERT (!LSUP_term_equals (uri3, uri4), "IRIs shouldn't match!");
  41. ASSERT (!LSUP_term_equals (uri4, uri5), "IRIs shouldn't match!");
  42. LSUP_term_free (uri1);
  43. LSUP_term_free (uri2);
  44. LSUP_term_free (uri3);
  45. LSUP_term_free (uri4);
  46. LSUP_term_free (uri5);
  47. LSUP_nsmap_free (nsm1);
  48. LSUP_nsmap_free (nsm2);
  49. return 0;
  50. }
  51. static int test_iriref_parts()
  52. {
  53. char *data[18][4] = {
  54. {"http://example.org", "http://example.org", "", ""},
  55. {"http://example.org/", "http://example.org", "/", ""},
  56. {"http://example.org?option", "http://example.org", "?option", ""},
  57. {"http://example.org/?option", "http://example.org", "/?option", ""},
  58. {
  59. "http://example.org#anchor",
  60. "http://example.org", "#anchor", "anchor"},
  61. {
  62. "http://example.org/#anchor",
  63. "http://example.org", "/#anchor", "anchor"},
  64. {
  65. "http://example.org/?option#anchor",
  66. "http://example.org", "/?option#anchor", "anchor"},
  67. {
  68. "http://example.org?option#anchor",
  69. "http://example.org", "?option#anchor", "anchor"},
  70. {
  71. "http://hanzi.edu/漢魏六朝隋碑誌索引/53?option#anchor",
  72. "http://hanzi.edu", "/漢魏六朝隋碑誌索引/53?option#anchor",
  73. "anchor"},
  74. {"ftp:///", "ftp://", "/", ""},
  75. {
  76. "file:///usr/local/lib/liblsuprdf.so",
  77. "file://", "/usr/local/lib/liblsuprdf.so", ""},
  78. {"/", "", "/", ""},
  79. {"/tmp", "", "/tmp", ""},
  80. {"./tmp", "", "./tmp", ""},
  81. {"tmp/test.nt", "", "tmp/test.nt", ""},
  82. {"", "", "", ""},
  83. {"#hello", "", "#hello", "hello"},
  84. {
  85. "urn:uuid:950404b6-0e4f-4e21-8267-c8c00e83563b",
  86. "urn:", "uuid:950404b6-0e4f-4e21-8267-c8c00e83563b", ""}
  87. };
  88. for (size_t i = 0; i < 18; i++) {
  89. LSUP_Term *iri = LSUP_iriref_new(data[i][0], NULL);
  90. char
  91. *pfx = LSUP_iriref_prefix (iri),
  92. *path = LSUP_iriref_path (iri),
  93. *frag = LSUP_iriref_frag (iri);
  94. EXPECT_STR_EQ (pfx, data[i][1]);
  95. EXPECT_STR_EQ (path, data[i][2]);
  96. EXPECT_STR_EQ (frag, data[i][3]);
  97. free (pfx);
  98. free (path);
  99. free (frag);
  100. LSUP_term_free (iri);
  101. }
  102. return 0;
  103. }
  104. static int test_iriref_abs_rel()
  105. {
  106. LSUP_NSMap *nsm1 = LSUP_nsmap_new();
  107. LSUP_nsmap_add (nsm1, "ns1", "http://example.org/res/");
  108. LSUP_Term *root1 = LSUP_iriref_new ("http://example.org/res/", NULL);
  109. LSUP_Term *root2 = LSUP_iriref_new ("urn:id:", NULL);
  110. LSUP_Term *rel_iri1 = LSUP_iriref_new ("http://anotherex.net/res/25", NULL);
  111. LSUP_Term *rel_iri2 = LSUP_iriref_new ("/admin/32", NULL);
  112. LSUP_Term *rel_iri3 = LSUP_iriref_new ("45/678", NULL);
  113. LSUP_Term *abs_iri1 = LSUP_iriref_absolute (root1, rel_iri1);
  114. LSUP_Term *abs_iri2 = LSUP_iriref_absolute (root1, rel_iri2);
  115. LSUP_Term *abs_iri3 = LSUP_iriref_absolute (root1, rel_iri3);
  116. EXPECT_STR_EQ (abs_iri1->data, rel_iri1->data);
  117. EXPECT_STR_EQ (abs_iri2->data, "http://example.org/admin/32");
  118. EXPECT_STR_EQ (abs_iri3->data, "http://example.org/res/45/678");
  119. LSUP_Term *rel_iri1a = LSUP_iriref_relative (root1, abs_iri1);
  120. LSUP_Term *rel_iri2a = LSUP_iriref_relative (root1, abs_iri2);
  121. LSUP_Term *rel_iri3a = LSUP_iriref_relative (root1, abs_iri3);
  122. EXPECT_STR_EQ (rel_iri1a->data, rel_iri1->data);
  123. EXPECT_STR_EQ (rel_iri2a->data, abs_iri2->data);
  124. EXPECT_STR_EQ (rel_iri3a->data, "45/678");
  125. LSUP_term_free (root1);
  126. LSUP_term_free (root2);
  127. LSUP_term_free (rel_iri1);
  128. LSUP_term_free (rel_iri2);
  129. LSUP_term_free (rel_iri3);
  130. LSUP_term_free (abs_iri1);
  131. LSUP_term_free (abs_iri2);
  132. LSUP_term_free (abs_iri3);
  133. LSUP_term_free (rel_iri1a);
  134. LSUP_term_free (rel_iri2a);
  135. LSUP_term_free (rel_iri3a);
  136. LSUP_nsmap_free (nsm1);
  137. return 0;
  138. }
  139. static int test_literal()
  140. {
  141. char *data = "hello";
  142. char *datatype = "urn:my:datatype";
  143. char *lang = "en-US";
  144. LSUP_Term *lit1 = LSUP_literal_new (data, LSUP_iriref_new (datatype, NULL));
  145. EXPECT_INT_EQ (lit1->type, LSUP_TERM_LITERAL);
  146. EXPECT_STR_EQ (lit1->data, data);
  147. EXPECT_STR_EQ (lit1->datatype->data, datatype);
  148. LSUP_Term *lit2 = LSUP_literal_new (data, LSUP_default_datatype);
  149. EXPECT_INT_EQ (lit2->type, LSUP_TERM_LITERAL);
  150. EXPECT_STR_EQ (lit2->data, data);
  151. EXPECT_STR_EQ (lit2->datatype->data, DEFAULT_DTYPE);
  152. LSUP_Term *lit3 = LSUP_literal_new (data, NULL);
  153. EXPECT_INT_EQ (lit3->type, LSUP_TERM_LITERAL);
  154. EXPECT_STR_EQ (lit3->data, data);
  155. EXPECT_STR_EQ (lit3->datatype->data, DEFAULT_DTYPE);
  156. ASSERT (lit1->datatype != lit2->datatype, "Wrong data type match!");
  157. ASSERT (lit2->datatype == lit3->datatype, "Data type mismatch!");
  158. ASSERT (!LSUP_term_equals (lit1, lit2), "Wrong term match!");
  159. ASSERT (LSUP_term_equals (lit2, lit3), "Term mismatch!");
  160. LSUP_Term *lt_lit1 = LSUP_lt_literal_new (data, lang);
  161. EXPECT_INT_EQ (lt_lit1->type, LSUP_TERM_LT_LITERAL);
  162. EXPECT_STR_EQ (lt_lit1->data, data);
  163. EXPECT_STR_EQ (lt_lit1->lang, lang);
  164. // LT-literal without lang is a normal string literal.
  165. LSUP_Term *lt_lit2 = LSUP_lt_literal_new (data, NULL);
  166. EXPECT_INT_EQ (lt_lit2->type, LSUP_TERM_LITERAL);
  167. EXPECT_STR_EQ (lt_lit2->data, data);
  168. ASSERT (LSUP_term_equals (lt_lit2, lit2), "Term mismatch!");
  169. EXPECT_STR_EQ (lt_lit2->datatype->data, DEFAULT_DTYPE);
  170. LSUP_term_free (lit1);
  171. LSUP_term_free (lit2);
  172. LSUP_term_free (lit3);
  173. LSUP_term_free (lt_lit1);
  174. LSUP_term_free (lt_lit2);
  175. return 0;
  176. }
  177. static int test_undefined()
  178. {
  179. LSUP_Term *undef1 = LSUP_term_new (LSUP_TERM_UNDEFINED, NULL, NULL);
  180. ASSERT (undef1 != NULL, "Error creating undefined term without data!");
  181. char *data = "bogus";
  182. LSUP_Term *undef2 = LSUP_term_new (LSUP_TERM_UNDEFINED, data, NULL);
  183. ASSERT (undef2 != NULL, "Error creating undefined term with data!");
  184. EXPECT_STR_EQ (undef2->data, data);
  185. LSUP_term_free (undef1);
  186. LSUP_term_free (undef2);
  187. return 0;
  188. }
  189. static int test_term_copy()
  190. {
  191. LSUP_Term *uri1 = LSUP_iriref_new ("http://hello.org", NULL);
  192. LSUP_Term *lit1 = LSUP_literal_new ("hello", NULL);
  193. LSUP_Term *tlit1 = LSUP_literal_new (
  194. "hello", LSUP_iriref_new ("urn:mydatatype:string", NULL));
  195. LSUP_Term *llit1 = LSUP_lt_literal_new ("hello", "en-US");
  196. LSUP_Term *uri2 = LSUP_term_copy (uri1);
  197. LSUP_Term *lit2 = LSUP_term_copy (lit1);
  198. LSUP_Term *tlit2 = LSUP_term_copy (tlit1);
  199. LSUP_Term *llit2 = LSUP_term_copy (llit1);
  200. ASSERT (LSUP_term_equals (uri1, uri2), "Term mismatch!");
  201. ASSERT (LSUP_term_equals (lit1, lit2), "Term mismatch!");
  202. ASSERT (LSUP_term_equals (tlit1, tlit2), "Term mismatch!");
  203. ASSERT (LSUP_term_equals (llit1, llit2), "Term mismatch!");
  204. LSUP_term_free (uri1);
  205. LSUP_term_free (uri2);
  206. LSUP_term_free (lit1);
  207. LSUP_term_free (lit2);
  208. LSUP_term_free (tlit1);
  209. LSUP_term_free (tlit2);
  210. LSUP_term_free (llit1);
  211. LSUP_term_free (llit2);
  212. return 0;
  213. }
  214. static int test_term_serialize_deserialize()
  215. {
  216. LSUP_Term *uri = LSUP_iriref_new ("http://hello.org", NULL);
  217. LSUP_Term *lit = LSUP_literal_new ("hello", NULL);
  218. LSUP_Term *tlit = LSUP_literal_new (
  219. "hello", LSUP_iriref_new ("urn:mydatatype:string", NULL));
  220. LSUP_Term *llit = LSUP_lt_literal_new ("hello", "en-US");
  221. LSUP_Buffer *sterm;
  222. LSUP_Term *dsterm;
  223. sterm = LSUP_term_serialize (uri);
  224. ASSERT (sterm != NULL, "Error serializing term!");
  225. //log_info ("%s", "Serialized URI: ");
  226. //LSUP_buffer_print (sterm);
  227. //log_info ("%s", "\n");
  228. dsterm = LSUP_term_new_from_buffer (sterm);
  229. ASSERT (dsterm != NULL, "Error deserializing term!");
  230. ASSERT (LSUP_term_equals (dsterm, uri), "URI serialization error!");
  231. LSUP_term_free (uri);
  232. LSUP_buffer_free (sterm);
  233. LSUP_term_free (dsterm);
  234. sterm = LSUP_term_serialize (lit);
  235. ASSERT (sterm != NULL, "Error serializing term!");
  236. //log_info ("%s", "Serialized literal: ");
  237. //LSUP_buffer_print (sterm);
  238. //log_info ("%s", "\n");
  239. dsterm = LSUP_term_new_from_buffer (sterm);
  240. ASSERT (dsterm != NULL, "Error deserializing term!");
  241. ASSERT (LSUP_term_equals (dsterm, lit), "lit serialization error!");
  242. LSUP_term_free (lit);
  243. LSUP_buffer_free (sterm);
  244. LSUP_term_free (dsterm);
  245. sterm = LSUP_term_serialize (tlit);
  246. ASSERT (sterm != NULL, "Error serializing term!");
  247. //log_info ("%s", "Serialized typed literal: ");
  248. //LSUP_buffer_print (sterm);
  249. //log_info ("%s", "\n");
  250. dsterm = LSUP_term_new_from_buffer (sterm);
  251. ASSERT (dsterm != NULL, "Error deserializing term!");
  252. ASSERT (LSUP_term_equals (dsterm, tlit), "tlit serialization error!");
  253. LSUP_term_free (tlit);
  254. LSUP_buffer_free (sterm);
  255. LSUP_term_free (dsterm);
  256. sterm = LSUP_term_serialize (llit);
  257. ASSERT (sterm != NULL, "Error serializing term!");
  258. //log_info ("%s", "Serialized typed and language-tagged URI: ");
  259. //LSUP_buffer_print (sterm);
  260. //log_info ("%s", "\n");
  261. dsterm = LSUP_term_new_from_buffer (sterm);
  262. ASSERT (dsterm != NULL, "Error deserializing term!");
  263. ASSERT (LSUP_term_equals (dsterm, llit), "URI serialization error!");
  264. LSUP_term_free (llit);
  265. LSUP_buffer_free (sterm);
  266. LSUP_term_free (dsterm);
  267. return 0;
  268. }
  269. static int test_term_to_key()
  270. {
  271. LSUP_NSMap *nsm = LSUP_nsmap_new();
  272. LSUP_nsmap_add (nsm, "ns1", "http://hello.org/term#");
  273. LSUP_Term *uri1 = LSUP_iriref_new ("http://hello.org/term#bye", NULL);
  274. LSUP_Term *uri2 = LSUP_iriref_new ("ns1:bye", nsm);
  275. LSUP_Term *lit = LSUP_literal_new ("hello", NULL);
  276. LSUP_Term *tlit = LSUP_literal_new ("hello", LSUP_default_datatype);
  277. LSUP_Term *llit1 = LSUP_lt_literal_new ("hello", "en-US");
  278. LSUP_Term *llit2 = LSUP_lt_literal_new ("hello", "en-GB");
  279. LSUP_Term *llit3 = LSUP_lt_literal_new ("hello", NULL);
  280. LSUP_Key uri1_key = LSUP_term_hash (uri1);
  281. LSUP_Key uri2_key = LSUP_term_hash (uri2);
  282. LSUP_Key lit_key = LSUP_term_hash (lit);
  283. LSUP_Key tlit_key = LSUP_term_hash (tlit);
  284. LSUP_Key llit1_key = LSUP_term_hash (llit1);
  285. LSUP_Key llit2_key = LSUP_term_hash (llit2);
  286. LSUP_Key llit3_key = LSUP_term_hash (llit3);
  287. ASSERT (uri1_key == uri2_key, "URI keys differ!");
  288. ASSERT (uri1_key != lit_key, "URI key conflict!");
  289. ASSERT (lit_key == tlit_key, "URI keys differ!");
  290. ASSERT (lit_key != llit1_key, "URI key conflict!");
  291. ASSERT (tlit_key != llit1_key, "URI key conflict!");
  292. ASSERT (llit1_key != llit2_key, "URI key conflict!");
  293. ASSERT (tlit_key == llit3_key, "URI keys differ!");
  294. LSUP_term_free (uri1);
  295. LSUP_term_free (uri2);
  296. LSUP_term_free (lit);
  297. LSUP_term_free (tlit);
  298. LSUP_term_free (llit1);
  299. LSUP_term_free (llit2);
  300. LSUP_term_free (llit3);
  301. LSUP_nsmap_free (nsm);
  302. return 0;
  303. }
  304. int term_tests() {
  305. RUN (test_iriref);
  306. RUN (test_iriref_parts);
  307. RUN (test_iriref_abs_rel);
  308. RUN (test_literal);
  309. RUN (test_undefined);
  310. RUN (test_term_copy);
  311. RUN (test_term_serialize_deserialize);
  312. RUN (test_term_to_key);
  313. return 0;
  314. }