1 /*
2 * Copyright (c) 2018 Intel Corporation.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #include <zephyr/ztest.h>
8 #include <stdio.h>
9 #include <limits.h>
10 #include <zephyr/sys/__assert.h>
11 #include <zephyr/fs/fs.h>
12 #include "test_common.h"
13
14 #ifndef PATH_MAX
15 #define PATH_MAX 4096
16 #endif
17
18 int test_rmdir(const char *dir_path);
19
test_mkdir(const char * dir_path,const char * file)20 int test_mkdir(const char *dir_path, const char *file)
21 {
22 int res;
23 struct fs_file_t filep;
24 char file_path[PATH_MAX] = { 0 };
25
26 fs_file_t_init(&filep);
27 res = sprintf(file_path, "%s/%s", dir_path, file);
28 __ASSERT_NO_MSG(res < sizeof(file_path));
29
30 if (check_file_dir_exists(dir_path)) {
31 TC_PRINT("[%s] exists, delete it\n", dir_path);
32 if (test_rmdir(dir_path)) {
33 TC_PRINT("Error deleting dir %s\n", dir_path);
34 return TC_FAIL;
35 }
36 } else {
37 TC_PRINT("Creating new dir %s\n", dir_path);
38 }
39
40 /* Verify fs_mkdir() */
41 res = fs_mkdir(dir_path);
42 if (res) {
43 TC_PRINT("Error creating dir[%d]\n", res);
44 return res;
45 }
46
47 res = fs_open(&filep, file_path, FS_O_CREATE | FS_O_RDWR);
48 if (res) {
49 TC_PRINT("Failed opening file [%d]\n", res);
50 return res;
51 }
52
53 TC_PRINT("Testing write to file %s\n", file_path);
54 res = test_file_write(&filep, "NOTHING");
55 if (res) {
56 fs_close(&filep);
57 return res;
58 }
59
60 res = fs_close(&filep);
61 if (res) {
62 TC_PRINT("Error closing file [%d]\n", res);
63 return res;
64 }
65
66 TC_PRINT("Created dir %s!\n", dir_path);
67
68 return res;
69 }
70
test_lsdir(const char * path)71 int test_lsdir(const char *path)
72 {
73 int res;
74 struct fs_dir_t dirp;
75 struct fs_dirent entry;
76
77 TC_PRINT("\nlsdir tests:\n");
78
79 fs_dir_t_init(&dirp);
80
81 /* Verify fs_opendir() */
82 res = fs_opendir(&dirp, path);
83 if (res) {
84 TC_PRINT("Error opening dir %s [%d]\n", path, res);
85 return res;
86 }
87
88 TC_PRINT("\nListing dir %s:\n", path);
89 for (;;) {
90 /* Verify fs_readdir() */
91 res = fs_readdir(&dirp, &entry);
92
93 /* entry.name[0] == 0 means end-of-dir */
94 if (res || entry.name[0] == 0) {
95 break;
96 }
97
98 if (entry.type == FS_DIR_ENTRY_DIR) {
99 TC_PRINT("[DIR ] %s\n", entry.name);
100 } else {
101 TC_PRINT("[FILE] %s (size = %zu)\n",
102 entry.name, entry.size);
103 }
104 }
105
106 /* Verify fs_closedir() */
107 fs_closedir(&dirp);
108
109 return res;
110 }
111
test_rmdir(const char * dir_path)112 int test_rmdir(const char *dir_path)
113 {
114 int res;
115 struct fs_dir_t dirp;
116 static struct fs_dirent entry;
117
118 fs_dir_t_init(&dirp);
119
120 if (!check_file_dir_exists(dir_path)) {
121 TC_PRINT("%s doesn't exist\n", dir_path);
122 return TC_FAIL;
123 }
124
125 res = fs_opendir(&dirp, dir_path);
126 if (res) {
127 TC_PRINT("Error opening dir[%d]\n", res);
128 return res;
129 }
130
131 TC_PRINT("\nRemoving files and sub directories in %s\n", dir_path);
132 for (;;) {
133 char file_path[PATH_MAX] = { 0 };
134
135 res = fs_readdir(&dirp, &entry);
136
137 /* entry.name[0] == 0 means end-of-dir */
138 if (res || entry.name[0] == 0) {
139 break;
140 }
141
142 /* Delete file or sub directory */
143 sprintf(file_path, "%s/%s", dir_path, entry.name);
144 __ASSERT_NO_MSG(res < sizeof(file_path));
145 TC_PRINT("Removing %s\n", file_path);
146
147 res = fs_unlink(file_path);
148 if (res) {
149 TC_PRINT("Error deleting file/dir [%d]\n", res);
150 fs_closedir(&dirp);
151 return res;
152 }
153 }
154
155 fs_closedir(&dirp);
156
157 /* Verify fs_unlink() */
158 res = fs_unlink(dir_path);
159 if (res) {
160 TC_PRINT("Error removing dir [%d]\n", res);
161 return res;
162 }
163
164 TC_PRINT("Removed dir %s!\n", dir_path);
165
166 return res;
167 }
168