OSDN Git Service

* Added test code for <BASE> tag to CHTML2.0 converter.
authorkonn <konn@1a406e8e-add9-4483-a2c8-d8cac5b7c224>
Wed, 9 Apr 2008 09:08:46 +0000 (09:08 +0000)
committerkonn <konn@1a406e8e-add9-4483-a2c8-d8cac5b7c224>
Wed, 9 Apr 2008 09:08:46 +0000 (09:08 +0000)
git-svn-id: svn+ssh://svn.sourceforge.jp/svnroot/modchxj/mod_chxj/branches/RELEASE_0_11_0@2054 1a406e8e-add9-4483-a2c8-d8cac5b7c224

src/chxj_chtml20.c
test/chxj_chtml20/test_chxj_chtml20.c

index 51c7a97..a66d253 100644 (file)
@@ -840,7 +840,7 @@ s_chtml20_start_base_tag(void *pdoc, Node *node)
       W20_L("\"");
     }
   }
-  W20_L(" >\r\n");
+  W20_L(">");
   return chtml20->out;
 }
 
index fbeeb74..7632db5 100644 (file)
@@ -51,6 +51,12 @@ void test_chtml20_a_tag_href_attribute_006();
 void test_chtml20_a_tag_accesskey_attribute_001();
 void test_chtml20_a_tag_accesskey_attribute_002();
 void test_chtml20_a_tag_accesskey_attribute_003();
+
+void test_chtml20_base_tag_001();
+void test_chtml20_base_tag_href_attribute_001();
+void test_chtml20_base_tag_href_attribute_002();
+void test_chtml20_base_tag_href_attribute_003();
+void test_chtml20_base_tag_href_attribute_004();
 /* pend */
 
 int
@@ -76,6 +82,12 @@ main()
   CU_add_test(chtml20_suite, "test a tag accesskey attribute.",                   test_chtml20_a_tag_accesskey_attribute_001);
   CU_add_test(chtml20_suite, "test a tag accesskey attribute with void char.",    test_chtml20_a_tag_accesskey_attribute_002);
   CU_add_test(chtml20_suite, "test a tag accesskey attribute with no value",      test_chtml20_a_tag_accesskey_attribute_003);
+
+  CU_add_test(chtml20_suite, "test base tag no attribute.",                       test_chtml20_base_tag_001);
+  CU_add_test(chtml20_suite, "test base tag href attribute with no value.",       test_chtml20_base_tag_href_attribute_001);
+  CU_add_test(chtml20_suite, "test base tag href attribute with void value.",     test_chtml20_base_tag_href_attribute_002);
+  CU_add_test(chtml20_suite, "test base tag href attribute with normal value.",   test_chtml20_base_tag_href_attribute_003);
+  CU_add_test(chtml20_suite, "test base tag href attribute with normal value.",   test_chtml20_base_tag_href_attribute_004);
   /* aend */
 
   CU_basic_run_tests();
@@ -598,6 +610,149 @@ void test_chtml20_a_tag_accesskey_attribute_003()
 #undef TEST_STRING
 #undef RESULT_STRING
 }
+/*============================================================================*/
+/* <BASE>                                                                     */
+/*============================================================================*/
+void test_chtml20_base_tag_001() 
+{
+#define  TEST_STRING "<html><head><base></head><body></body></html>"
+#define  RESULT_STRING "<html><head><base></head><body></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_exchange_chtml20(&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);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_chtml20_base_tag_href_attribute_001() 
+{
+#define  TEST_STRING "<html><head><base href></head><body></body></html>"
+#define  RESULT_STRING "<html><head><base href=\"\"></head><body></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_exchange_chtml20(&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);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_chtml20_base_tag_href_attribute_002() 
+{
+#define  TEST_STRING "<html><head><base href=\"\"></head><body></body></html>"
+#define  RESULT_STRING "<html><head><base href=\"\"></head><body></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_exchange_chtml20(&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);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_chtml20_base_tag_href_attribute_003() 
+{
+#define  TEST_STRING "<html><head><base href=\"http://www.google.co.jp/\"></head><body></body></html>"
+#define  RESULT_STRING "<html><head><base href=\"http://www.google.co.jp/\"></head><body></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_exchange_chtml20(&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);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
+void test_chtml20_base_tag_href_attribute_004() 
+{
+#define  TEST_STRING "<html><head><base href=\".\"></head><body></body></html>"
+#define  RESULT_STRING "<html><head><base href=\".\"></head><body></body></html>"
+  char  *ret;
+  char  *tmp;
+  device_table spec;
+  chxjconvrule_entry entry;
+  cookie_t cookie;
+  apr_size_t destlen;
+  APR_INIT;
+
+  COOKIE_INIT(cookie);
+
+  SPEC_INIT(spec);
+  destlen = sizeof(TEST_STRING)-1;
+
+  tmp = chxj_encoding(&r, TEST_STRING, &destlen);
+  ret = chxj_exchange_chtml20(&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);
+
+  APR_TERM;
+#undef TEST_STRING
+#undef RESULT_STRING
+}
 /*
  * vim:ts=2 et
  */