summaryrefslogtreecommitdiff
path: root/test/nullable.c
diff options
context:
space:
mode:
authorJohn-Mark Bell <jmb@netsurf-browser.org>2013-01-06 22:34:18 +0000
committerJohn-Mark Bell <jmb@netsurf-browser.org>2013-01-06 22:34:18 +0000
commitefe52d57b2e0d1cb15ce3ccea5dd7d5e0359dae4 (patch)
tree1c772e308c8f35530c52bd889ee897d71a500814 /test/nullable.c
parent097de4ee4cd1e7df6661c94b87a5389e0cf50b77 (diff)
downloadiconv-efe52d57b2e0d1cb15ce3ccea5dd7d5e0359dae4.tar.gz
iconv-efe52d57b2e0d1cb15ce3ccea5dd7d5e0359dae4.tar.bz2
Correct handling of trailing valid shift sequences. Previously would
erroneously report EINVAL, instead of silently accepting them. Requires UnicodeLib 0.60.
Diffstat (limited to 'test/nullable.c')
-rw-r--r--test/nullable.c101
1 files changed, 101 insertions, 0 deletions
diff --git a/test/nullable.c b/test/nullable.c
new file mode 100644
index 0000000..c9523f5
--- /dev/null
+++ b/test/nullable.c
@@ -0,0 +1,101 @@
+#include <errno.h>
+#include <stdio.h>
+#include <string.h>
+
+#include <iconv/iconv.h>
+#include <iconv-internal/iconv.h>
+
+#include "testutils.h"
+
+#ifdef __riscos__
+#define ALIASES_FILE "Files.Aliases"
+#else
+#define ALIASES_FILE "Files/Aliases"
+#endif
+
+typedef struct nullable_testcase {
+ const char *from_charset;
+ const char *source;
+ struct {
+ size_t retval;
+ int errval;
+ size_t remaining;
+ } expected;
+} nullable_testcase;
+
+static const nullable_testcase tests[] = {
+ { "iso-2022-jp", "1234\x1b$@123456\x1b(B", { 0, 0, 0 } },
+ { "iso-2022-jp", "1234\x1b$@123456\x1b(", { (size_t) -1, EINVAL, 2 } },
+ { NULL, NULL, { 0, 0, 0 } }
+};
+
+static void run_test(const nullable_testcase *test)
+{
+ iconv_t cd;
+ char out[128];
+ char *inp = (char *) test->source, *outp = out;
+ size_t inlen = strlen(inp), outlen = sizeof(out);
+ size_t read;
+
+ cd = iconv_open("utf-8", test->from_charset);
+ assert(cd != (iconv_t) -1);
+
+ read = iconv(cd, &inp, &inlen, &outp, &outlen);
+ assert(read == test->expected.retval);
+
+ if (test->expected.retval == (size_t) -1) {
+ assert(errno == test->expected.errval);
+ assert(inlen == test->expected.remaining);
+ }
+
+ iconv_close(cd);
+}
+
+static void run_tests(void)
+{
+ int index;
+
+ for (index = 0; tests[index].from_charset != NULL; index++) {
+ run_test(&tests[index]);
+ }
+}
+
+int main(int argc, char **argv)
+{
+ const char *ucpath;
+ int alen;
+ char aliases[4096];
+
+ UNUSED(argc);
+ UNUSED(argv);
+
+#ifdef __riscos__
+ ucpath = "Unicode:";
+#else
+ ucpath = getenv("UNICODE_DIR");
+#endif
+
+ assert(ucpath != NULL);
+
+ strncpy(aliases, ucpath, sizeof(aliases));
+ alen = strlen(aliases);
+#ifndef __riscos__
+ if (aliases[alen - 1] != '/') {
+ strncat(aliases, "/", sizeof(aliases) - alen - 1);
+ alen += 1;
+ }
+#endif
+ strncat(aliases, ALIASES_FILE, sizeof(aliases) - alen - 1);
+ aliases[sizeof(aliases) - 1] = '\0';
+
+ assert(iconv_initialise(aliases) == 1);
+
+ run_tests();
+
+ iconv_finalise();
+
+ printf("PASS\n");
+
+ return 0;
+}
+