/* * 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_vfs_jffs.h" static UINT32 TestCase(VOID) { INT32 fd = -1; INT32 fd1 = -1; INT32 ret, len; INT32 i = 0; struct flock fl = { 0 }; CHAR filebuf[JFFS_STANDARD_NAME_LENGTH] = "0000000000111111111122222222223333333333"; CHAR readbuf[JFFS_STANDARD_NAME_LENGTH] = "liteos"; CHAR pathname1[JFFS_STANDARD_NAME_LENGTH] = { JFFS_PATH_NAME0 }; CHAR pathname2[JFFS_STANDARD_NAME_LENGTH] = { JFFS_PATH_NAME0 }; CHAR pathname3[JFFS_STANDARD_NAME_LENGTH] = { JFFS_PATH_NAME0 }; CHAR buffile[JFFS_STANDARD_NAME_LENGTH] = { JFFS_PATH_NAME0 }; struct stat buf1 = { 0 }; struct stat buf2 = { 0 }; ret = mkdir(pathname1, HIGHEST_AUTHORITY); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT); ret = chdir(pathname1); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT); strcat_s(pathname1, JFFS_STANDARD_NAME_LENGTH, "/jffs_1600.txt"); strcat_s(pathname2, JFFS_STANDARD_NAME_LENGTH, "/test.txt"); fd = open(pathname1, O_NONBLOCK | O_CREAT | O_RDWR | O_EXCL, HIGHEST_AUTHORITY); ICUNIT_GOTO_NOT_EQUAL(fd, -1, fd, EXIT3); len = write(fd, filebuf, strlen(filebuf)); ICUNIT_GOTO_EQUAL(len, strlen(filebuf), len, EXIT3); ret = close(fd); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT3); ret = stat(buffile, &buf1); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT1); JffsStatPrintf(buf1); for (i = 0; i < JFFS_PRESSURE_CYCLES; i++) { ret = rename(pathname1, pathname2); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT1); ret = rename(pathname2, pathname1); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT1); fd1 = open(pathname1, O_NONBLOCK | O_RDWR, HIGHEST_AUTHORITY); ICUNIT_GOTO_NOT_EQUAL(fd, -1, fd, EXIT2); ret = lseek(fd1, 0, SEEK_SET); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT2); len = read(fd1, readbuf, JFFS_STANDARD_NAME_LENGTH); ICUNIT_GOTO_EQUAL(len, strlen(filebuf), len, EXIT2); ICUNIT_GOTO_STRING_EQUAL(readbuf, "0000000000111111111122222222223333333333", readbuf, EXIT2); ret = close(fd1); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT2); ret = rename(pathname1, pathname2); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT1); ret = rename(pathname2, pathname1); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT1); } ret = stat(buffile, &buf2); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT1); JffsStatPrintf(buf2); ret = unlink(pathname1); ICUNIT_GOTO_EQUAL(ret, 0, ret, EXIT1); ret = chdir(JFFS_MAIN_DIR0); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT); ret = rmdir(pathname3); ICUNIT_GOTO_EQUAL(ret, JFFS_NO_ERROR, ret, EXIT); return JFFS_NO_ERROR; EXIT3: close(fd); goto EXIT1; EXIT2: close(fd1); EXIT1: remove(pathname1); remove(pathname2); EXIT: rmdir(pathname3); return JFFS_NO_ERROR; } VOID ItFsJffsPressure001(VOID) { TEST_ADD_CASE("ItFsJffsPressure001", TestCase, TEST_VFS, TEST_JFFS, TEST_LEVEL3, TEST_PRESSURE); }