1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/vfs_iterate_mount/main.c
chrysn f0e80ee10c tests: Cover vfs_iterate_mount_dirs in a new test
... adding precision to the documentation where a corner case was
discovered during testing and is permitted.

The test is too large for one small board, just like the other existing
VFS test.
2022-02-16 19:15:02 +01:00

125 lines
3.1 KiB
C

/*
* Copyright (C) Christian Amsüss <chrysn@fsfe.org>
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* Mount and unmount a few file systems, demonstrating that
* vfs_iterate_mount_dirs performs as advertised.
*
* @author Christian Amsüss <chrysn@fsfe.org>
*/
#include <stdio.h>
#include <assert.h>
#include <string.h>
#include <vfs.h>
#include <fs/constfs.h>
static constfs_file_t constfs_files[1] = {
/* Not completely empty -- that'd be a hassle around empty arrays and
* their size */
{
.path = "some-file",
.size = 0,
.data = (void*)"",
},
};
static constfs_t constfs_desc = {
.nfiles = ARRAY_SIZE(constfs_files),
.files = constfs_files,
};
static vfs_mount_t mount1 = {
.fs = &constfs_file_system,
.mount_point = "/const1",
.private_data = &constfs_desc,
};
static vfs_mount_t mount2 = {
.fs = &constfs_file_system,
.mount_point = "/const2",
.private_data = &constfs_desc,
};
static vfs_mount_t mount3 = {
.fs = &constfs_file_system,
.mount_point = "/const3",
.private_data = &constfs_desc,
};
static vfs_mount_t mount4 = {
.fs = &constfs_file_system,
.mount_point = "/const4",
.private_data = &constfs_desc,
};
/* Crank the iterator, reporting "N%s" for the next entry, or "O\n" for the end
* of the iterator (avoiding the letter "E" which may be misread for an error
* in a casual look at the error output) */
static void iter_and_report(vfs_DIR *iter) {
bool result = vfs_iterate_mount_dirs(iter);
if (result) {
printf("N(%s)", iter->mp->mount_point);
} else {
printf("O\n");
/* Zero out so we're ready for next round immediately */
memset(iter, 0, sizeof(*iter));
}
}
int main(void) {
int res = 0;
vfs_DIR iter;
memset(&iter, 0, sizeof(iter));
res |= vfs_mount(&mount1);
res |= vfs_mount(&mount2);
res |= vfs_mount(&mount3);
res |= vfs_mount(&mount4);
assert(res == 0);
printf("Mounted 1234\n");
/* N1N2N3N4E */
iter_and_report(&iter);
iter_and_report(&iter);
iter_and_report(&iter);
iter_and_report(&iter);
iter_and_report(&iter);
/* N1N2, unmount 3, N4E */
iter_and_report(&iter);
iter_and_report(&iter);
res |= vfs_umount(&mount3);
iter_and_report(&iter);
iter_and_report(&iter);
/* N1, unmount 2, (3 is already unmounted), N4, mount 3 N3, unmount 1 and remount it at the end N1, O */
/* It is OK that 1 is reported twice, because its first occurrence is its
* old mounting, and later it reappears */
iter_and_report(&iter);
res |= vfs_umount(&mount2);
iter_and_report(&iter);
res |= vfs_mount(&mount3);
iter_and_report(&iter);
res |= vfs_umount(&mount1);
res |= vfs_mount(&mount1);
iter_and_report(&iter);
iter_and_report(&iter);
/* This ensures we're not leaking locks */
res |= vfs_umount(&mount1);
res |= vfs_umount(&mount3);
res |= vfs_umount(&mount4);
printf("All unmounted\n");
/* Only O */
iter_and_report(&iter);
}