OSDN Git Service

* Added h3 tag with CSS for au XHTML converter.
authorkonn <konn@1a406e8e-add9-4483-a2c8-d8cac5b7c224>
Sun, 13 Jul 2008 17:40:15 +0000 (17:40 +0000)
committerkonn <konn@1a406e8e-add9-4483-a2c8-d8cac5b7c224>
Sun, 13 Jul 2008 17:40:15 +0000 (17:40 +0000)
git-svn-id: svn+ssh://svn.sourceforge.jp/svnroot/modchxj/mod_chxj/branches/sandbox@2908 1a406e8e-add9-4483-a2c8-d8cac5b7c224

src/chxj_xhtml_mobile_1_0.c
test/chxj_xhtml_mobile_1_0/test_chxj_xhtml_mobile_1_0.c

index 4c7f97d..de00a85 100644 (file)
@@ -2100,39 +2100,53 @@ static char *
 s_xhtml_1_0_start_h3_tag(void *pdoc, Node *node)
 {
   xhtml_t *xhtml = GET_XHTML(pdoc);
-  Doc     *doc   = xhtml->doc;
+  Doc     *doc = xhtml->doc;
   Attr    *attr;
+  char    *attr_style = NULL;
+  char    *attr_align = NULL;
 
-  W_L("<h3");
   for (attr = qs_get_attr(doc,node);
        attr;
        attr = qs_get_next_attr(doc,attr)) {
-    char* name;
-    char* value;
-    name  = qs_get_attr_name(doc,attr);
-    value = qs_get_attr_value(doc,attr);
+    char *name  = qs_get_attr_name(doc,attr);
+    char *value = qs_get_attr_value(doc,attr);
     if (STRCASEEQ('a','A',"align", name)) {
-      if (value) {
-        if (STRCASEEQ('l','L',"left",value)) {
-          W_L(" style=\"");
-          W_L("text-align:left");
-          W_L("\"");
+      if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+        attr_align = value;
+      }
+    }
+    else if (STRCASEEQ('s','S',"style",name) && value && *value) {
+      attr_style = value;
+    }
+  }
+  if (IS_CSS_ON(xhtml->entryp)) {
+    css_prop_list_t *style = s_xhtml_1_0_push_and_get_now_style(pdoc, node, attr_style);
+    if (style) {
+      css_property_t *list_style_type_prop = chxj_css_get_property_value(doc, style, "text-align");
+      css_property_t *cur;
+      for (cur = list_style_type_prop->next; cur != list_style_type_prop; cur = cur->next) {
+        if (STRCASEEQ('l','L',"left", cur->value)) {
+          attr_align = apr_pstrdup(doc->pool, "left");
         }
-        else if (STRCASEEQ('r','R',"right",value)) {
-          W_L(" style=\"");
-          W_L("text-align:right");
-          W_L("\"");
+        else if (STRCASEEQ('c','C',"center",cur->value)) {
+          attr_align = apr_pstrdup(doc->pool, "center");
         }
-        else if (STRCASEEQ('c','C',"center",value)) {
-          W_L(" style=\"");
-          W_L("text-align:center");
-          W_L("\"");
+        else if (STRCASEEQ('r','R',"right",cur->value)) {
+          attr_align = apr_pstrdup(doc->pool, "right");
         }
-        break;
       }
     }
   }
+  W_L("<h3");
+  if (attr_align) {
+    W_L(" style=\"");
+    W_L("text-align:");
+    W_V(attr_align);
+    W_L(";");
+    W_L("\"");
+  }
   W_L(">");
+
   return xhtml->out;
 }
 
@@ -2152,6 +2166,10 @@ s_xhtml_1_0_end_h3_tag(void *pdoc, Node *UNUSED(child))
   Doc     *doc   = xhtml->doc;
 
   W_L("</h3>");
+  if (IS_CSS_ON(xhtml->entryp)) {
+    chxj_css_pop_prop_list(xhtml->css_prop_stack);
+  }
+
   return xhtml->out;
 }
 
index c18de1f..59d7353 100644 (file)
@@ -588,6 +588,20 @@ void test_xhtml_h1_tag_with_css_003();
 void test_xhtml_h1_tag_with_css_004();
 void test_xhtml_h1_tag_with_css_005();
 void test_xhtml_h1_tag_with_css_006();
+
+void test_xhtml_h2_tag_with_css_001();
+void test_xhtml_h2_tag_with_css_002();
+void test_xhtml_h2_tag_with_css_003();
+void test_xhtml_h2_tag_with_css_004();
+void test_xhtml_h2_tag_with_css_005();
+void test_xhtml_h2_tag_with_css_006();
+
+void test_xhtml_h3_tag_with_css_001();
+void test_xhtml_h3_tag_with_css_002();
+void test_xhtml_h3_tag_with_css_003();
+void test_xhtml_h3_tag_with_css_004();
+void test_xhtml_h3_tag_with_css_005();
+void test_xhtml_h3_tag_with_css_006();
 /* pend */
 
 int
@@ -1212,6 +1226,20 @@ main()
   CU_add_test(xhtml_suite, "test h1 with css 004",                               test_xhtml_h1_tag_with_css_004);
   CU_add_test(xhtml_suite, "test h1 with css 005",                               test_xhtml_h1_tag_with_css_005);
   CU_add_test(xhtml_suite, "test h1 with css 006",                               test_xhtml_h1_tag_with_css_006);
+
+  CU_add_test(xhtml_suite, "test h2 with css 001",                               test_xhtml_h2_tag_with_css_001);
+  CU_add_test(xhtml_suite, "test h2 with css 002",                               test_xhtml_h2_tag_with_css_002);
+  CU_add_test(xhtml_suite, "test h2 with css 003",                               test_xhtml_h2_tag_with_css_003);
+  CU_add_test(xhtml_suite, "test h2 with css 004",                               test_xhtml_h2_tag_with_css_004);
+  CU_add_test(xhtml_suite, "test h2 with css 005",                               test_xhtml_h2_tag_with_css_005);
+  CU_add_test(xhtml_suite, "test h2 with css 006",                               test_xhtml_h2_tag_with_css_006);
+
+  CU_add_test(xhtml_suite, "test h3 with css 001",                               test_xhtml_h3_tag_with_css_001);
+  CU_add_test(xhtml_suite, "test h3 with css 002",                               test_xhtml_h3_tag_with_css_002);
+  CU_add_test(xhtml_suite, "test h3 with css 003",                               test_xhtml_h3_tag_with_css_003);
+  CU_add_test(xhtml_suite, "test h3 with css 004",                               test_xhtml_h3_tag_with_css_004);
+  CU_add_test(xhtml_suite, "test h3 with css 005",                               test_xhtml_h3_tag_with_css_005);
+  CU_add_test(xhtml_suite, "test h3 with css 006",                               test_xhtml_h3_tag_with_css_006);
   /* aend */
 
   CU_basic_run_tests();
@@ -1562,7 +1590,7 @@ void test_xhtml_a_tag_href_attribute_002()
 void test_xhtml_a_tag_href_attribute_003() 
 {
 #define  TEST_STRING "<a href=\"a.html\">abc</a>"
-#define  RESULT_STRING "<a href=\"a.html\">abc</a>"
+#define  RESULT_STRING "<a href=\"a.html?_chxj_cc=test_cookie_id\">abc</a>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -1591,7 +1619,7 @@ void test_xhtml_a_tag_href_attribute_003()
 void test_xhtml_a_tag_href_attribute_004() 
 {
 #define  TEST_STRING "<a href=\"a.html#abc\">abc</a>"
-#define  RESULT_STRING "<a href=\"a.html#abc\">abc</a>"
+#define  RESULT_STRING "<a href=\"a.html#abc?_chxj_cc=test_cookie_id\">abc</a>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -1620,7 +1648,7 @@ void test_xhtml_a_tag_href_attribute_004()
 void test_xhtml_a_tag_href_attribute_005() 
 {
 #define  TEST_STRING "<a href=\"a.html#\">abc</a>"
-#define  RESULT_STRING "<a href=\"a.html#\">abc</a>"
+#define  RESULT_STRING "<a href=\"a.html#?_chxj_cc=test_cookie_id\">abc</a>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -3423,7 +3451,7 @@ void test_xhtml_form_tag_005()
 void test_xhtml_form_tag_006() 
 {
 #define  TEST_STRING "<form action></form>"
-#define  RESULT_STRING "<form action=\"\"></form>"
+#define  RESULT_STRING "<form action=\"?_chxj_cc=test_cookie_id\"></form>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -3510,7 +3538,7 @@ void test_xhtml_form_tag_008()
 void test_xhtml_form_tag_009() 
 {
 #define  TEST_STRING "<form method=\"post\" action=\"hogehoge\"></form>"
-#define  RESULT_STRING "<form method=\"post\" action=\"hogehoge\"></form>"
+#define  RESULT_STRING "<form method=\"post\" action=\"hogehoge?_chxj_cc=test_cookie_id\"></form>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -4357,7 +4385,7 @@ void test_xhtml_h3_tag_006()
 void test_xhtml_h3_tag_007() 
 {
 #define  TEST_STRING "<h3 align=\"left\"></h3>"
-#define  RESULT_STRING "<h3 style=\"text-align:left\"></h3>"
+#define  RESULT_STRING "<h3 style=\"text-align:left;\"></h3>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -4386,7 +4414,7 @@ void test_xhtml_h3_tag_007()
 void test_xhtml_h3_tag_008() 
 {
 #define  TEST_STRING "<h3 align=\"right\"></h3>"
-#define  RESULT_STRING "<h3 style=\"text-align:right\"></h3>"
+#define  RESULT_STRING "<h3 style=\"text-align:right;\"></h3>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -4415,7 +4443,7 @@ void test_xhtml_h3_tag_008()
 void test_xhtml_h3_tag_009() 
 {
 #define  TEST_STRING "<h3 align=\"center\"></h3>"
-#define  RESULT_STRING "<h3 style=\"text-align:center\"></h3>"
+#define  RESULT_STRING "<h3 style=\"text-align:center;\"></h3>"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -5991,7 +6019,7 @@ void test_xhtml_img_tag_001()
 void test_xhtml_img_tag_002() 
 {
 #define  TEST_STRING "<img src>"
-#define  RESULT_STRING "<img src=\"\" />"
+#define  RESULT_STRING "<img src=\"?_chxj_cc=test_cookie_id&_chxj_nc=true\" />"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -6020,7 +6048,7 @@ void test_xhtml_img_tag_002()
 void test_xhtml_img_tag_003() 
 {
 #define  TEST_STRING "<img src=\"\">"
-#define  RESULT_STRING "<img src=\"\" />"
+#define  RESULT_STRING "<img src=\"?_chxj_cc=test_cookie_id&_chxj_nc=true\" />"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -6049,7 +6077,7 @@ void test_xhtml_img_tag_003()
 void test_xhtml_img_tag_004() 
 {
 #define  TEST_STRING "<img src=\"aaa\">"
-#define  RESULT_STRING "<img src=\"aaa\" />"
+#define  RESULT_STRING "<img src=\"aaa?_chxj_cc=test_cookie_id&_chxj_nc=true\" />"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -6078,7 +6106,7 @@ void test_xhtml_img_tag_004()
 void test_xhtml_img_tag_005() 
 {
 #define  TEST_STRING "<img src=\"亀さん\">"
-#define  RESULT_STRING "<img src=\"亀さん\" />"
+#define  RESULT_STRING "<img src=\"亀さん?_chxj_cc=test_cookie_id&_chxj_nc=true\" />"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -6107,7 +6135,7 @@ void test_xhtml_img_tag_005()
 void test_xhtml_img_tag_006() 
 {
 #define  TEST_STRING "<img src=\"ハンカク\">"
-#define  RESULT_STRING "<img src=\"ハンカク\" />"
+#define  RESULT_STRING "<img src=\"ハンカク?_chxj_cc=test_cookie_id&_chxj_nc=true\" />"
   char  *ret;
   char  *tmp;
   device_table spec;
@@ -16835,6 +16863,258 @@ void test_xhtml_h2_tag_with_css_006()
 #undef TEST_STRING
 #undef RESULT_STRING
 }
+
+
+
+/*===========================================================================*/
+/* h3 tag with CSS                                                           */
+/*===========================================================================*/
+char *test_chxj_serf_get046(request_rec *r, apr_pool_t *ppool, const char *uri_path, int ss, apr_size_t *len)
+{
+  static char *css = "a:focus { display: none }\n"
+                     "a:link  { display: none }\n"
+                     "a       { display: none }\n"
+                     "hr      { display: none }\n"
+                     "a:visited { display:none }\n"
+                     "h3      { text-align: right }\n";
+  *len = strlen(css);
+  call_check = 1;
+  return css;
+}
+void test_xhtml_h3_tag_with_css_001()
+{
+#define  TEST_STRING "<html><head><link rel=\"stylesheet\" href=\"http://localhost/a.css\"  type=\"text/css\" />" \
+                     "</head><body><h3>あいう</h3></body></html>"
+#define  RESULT_STRING "<?xml version=\"1.0\" encoding=\"Windows-31J\"?><!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">" \
+                       "<html xmlns=\"http://www.w3.org/1999/xhtml\">" \
+                       "<head></head><body><h3 style=\"text-align:right;\">あいう</h3></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+  chxj_serf_get = test_chxj_serf_get046;
+  call_check = 0;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+  entry.action |= CONVRULE_CSS_ON_BIT;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_convert_xhtml_mobile_1_0(&r, &spec, tmp, destlen, &destlen, &entry, &cookie);
+  ret = chxj_rencoding(&r, ret, &destlen);
+  CU_ASSERT(ret != NULL);
+  CU_ASSERT(strcmp(RESULT_STRING, ret) == 0);
+  CU_ASSERT(destlen == sizeof(RESULT_STRING)-1);
+  CU_ASSERT(call_check == 1);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+char *test_chxj_serf_get047(request_rec *r, apr_pool_t *ppool, const char *uri_path, int ss, apr_size_t *len)
+{
+  static char *css = "a:focus { display: none }\n"
+                     "a:link  { display: none }\n"
+                     "a       { display: none }\n"
+                     "hr      { display: none }\n"
+                     "a:visited { display:none }\n"
+                     "h3      { text-align: center }\n";
+  *len = strlen(css);
+  call_check = 1;
+  return css;
+}
+void test_xhtml_h3_tag_with_css_002()
+{
+#define  TEST_STRING "<html><head><link rel=\"stylesheet\" href=\"http://localhost/a.css\"  type=\"text/css\" />" \
+                     "</head><body><h3>あいう</h3></body></html>"
+#define  RESULT_STRING "<?xml version=\"1.0\" encoding=\"Windows-31J\"?><!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">" \
+                       "<html xmlns=\"http://www.w3.org/1999/xhtml\">" \
+                       "<head></head><body><h3 style=\"text-align:center;\">あいう</h3></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+  chxj_serf_get = test_chxj_serf_get047;
+  call_check = 0;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+  entry.action |= CONVRULE_CSS_ON_BIT;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_convert_xhtml_mobile_1_0(&r, &spec, tmp, destlen, &destlen, &entry, &cookie);
+  ret = chxj_rencoding(&r, ret, &destlen);
+  CU_ASSERT(ret != NULL);
+  CU_ASSERT(strcmp(RESULT_STRING, ret) == 0);
+  CU_ASSERT(destlen == sizeof(RESULT_STRING)-1);
+  CU_ASSERT(call_check == 1);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+char *test_chxj_serf_get048(request_rec *r, apr_pool_t *ppool, const char *uri_path, int ss, apr_size_t *len)
+{
+  static char *css = "a:focus { display: none }\n"
+                     "a:link  { display: none }\n"
+                     "a       { display: none }\n"
+                     "hr      { display: none }\n"
+                     "a:visited { display:none }\n"
+                     "h3      { text-align: right }\n";
+  *len = strlen(css);
+  call_check = 1;
+  return css;
+}
+void test_xhtml_h3_tag_with_css_003()
+{
+#define  TEST_STRING "<html><head><link rel=\"stylesheet\" href=\"http://localhost/a.css\"  type=\"text/css\" />" \
+                     "</head><body><h3>あいう</h3></body></html>"
+#define  RESULT_STRING "<?xml version=\"1.0\" encoding=\"Windows-31J\"?><!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">" \
+                       "<html xmlns=\"http://www.w3.org/1999/xhtml\">" \
+                       "<head></head><body><h3 style=\"text-align:right;\">あいう</h3></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+  chxj_serf_get = test_chxj_serf_get048;
+  call_check = 0;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+  entry.action |= CONVRULE_CSS_ON_BIT;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_convert_xhtml_mobile_1_0(&r, &spec, tmp, destlen, &destlen, &entry, &cookie);
+  ret = chxj_rencoding(&r, ret, &destlen);
+  CU_ASSERT(ret != NULL);
+  CU_ASSERT(strcmp(RESULT_STRING, ret) == 0);
+  CU_ASSERT(destlen == sizeof(RESULT_STRING)-1);
+  CU_ASSERT(call_check == 1);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_xhtml_h3_tag_with_css_004()
+{
+#define  TEST_STRING "<html><head>" \
+                     "</head><body><h3 style=\"text-align: left\">あいう</h3></body></html>"
+#define  RESULT_STRING "<?xml version=\"1.0\" encoding=\"Windows-31J\"?><!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">" \
+                       "<html xmlns=\"http://www.w3.org/1999/xhtml\">" \
+                       "<head></head><body><h3 style=\"text-align:left;\">あいう</h3></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+  chxj_serf_get = test_chxj_serf_get048;
+  call_check = 0;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+  entry.action |= CONVRULE_CSS_ON_BIT;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_convert_xhtml_mobile_1_0(&r, &spec, tmp, destlen, &destlen, &entry, &cookie);
+  ret = chxj_rencoding(&r, ret, &destlen);
+  CU_ASSERT(ret != NULL);
+  CU_ASSERT(strcmp(RESULT_STRING, ret) == 0);
+  CU_ASSERT(destlen == sizeof(RESULT_STRING)-1);
+  CU_ASSERT(call_check == 0);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_xhtml_h3_tag_with_css_005()
+{
+#define  TEST_STRING "<html><head>" \
+                     "</head><body><h3 style=\"text-align: center\">あいう</h3></body></html>"
+#define  RESULT_STRING "<?xml version=\"1.0\" encoding=\"Windows-31J\"?><!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">" \
+                       "<html xmlns=\"http://www.w3.org/1999/xhtml\">" \
+                       "<head></head><body><h3 style=\"text-align:center;\">あいう</h3></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+  chxj_serf_get = test_chxj_serf_get048;
+  call_check = 0;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+  entry.action |= CONVRULE_CSS_ON_BIT;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_convert_xhtml_mobile_1_0(&r, &spec, tmp, destlen, &destlen, &entry, &cookie);
+  ret = chxj_rencoding(&r, ret, &destlen);
+  CU_ASSERT(ret != NULL);
+  CU_ASSERT(strcmp(RESULT_STRING, ret) == 0);
+  CU_ASSERT(destlen == sizeof(RESULT_STRING)-1);
+  CU_ASSERT(call_check == 0);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_xhtml_h3_tag_with_css_006()
+{
+#define  TEST_STRING "<html><head>" \
+                     "</head><body><h3 style=\"text-align: right\">あいう</h3></body></html>"
+#define  RESULT_STRING "<?xml version=\"1.0\" encoding=\"Windows-31J\"?><!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">" \
+                       "<html xmlns=\"http://www.w3.org/1999/xhtml\">" \
+                       "<head></head><body><h3 style=\"text-align:right;\">あいう</h3></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+  chxj_serf_get = test_chxj_serf_get048;
+  call_check = 0;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+  entry.action |= CONVRULE_CSS_ON_BIT;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_convert_xhtml_mobile_1_0(&r, &spec, tmp, destlen, &destlen, &entry, &cookie);
+  ret = chxj_rencoding(&r, ret, &destlen);
+  CU_ASSERT(ret != NULL);
+  CU_ASSERT(strcmp(RESULT_STRING, ret) == 0);
+  CU_ASSERT(destlen == sizeof(RESULT_STRING)-1);
+  CU_ASSERT(call_check == 0);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
 /*
  * vim:ts=2 et
  */