sys_test_025.cpp 5.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
/*
 * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
 * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification,
 * are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice, this list of
 * conditions and the following disclaimer.
 *
 * 2. 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.
 *
 * 3. Neither the name of the copyright holder nor the names of its contributors may be used
 * to endorse or promote products derived from this software without specific prior written
 * permission.
 *
 * 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 HOLDER 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 "It_test_sys.h"
#include <grp.h>

#define GROUPFILE "/etc/group"

37
STATIC INT32 TestCase0(void)
38 39 40 41 42 43
{
    struct group getNam1 = { nullptr };
    struct group *getNam2 = nullptr;
    struct group getData1 = { nullptr };
    struct group *getData2 = nullptr;
    struct group *groupRet = nullptr;
44 45
    CHAR buf[1000]; /* 1000, buffer for test */
    size_t len = sizeof(buf);
46

47
    INT32 ret = getgrgid_r(0, &getNam1, buf, len, &getNam2);
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
    ICUNIT_ASSERT_EQUAL(ret, 0, ret);

    ICUNIT_ASSERT_NOT_EQUAL(getNam2, nullptr, getNam2);
    ICUNIT_ASSERT_STRING_EQUAL(getNam2->gr_name, "root", getNam2->gr_name);
    ICUNIT_ASSERT_STRING_EQUAL(getNam2->gr_passwd, "x", getNam2->gr_passwd);
    ICUNIT_ASSERT_EQUAL(getNam2->gr_gid, 0, getNam2->gr_gid);

    groupRet = getgrgid(0);
    ICUNIT_ASSERT_NOT_EQUAL(groupRet, nullptr, groupRet);
    ICUNIT_ASSERT_STRING_EQUAL(groupRet->gr_name, "root", groupRet->gr_name);
    ICUNIT_ASSERT_STRING_EQUAL(groupRet->gr_passwd, "x", groupRet->gr_passwd);
    ICUNIT_ASSERT_EQUAL(groupRet->gr_gid, 0, groupRet->gr_gid);

    groupRet = getgrnam("root");
    ICUNIT_ASSERT_NOT_EQUAL(groupRet, nullptr, groupRet);
    ICUNIT_ASSERT_STRING_EQUAL(groupRet->gr_name, "root", groupRet->gr_name);
    ICUNIT_ASSERT_STRING_EQUAL(groupRet->gr_passwd, "x", groupRet->gr_passwd);
    ICUNIT_ASSERT_EQUAL(groupRet->gr_gid, 0, groupRet->gr_gid);

    ret = getgrnam_r("root", &getData1, buf, len, &getData2);
    ICUNIT_ASSERT_EQUAL(ret, 0, ret);
    ICUNIT_ASSERT_NOT_EQUAL(getData2, nullptr, getData2);
    ICUNIT_ASSERT_STRING_EQUAL(getData2->gr_name, "root", getData2->gr_name);
    ICUNIT_ASSERT_STRING_EQUAL(getData2->gr_passwd, "x", getData2->gr_passwd);
    ICUNIT_ASSERT_EQUAL(getData2->gr_gid, 0, getData2->gr_gid);
    return 0;
}

76
STATIC INT32 TestCase1(void)
77
{
78 79
    INT32 len = 1000;
    CHAR buf[1000];
80 81 82 83 84 85
    struct group getNam1 = { nullptr };
    struct group *getNam2 = nullptr;
    struct group getData1 = { nullptr };
    struct group *getData2 = nullptr;
    struct group *groupRet = nullptr;

86
    INT32 ret = getgrgid_r(-1, &getNam1, buf, len, &getNam2);
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
    ICUNIT_ASSERT_NOT_EQUAL(ret, 0, ret);
    ICUNIT_ASSERT_EQUAL(errno, EAFNOSUPPORT, errno);
    errno = 0;

    groupRet = getgrgid(-1);
    ICUNIT_ASSERT_EQUAL(groupRet, 0, groupRet);
    ICUNIT_ASSERT_EQUAL(errno, EAFNOSUPPORT, errno);
    errno = 0;

    groupRet = getgrnam("null");
    ICUNIT_ASSERT_EQUAL(groupRet, nullptr, groupRet);
    ICUNIT_ASSERT_EQUAL(errno, EAFNOSUPPORT, errno);
    errno = 0;

    ret = getgrnam_r("null", &getData1, buf, len, &getData2);
    ICUNIT_ASSERT_NOT_EQUAL(ret, 0, ret);
    ICUNIT_ASSERT_EQUAL(errno, EAFNOSUPPORT, errno);
    errno = 0;

    return 0;
}

109
STATIC INT32 TestCase(void)
110
{
111 112 113 114 115 116 117 118 119 120 121 122 123
    CHAR *pathList[] = {"/etc/group"};
    CHAR *streamList[] = {g_groupFileStream};
    INT32 streamLen[] = {strlen(g_groupFileStream)};

    INT32 ret = PrepareFileEnv(pathList, streamList, streamLen, 1);
    if (ret != 0) {
        printf("error: need some env file, but prepare is not ok");
        (VOID)RecoveryFileEnv(pathList, 1);
        return -1;
    }

    ret = TestCase0();
    ICUNIT_GOTO_EQUAL(ret, 0, ret, ERROUT);
124 125

    ret = TestCase1();
126
    ICUNIT_GOTO_EQUAL(ret, 0, re, ERROUT);
127

128
    (VOID)RecoveryFileEnv(pathList, 1);
129
    return 0;
130 131 132
ERROUT:
    (VOID)RecoveryFileEnv(pathList, 1);
    return -1;
133 134 135 136 137 138 139
}

VOID ItTestSys025(VOID)
{
    TEST_ADD_CASE("IT_TEST_SYS_025", TestCase, TEST_POSIX, TEST_MEM, TEST_LEVEL0, TEST_FUNCTION);
}