Blame test/ctype_internal_test.c

Packit c4476c
/*
Packit c4476c
 * Copyright 2017-2018 The OpenSSL Project Authors. All Rights Reserved.
Packit c4476c
 *
Packit c4476c
 * Licensed under the OpenSSL license (the "License").  You may not use
Packit c4476c
 * this file except in compliance with the License.  You can obtain a copy
Packit c4476c
 * in the file LICENSE in the source distribution or at
Packit c4476c
 * https://www.openssl.org/source/license.html
Packit c4476c
 */
Packit c4476c
Packit c4476c
#include "testutil.h"
Packit c4476c
#include "crypto/ctype.h"
Packit c4476c
#include "internal/nelem.h"
Packit c4476c
#include <ctype.h>
Packit c4476c
#include <stdio.h>
Packit c4476c
Packit c4476c
/*
Packit c4476c
 * Even though the VMS C RTL claims to be C99 compatible, it's not entirely
Packit c4476c
 * so far (C RTL version 8.4). Same applies to OSF. For the sake of these
Packit c4476c
 * tests, we therefore define our own.
Packit c4476c
 */
Packit c4476c
#if (defined(__VMS) && __CRTL_VER <= 80400000) || defined(__osf__)
Packit c4476c
static int isblank(int c)
Packit c4476c
{
Packit c4476c
    return c == ' ' || c == '\t';
Packit c4476c
}
Packit c4476c
#endif
Packit c4476c
Packit c4476c
static int test_ctype_chars(int n)
Packit c4476c
{
Packit c4476c
    if (!TEST_int_eq(isascii((unsigned char)n) != 0, ossl_isascii(n) != 0))
Packit c4476c
        return 0;
Packit c4476c
Packit c4476c
    if (!ossl_isascii(n))
Packit c4476c
        return 1;
Packit c4476c
Packit c4476c
    return TEST_int_eq(isalpha(n) != 0, ossl_isalpha(n) != 0)
Packit c4476c
           && TEST_int_eq(isalnum(n) != 0, ossl_isalnum(n) != 0)
Packit c4476c
#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
Packit c4476c
           && TEST_int_eq(isblank(n) != 0, ossl_isblank(n) != 0)
Packit c4476c
#endif
Packit c4476c
           && TEST_int_eq(iscntrl(n) != 0, ossl_iscntrl(n) != 0)
Packit c4476c
           && TEST_int_eq(isdigit(n) != 0, ossl_isdigit(n) != 0)
Packit c4476c
           && TEST_int_eq(isgraph(n) != 0, ossl_isgraph(n) != 0)
Packit c4476c
           && TEST_int_eq(islower(n) != 0, ossl_islower(n) != 0)
Packit c4476c
           && TEST_int_eq(isprint(n) != 0, ossl_isprint(n) != 0)
Packit c4476c
           && TEST_int_eq(ispunct(n) != 0, ossl_ispunct(n) != 0)
Packit c4476c
           && TEST_int_eq(isspace(n) != 0, ossl_isspace(n) != 0)
Packit c4476c
           && TEST_int_eq(isupper(n) != 0, ossl_isupper(n) != 0)
Packit c4476c
           && TEST_int_eq(isxdigit(n) != 0, ossl_isxdigit(n) != 0);
Packit c4476c
}
Packit c4476c
Packit c4476c
static struct {
Packit c4476c
    int u;
Packit c4476c
    int l;
Packit c4476c
} case_change[] = {
Packit c4476c
    { 'A', 'a' },
Packit c4476c
    { 'X', 'x' },
Packit c4476c
    { 'Z', 'z' },
Packit c4476c
    { '0', '0' },
Packit c4476c
    { '%', '%' },
Packit c4476c
    { '~', '~' },
Packit c4476c
    {   0,   0 },
Packit c4476c
    { EOF, EOF }
Packit c4476c
};
Packit c4476c
Packit c4476c
static int test_ctype_toupper(int n)
Packit c4476c
{
Packit c4476c
    return TEST_int_eq(ossl_toupper(case_change[n].l), case_change[n].u)
Packit c4476c
           && TEST_int_eq(ossl_toupper(case_change[n].u), case_change[n].u);
Packit c4476c
}
Packit c4476c
Packit c4476c
static int test_ctype_tolower(int n)
Packit c4476c
{
Packit c4476c
    return TEST_int_eq(ossl_tolower(case_change[n].u), case_change[n].l)
Packit c4476c
           && TEST_int_eq(ossl_tolower(case_change[n].l), case_change[n].l);
Packit c4476c
}
Packit c4476c
Packit c4476c
static int test_ctype_eof(void)
Packit c4476c
{
Packit c4476c
    return test_ctype_chars(EOF);
Packit c4476c
}
Packit c4476c
Packit c4476c
int setup_tests(void)
Packit c4476c
{
Packit c4476c
    ADD_ALL_TESTS(test_ctype_chars, 256);
Packit c4476c
    ADD_ALL_TESTS(test_ctype_toupper, OSSL_NELEM(case_change));
Packit c4476c
    ADD_ALL_TESTS(test_ctype_tolower, OSSL_NELEM(case_change));
Packit c4476c
    ADD_TEST(test_ctype_eof);
Packit c4476c
    return 1;
Packit c4476c
}