aboutsummaryrefslogtreecommitdiff
path: root/src/tests
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2020-05-26 11:45:44 +0200
committerAleksander Morgado <aleksander@aleksander.es>2020-05-26 15:05:52 +0200
commita399c7e42a8e780dc47edbac45d64db75e031fac (patch)
tree290b99db79770f8ec3a2701da6def49fa61b0924 /src/tests
parentc99457695334eb7a9f32ea0d085ee39e01a96a59 (diff)
charsets: take_and_convert() methods should support GSM encoding
The iconv() operation would fail because we wouldn't give any proper charset string to convert to/from. Use our custom GSM encoding support instead.
Diffstat (limited to 'src/tests')
-rw-r--r--src/tests/test-charsets.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/tests/test-charsets.c b/src/tests/test-charsets.c
index d223d706..0931d7e8 100644
--- a/src/tests/test-charsets.c
+++ b/src/tests/test-charsets.c
@@ -350,6 +350,19 @@ test_take_convert_ucs2_bad_ascii2 (void)
g_assert (converted == NULL);
}
+static void
+test_take_convert_gsm_utf8 (void)
+{
+ gchar *src, *converted, *utf8;
+
+ src = g_strdup ("T-Mobile");
+ converted = mm_charset_take_and_convert_to_utf8 (src, MM_MODEM_CHARSET_GSM);
+ g_assert_cmpstr (converted, ==, "T-Mobile");
+ utf8 = mm_utf8_take_and_convert_to_charset (converted, MM_MODEM_CHARSET_GSM);
+ g_assert_cmpstr (utf8, ==, "T-Mobile");
+ g_free (utf8);
+}
+
struct charset_can_convert_to_test_s {
const char *utf8;
gboolean to_gsm;
@@ -432,6 +445,7 @@ int main (int argc, char **argv)
g_test_add_func ("/MM/charsets/take-convert/ucs2/hex", test_take_convert_ucs2_hex_utf8);
g_test_add_func ("/MM/charsets/take-convert/ucs2/bad-ascii", test_take_convert_ucs2_bad_ascii);
g_test_add_func ("/MM/charsets/take-convert/ucs2/bad-ascii-2", test_take_convert_ucs2_bad_ascii2);
+ g_test_add_func ("/MM/charsets/take-convert/gsm", test_take_convert_gsm_utf8);
g_test_add_func ("/MM/charsets/can-convert-to", test_charset_can_covert_to);