Blame gnulib-tests/test-striconv.c

Packit Service fdd496
/* Test of character set conversion.
Packit Service fdd496
   Copyright (C) 2007-2017 Free Software Foundation, Inc.
Packit Service fdd496
Packit Service fdd496
   This program is free software: you can redistribute it and/or modify
Packit Service fdd496
   it under the terms of the GNU General Public License as published by
Packit Service fdd496
   the Free Software Foundation; either version 3 of the License, or
Packit Service fdd496
   (at your option) any later version.
Packit Service fdd496
Packit Service fdd496
   This program is distributed in the hope that it will be useful,
Packit Service fdd496
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service fdd496
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service fdd496
   GNU General Public License for more details.
Packit Service fdd496
Packit Service fdd496
   You should have received a copy of the GNU General Public License
Packit Service fdd496
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit Service fdd496
Packit Service fdd496
/* Written by Bruno Haible <bruno@clisp.org>, 2007.  */
Packit Service fdd496
Packit Service fdd496
#include <config.h>
Packit Service fdd496
Packit Service fdd496
#include "striconv.h"
Packit Service fdd496
Packit Service fdd496
#if HAVE_ICONV
Packit Service fdd496
# include <iconv.h>
Packit Service fdd496
#endif
Packit Service fdd496
Packit Service fdd496
#include <errno.h>
Packit Service fdd496
#include <stdlib.h>
Packit Service fdd496
#include <string.h>
Packit Service fdd496
Packit Service fdd496
#include "macros.h"
Packit Service fdd496
Packit Service fdd496
int
Packit Service fdd496
main ()
Packit Service fdd496
{
Packit Service fdd496
#if HAVE_ICONV
Packit Service fdd496
  /* Assume that iconv() supports at least the encodings ASCII, ISO-8859-1,
Packit Service fdd496
     and UTF-8.  */
Packit Service fdd496
  iconv_t cd_88591_to_utf8 = iconv_open ("UTF-8", "ISO-8859-1");
Packit Service fdd496
  iconv_t cd_utf8_to_88591 = iconv_open ("ISO-8859-1", "UTF-8");
Packit Service fdd496
Packit Service fdd496
  ASSERT (cd_88591_to_utf8 != (iconv_t)(-1));
Packit Service fdd496
  ASSERT (cd_utf8_to_88591 != (iconv_t)(-1));
Packit Service fdd496
Packit Service fdd496
  /* ------------------------- Test mem_cd_iconv() ------------------------- */
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from ISO-8859-1 to UTF-8 with no errors.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
Packit Service fdd496
    static const char expected[] = "\303\204rger mit b\303\266sen B\303\274bchen ohne Augenma\303\237";
Packit Service fdd496
    char *result = NULL;
Packit Service fdd496
    size_t length = 0;
Packit Service fdd496
    int retval = mem_cd_iconv (input, strlen (input), cd_88591_to_utf8,
Packit Service fdd496
                               &result, &length);
Packit Service fdd496
    ASSERT (retval == 0);
Packit Service fdd496
    ASSERT (length == strlen (expected));
Packit Service fdd496
    ASSERT (result != NULL && memcmp (result, expected, strlen (expected)) == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with no errors.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\303\204rger mit b\303\266sen B\303\274bchen ohne Augenma\303\237";
Packit Service fdd496
    static const char expected[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
Packit Service fdd496
    char *result = NULL;
Packit Service fdd496
    size_t length = 0;
Packit Service fdd496
    int retval = mem_cd_iconv (input, strlen (input), cd_utf8_to_88591,
Packit Service fdd496
                               &result, &length);
Packit Service fdd496
    ASSERT (retval == 0);
Packit Service fdd496
    ASSERT (length == strlen (expected));
Packit Service fdd496
    ASSERT (result != NULL && memcmp (result, expected, strlen (expected)) == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with EILSEQ.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\342\202\254"; /* EURO SIGN */
Packit Service fdd496
    char *result = NULL;
Packit Service fdd496
    size_t length = 0;
Packit Service fdd496
    int retval = mem_cd_iconv (input, strlen (input), cd_utf8_to_88591,
Packit Service fdd496
                               &result, &length);
Packit Service fdd496
    ASSERT (retval == -1 && errno == EILSEQ);
Packit Service fdd496
    ASSERT (result == NULL);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with EINVAL.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\342";
Packit Service fdd496
    char *result = NULL;
Packit Service fdd496
    size_t length = 0;
Packit Service fdd496
    int retval = mem_cd_iconv (input, strlen (input), cd_utf8_to_88591,
Packit Service fdd496
                               &result, &length);
Packit Service fdd496
    ASSERT (retval == 0);
Packit Service fdd496
    ASSERT (length == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* ------------------------- Test str_cd_iconv() ------------------------- */
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from ISO-8859-1 to UTF-8 with no errors.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
Packit Service fdd496
    static const char expected[] = "\303\204rger mit b\303\266sen B\303\274bchen ohne Augenma\303\237";
Packit Service fdd496
    char *result = str_cd_iconv (input, cd_88591_to_utf8);
Packit Service fdd496
    ASSERT (result != NULL);
Packit Service fdd496
    ASSERT (strcmp (result, expected) == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with no errors.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\303\204rger mit b\303\266sen B\303\274bchen ohne Augenma\303\237";
Packit Service fdd496
    static const char expected[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
Packit Service fdd496
    char *result = str_cd_iconv (input, cd_utf8_to_88591);
Packit Service fdd496
    ASSERT (result != NULL);
Packit Service fdd496
    ASSERT (strcmp (result, expected) == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with EILSEQ.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "Costs: 27 \342\202\254"; /* EURO SIGN */
Packit Service fdd496
    char *result = str_cd_iconv (input, cd_utf8_to_88591);
Packit Service fdd496
    ASSERT (result == NULL && errno == EILSEQ);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with EINVAL.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\342";
Packit Service fdd496
    char *result = str_cd_iconv (input, cd_utf8_to_88591);
Packit Service fdd496
    ASSERT (result != NULL);
Packit Service fdd496
    ASSERT (strcmp (result, "") == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  iconv_close (cd_88591_to_utf8);
Packit Service fdd496
  iconv_close (cd_utf8_to_88591);
Packit Service fdd496
Packit Service fdd496
  /* -------------------------- Test str_iconv() -------------------------- */
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from ISO-8859-1 to UTF-8 with no errors.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
Packit Service fdd496
    static const char expected[] = "\303\204rger mit b\303\266sen B\303\274bchen ohne Augenma\303\237";
Packit Service fdd496
    char *result = str_iconv (input, "ISO-8859-1", "UTF-8");
Packit Service fdd496
    ASSERT (result != NULL);
Packit Service fdd496
    ASSERT (strcmp (result, expected) == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with no errors.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\303\204rger mit b\303\266sen B\303\274bchen ohne Augenma\303\237";
Packit Service fdd496
    static const char expected[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337";
Packit Service fdd496
    char *result = str_iconv (input, "UTF-8", "ISO-8859-1");
Packit Service fdd496
    ASSERT (result != NULL);
Packit Service fdd496
    ASSERT (strcmp (result, expected) == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with EILSEQ.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "Costs: 27 \342\202\254"; /* EURO SIGN */
Packit Service fdd496
    char *result = str_iconv (input, "UTF-8", "ISO-8859-1");
Packit Service fdd496
    ASSERT (result == NULL && errno == EILSEQ);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
  /* Test conversion from UTF-8 to ISO-8859-1 with EINVAL.  */
Packit Service fdd496
  {
Packit Service fdd496
    static const char input[] = "\342";
Packit Service fdd496
    char *result = str_iconv (input, "UTF-8", "ISO-8859-1");
Packit Service fdd496
    ASSERT (result != NULL);
Packit Service fdd496
    ASSERT (strcmp (result, "") == 0);
Packit Service fdd496
    free (result);
Packit Service fdd496
  }
Packit Service fdd496
Packit Service fdd496
#endif
Packit Service fdd496
Packit Service fdd496
  return 0;
Packit Service fdd496
}