summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2022-11-29 12:09:33 +0000
committerMatthias Clasen <mclasen@redhat.com>2022-11-29 12:09:33 +0000
commitd2158e825b62e3ae0f488b85c5f69a954ca92c60 (patch)
tree4304d5b90c4446d6e2b10ea3c171aa7301f7f75f
parent36a4bb0341865e9d861dd52054461513cff66c76 (diff)
parentbe324cc6659132ea50175ed8d341cb5f1175ce4d (diff)
downloadgtk+-d2158e825b62e3ae0f488b85c5f69a954ca92c60.tar.gz
Merge branch 'matthiasc/for-main' into 'main'
testsuite: Skip tests that miss charset support See merge request GNOME/gtk!5277
-rw-r--r--testsuite/css/data.c59
1 files changed, 26 insertions, 33 deletions
diff --git a/testsuite/css/data.c b/testsuite/css/data.c
index 60cc2661cc..8022bcd96f 100644
--- a/testsuite/css/data.c
+++ b/testsuite/css/data.c
@@ -30,43 +30,22 @@ struct _Test
const char *mimetype;
const char *contents;
gsize contents_len;
+ const char *charset;
};
#define CONTENTS(data) (data), sizeof(data) - 1
Test tests[] = {
- { "simple",
- "data:,HelloWorld",
- NULL, CONTENTS("HelloWorld") },
- { "nodata",
- "data:,",
- NULL, CONTENTS("") },
- { "case_sensitive",
- "dATa:,HelloWorld",
- NULL, CONTENTS("HelloWorld") },
- { "semicolon_after_comma",
- "data:,;base64",
- NULL, CONTENTS(";base64") },
- { "mimetype",
- "data:image/png,nopng",
- "image/png", CONTENTS("nopng") },
- { "charset",
- "data:text/plain;charset=ISO-8859-1,Timm B\344der",
- "text/plain", CONTENTS("Timm Bäder") },
- { "charset_escaped",
- "data:text/plain;charset=ISO-8859-1,Timm%20B%E4der",
- "text/plain", CONTENTS("Timm Bäder") },
- { "charset_base64",
- "data:text/plain;charset=ISO-8859-5;base64,wOPh29DdILjW0ePb0OLe0g==",
- "text/plain", CONTENTS("Руслан Ижбулатов") },
- { "wrong_scheme",
- "duda:,Hello",
- NULL, NULL, 0 },
- { "missing_comma",
- "data:text/plain;charset=ISO-8859-1:bla",
- NULL, NULL, 0 },
- { "bad_escape",
- "data:,abc%00",
- NULL, NULL, -1 },
+ { "simple", "data:,HelloWorld", NULL, CONTENTS("HelloWorld"), NULL },
+ { "nodata", "data:,", NULL, CONTENTS(""), NULL },
+ { "case_sensitive", "dATa:,HelloWorld", NULL, CONTENTS("HelloWorld"), NULL },
+ { "semicolon_after_comma", "data:,;base64", NULL, CONTENTS(";base64"), NULL },
+ { "mimetype", "data:image/png,nopng", "image/png", CONTENTS("nopng"), NULL },
+ { "charset", "data:text/plain;charset=ISO-8859-1,Timm B\344der", "text/plain", CONTENTS("Timm Bäder"), "ISO-8859-1" },
+ { "charset_escaped", "data:text/plain;charset=ISO-8859-1,Timm%20B%E4der", "text/plain", CONTENTS("Timm Bäder"), "ISO-8859-1" },
+ { "charset_base64", "data:text/plain;charset=ISO-8859-5;base64,wOPh29DdILjW0ePb0OLe0g==", "text/plain", CONTENTS("Руслан Ижбулатов"), "ISO-8859-5" },
+ { "wrong_scheme", "duda:,Hello", NULL, NULL, 0, NULL },
+ { "missing_comma", "data:text/plain;charset=ISO-8859-1:bla", NULL, NULL, 0, "ISO-8859-1" },
+ { "bad_escape", "data:,abc%00", NULL, NULL, -1, NULL },
};
static void
@@ -77,6 +56,20 @@ test_parse (gconstpointer data)
char *mimetype = NULL;
GBytes *bytes;
+ if (test->charset)
+ {
+ GIConv iconv;
+
+ iconv = g_iconv_open ("UTF-8", test->charset);
+ if (iconv == (GIConv) -1)
+ {
+ g_test_skip_printf ("Conversion from %s to UTF-8 not supported", test->charset);
+ return;
+ }
+
+ g_iconv_close (iconv);
+ }
+
bytes = gtk_css_data_url_parse (test->url, &mimetype, &error);
if (test->contents)