/* * Copyright (C) 2016 The Android Open Source Project * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #include <gtest/gtest.h> #include <langinfo.h> TEST(langinfo, category_CTYPE) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); EXPECT_STREQ("UTF-8", nl_langinfo(CODESET)); } TEST(langinfo, category_TIME) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); #if defined(__BIONIC__) // bionic's C locale is ISO rather than en_US. EXPECT_STREQ("%F %T %z", nl_langinfo(D_T_FMT)); EXPECT_STREQ("%F", nl_langinfo(D_FMT)); #else EXPECT_STREQ("%a %d %b %Y %r %Z", nl_langinfo(D_T_FMT)); EXPECT_STREQ("%m/%d/%Y", nl_langinfo(D_FMT)); #endif EXPECT_STREQ("%T", nl_langinfo(T_FMT)); EXPECT_STREQ("%I:%M:%S %p", nl_langinfo(T_FMT_AMPM)); EXPECT_STREQ("AM", nl_langinfo(AM_STR)); EXPECT_STREQ("PM", nl_langinfo(PM_STR)); EXPECT_STREQ("Sunday", nl_langinfo(DAY_1)); EXPECT_STREQ("Monday", nl_langinfo(DAY_2)); EXPECT_STREQ("Tuesday", nl_langinfo(DAY_3)); EXPECT_STREQ("Wednesday", nl_langinfo(DAY_4)); EXPECT_STREQ("Thursday", nl_langinfo(DAY_5)); EXPECT_STREQ("Friday", nl_langinfo(DAY_6)); EXPECT_STREQ("Saturday", nl_langinfo(DAY_7)); EXPECT_STREQ("Sun", nl_langinfo(ABDAY_1)); EXPECT_STREQ("Mon", nl_langinfo(ABDAY_2)); EXPECT_STREQ("Tue", nl_langinfo(ABDAY_3)); EXPECT_STREQ("Wed", nl_langinfo(ABDAY_4)); EXPECT_STREQ("Thu", nl_langinfo(ABDAY_5)); EXPECT_STREQ("Fri", nl_langinfo(ABDAY_6)); EXPECT_STREQ("Sat", nl_langinfo(ABDAY_7)); EXPECT_STREQ("January", nl_langinfo(MON_1)); EXPECT_STREQ("February", nl_langinfo(MON_2)); EXPECT_STREQ("March", nl_langinfo(MON_3)); EXPECT_STREQ("April", nl_langinfo(MON_4)); EXPECT_STREQ("May", nl_langinfo(MON_5)); EXPECT_STREQ("June", nl_langinfo(MON_6)); EXPECT_STREQ("July", nl_langinfo(MON_7)); EXPECT_STREQ("August", nl_langinfo(MON_8)); EXPECT_STREQ("September", nl_langinfo(MON_9)); EXPECT_STREQ("October", nl_langinfo(MON_10)); EXPECT_STREQ("November", nl_langinfo(MON_11)); EXPECT_STREQ("December", nl_langinfo(MON_12)); EXPECT_STREQ("Jan", nl_langinfo(ABMON_1)); EXPECT_STREQ("Feb", nl_langinfo(ABMON_2)); EXPECT_STREQ("Mar", nl_langinfo(ABMON_3)); EXPECT_STREQ("Apr", nl_langinfo(ABMON_4)); EXPECT_STREQ("May", nl_langinfo(ABMON_5)); EXPECT_STREQ("Jun", nl_langinfo(ABMON_6)); EXPECT_STREQ("Jul", nl_langinfo(ABMON_7)); EXPECT_STREQ("Aug", nl_langinfo(ABMON_8)); EXPECT_STREQ("Sep", nl_langinfo(ABMON_9)); EXPECT_STREQ("Oct", nl_langinfo(ABMON_10)); EXPECT_STREQ("Nov", nl_langinfo(ABMON_11)); EXPECT_STREQ("Dec", nl_langinfo(ABMON_12)); EXPECT_STREQ("", nl_langinfo(ERA)); EXPECT_STREQ("", nl_langinfo(ERA_D_FMT)); EXPECT_STREQ("", nl_langinfo(ERA_D_T_FMT)); EXPECT_STREQ("", nl_langinfo(ERA_T_FMT)); EXPECT_STREQ("", nl_langinfo(ALT_DIGITS)); } TEST(langinfo, category_NUMERIC) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); EXPECT_STREQ(".", nl_langinfo(RADIXCHAR)); EXPECT_STREQ("", nl_langinfo(THOUSEP)); } TEST(langinfo, category_MESSAGES) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); EXPECT_STREQ("^[yY]", nl_langinfo(YESEXPR)); EXPECT_STREQ("^[nN]", nl_langinfo(NOEXPR)); } TEST(langinfo, category_MONETARY) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); // POSIX says that if the currency symbol is the empty string (as it is for // the C locale), an implementation can return the empty string and not // include the leading [+-.] that signifies where the currency symbol should // appear. For consistency with localeconv (which POSIX says to prefer for // RADIXCHAR, THOUSEP, and CRNCYSTR) we return the empty string. glibc // disagrees. #if defined(__BIONIC__) EXPECT_STREQ("", nl_langinfo(CRNCYSTR)); #else EXPECT_STREQ("-", nl_langinfo(CRNCYSTR)); #endif } TEST(langinfo, invalid) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); EXPECT_STREQ("", nl_langinfo(-1)); EXPECT_STREQ("", nl_langinfo(0)); EXPECT_STREQ("", nl_langinfo(666)); } TEST(langinfo, matches_localeconv) { ASSERT_STREQ("C.UTF-8", setlocale(LC_ALL, "C.UTF-8")); EXPECT_STREQ(localeconv()->decimal_point, nl_langinfo(RADIXCHAR)); EXPECT_STREQ(localeconv()->thousands_sep, nl_langinfo(THOUSEP)); #if defined(__BIONIC__) // (See comment in category_MONETARY test.) EXPECT_STREQ(localeconv()->currency_symbol, nl_langinfo(CRNCYSTR)); #endif }