test_codec_ttl.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. #include "test.h"
  2. #include "codec/codec_ttl.h"
  3. #define W3C_POS_TEST_CT 30
  4. #define W3C_NEG_TEST_CT 14
  5. #define W3C_TEST_BASE "http://www.w3.org/2001/sw/DataAccess/df1/tests/"
  6. static LSUP_Triple trp[8];
  7. /// Encode a graph as TTL.
  8. int
  9. test_encode_ttl_graph()
  10. {
  11. log_info ("Test encoding graph document.");
  12. LSUP_Graph *gr = LSUP_graph_new (NULL, NULL, NULL);
  13. if (!gr) return LSUP_MEM_ERR;
  14. size_t ins;
  15. LSUP_graph_add (gr, trp, &ins);
  16. char *out = calloc (1, 1);
  17. void *it = codec.encode_graph_init (gr);
  18. ASSERT (it != NULL, "Error creating codec iterator!");
  19. char *tmp = NULL;
  20. LSUP_rc rc;
  21. while ((rc = codec.encode_graph_iter (it, &tmp)) != LSUP_END) {
  22. log_info ("Serialized fragment: %s\n", tmp);
  23. ASSERT (rc >= 0, "Encoding step failed!");
  24. out = realloc (out, strlen(out) + strlen (tmp) + 1);
  25. out = strcat (out, tmp);
  26. }
  27. log_info ("Serialized graph: %s\n", out);
  28. codec.encode_graph_done (it);
  29. free (tmp);
  30. LSUP_graph_free (gr);
  31. /*
  32. for (int i = 0; i < 7; i++)
  33. ASSERT (strstr (out, end_nt_doc[i]) != NULL, end_nt_doc[i]);
  34. */
  35. free (out);
  36. return 0;
  37. }
  38. /// Positive test suite from W3C.
  39. int
  40. test_w3c_pos()
  41. {
  42. char test_fname[36], out_fname[36];
  43. LSUP_Graph *gr;
  44. size_t ct;
  45. char *err;
  46. char ch;
  47. for (int i = 0; i <= W3C_POS_TEST_CT; i++) {
  48. #if 1
  49. // Tests 14÷16 with 10K triples is quite long. Skip them temporarily.
  50. // TODO use a switch based on env var.
  51. if (i > 12 && i <17) continue;
  52. #endif
  53. size_t nt_ct = 0;
  54. sprintf (test_fname, "test/assets/ttl/test-%02d.ttl", i);
  55. sprintf (out_fname, "test/assets/ttl/test-%02d.out", i);
  56. FILE *test_stream = fopen (test_fname, "r");
  57. FILE *out_stream = fopen (out_fname, "r");
  58. log_info ("Testing %s", test_fname);
  59. while ((ch=fgetc (out_stream)) != EOF) {
  60. if (ch == '\n') nt_ct++;
  61. }
  62. EXPECT_PASS (codec.decode_graph (test_stream, &gr, &ct, &err));
  63. EXPECT_INT_EQ (LSUP_graph_size (gr), nt_ct); // Just count NT lines.
  64. LSUP_graph_free (gr);
  65. fclose (test_stream);
  66. fclose (out_stream);
  67. free (err);
  68. }
  69. return 0;
  70. }
  71. /// Negative test suite from W3C.
  72. int
  73. test_w3c_neg()
  74. {
  75. char test_fname[36];
  76. LSUP_Graph *gr;
  77. size_t ct;
  78. char *err;
  79. for (int i = 0; i <= W3C_NEG_TEST_CT; i++) {
  80. sprintf (test_fname, "test/assets/ttl/bad-%02d.ttl", i);
  81. FILE *test_stream = fopen (test_fname, "r");
  82. log_info ("Testing %s", test_fname);
  83. LSUP_rc rc = codec.decode_graph (test_stream, &gr, &ct, &err);
  84. log_info ("rc: %d", rc);
  85. ASSERT (rc == LSUP_PARSE_ERR, "Bad test did not raise a parse error!");
  86. fclose (test_stream);
  87. free (err);
  88. }
  89. return 0;
  90. }
  91. int codec_ttl_tests()
  92. {
  93. LSUP_Term **terms = init_terms();
  94. init_triples (terms);
  95. codec = ttl_codec;
  96. RUN (test_encode_ttl_graph);
  97. RUN (test_decode_nt_graph);
  98. RUN (test_decode_nt_bad_graph);
  99. RUN (test_w3c_pos);
  100. RUN (test_w3c_neg);
  101. free_terms(terms);
  102. return 0;
  103. }