summaryrefslogtreecommitdiffstats
path: root/testsuites
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2012-03-02 10:18:10 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2012-03-13 12:23:44 +0100
commit3ba4f828e45141e9428a2c06d3d7c4bec3d5b404 (patch)
treef790e1259ffa11da3f993e58d2ceeb152b4133f3 /testsuites
parentFilesystem: Reference counting for locations (diff)
downloadrtems-3ba4f828e45141e9428a2c06d3d7c4bec3d5b404.tar.bz2
Filesystem: Read-only file system checks
o Make sure EROFS is indicated for write operations on a read-only file system. o Add error indication for read-only file systems in fchmod() and fchown() according to POSIX.
Diffstat (limited to 'testsuites')
-rw-r--r--testsuites/fstests/fsrofs01/Makefile.am20
-rw-r--r--testsuites/fstests/fsrofs01/fsrofs01.doc11
-rw-r--r--testsuites/fstests/fsrofs01/fsrofs01.scn2
-rw-r--r--testsuites/fstests/fsrofs01/init.c188
-rw-r--r--testsuites/psxtests/psxfchx01/init.c5
-rw-r--r--testsuites/psxtests/psxmount/test.c33
6 files changed, 251 insertions, 8 deletions
diff --git a/testsuites/fstests/fsrofs01/Makefile.am b/testsuites/fstests/fsrofs01/Makefile.am
new file mode 100644
index 0000000000..729a6290aa
--- /dev/null
+++ b/testsuites/fstests/fsrofs01/Makefile.am
@@ -0,0 +1,20 @@
+rtems_tests_PROGRAMS = fsrofs01
+fsrofs01_SOURCES = init.c
+
+dist_rtems_tests_DATA = fsrofs01.scn fsrofs01.doc
+
+include $(RTEMS_ROOT)/make/custom/@RTEMS_BSP@.cfg
+include $(top_srcdir)/../automake/compile.am
+include $(top_srcdir)/../automake/leaf.am
+
+
+AM_CPPFLAGS += -I$(top_srcdir)/../support/include
+
+LINK_OBJS = $(fsrofs01_OBJECTS)
+LINK_LIBS = $(fsrofs01_LDLIBS)
+
+fsrofs01$(EXEEXT): $(fsrofs01_OBJECTS) $(fsrofs01_DEPENDENCIES)
+ @rm -f fsrofs01$(EXEEXT)
+ $(make-exe)
+
+include $(top_srcdir)/../automake/local.am
diff --git a/testsuites/fstests/fsrofs01/fsrofs01.doc b/testsuites/fstests/fsrofs01/fsrofs01.doc
new file mode 100644
index 0000000000..9a600aeb33
--- /dev/null
+++ b/testsuites/fstests/fsrofs01/fsrofs01.doc
@@ -0,0 +1,11 @@
+This file describes the directives and concepts tested by this test set.
+
+test set name: fsrofs01
+
+directives:
+
+ TBD
+
+concepts:
+
+ Make sure EROFS is indicated for write operations on a read-only file system.
diff --git a/testsuites/fstests/fsrofs01/fsrofs01.scn b/testsuites/fstests/fsrofs01/fsrofs01.scn
new file mode 100644
index 0000000000..e19d9e51d8
--- /dev/null
+++ b/testsuites/fstests/fsrofs01/fsrofs01.scn
@@ -0,0 +1,2 @@
+*** TEST FSROFS 1 ***
+*** END OF TEST FSROFS 1 ***
diff --git a/testsuites/fstests/fsrofs01/init.c b/testsuites/fstests/fsrofs01/init.c
new file mode 100644
index 0000000000..9bea11503d
--- /dev/null
+++ b/testsuites/fstests/fsrofs01/init.c
@@ -0,0 +1,188 @@
+/*
+ * Copyright (c) 2012 embedded brains GmbH. All rights reserved.
+ *
+ * embedded brains GmbH
+ * Obere Lagerstr. 30
+ * 82178 Puchheim
+ * Germany
+ * <rtems@embedded-brains.de>
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.com/license/LICENSE.
+ */
+
+#ifdef HAVE_CONFIG_H
+ #include "config.h"
+#endif
+
+#include "tmacros.h"
+
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <unistd.h>
+#include <stdio.h>
+
+#include <rtems/libio.h>
+#include <rtems/rtems-rfs-format.h>
+#include <rtems/ramdisk.h>
+
+static const rtems_rfs_format_config rfs_config;
+
+static const char rda [] = "/dev/rda";
+
+static const char mnt [] = "/mnt";
+
+static const char file [] = "/mnt/file";
+
+static const char not_exist [] = "/mnt/not_exist";
+
+static void test_mount(bool writeable)
+{
+ int rv;
+ const void *data = NULL;
+
+ rv = mount(
+ rda,
+ mnt,
+ RTEMS_FILESYSTEM_TYPE_RFS,
+ writeable ? RTEMS_FILESYSTEM_READ_WRITE : 0,
+ data
+ );
+ rtems_test_assert(rv == 0);
+}
+
+static void test_create_file_system(void)
+{
+ int rv;
+
+ rv = mkdir(mnt, S_IRWXU | S_IRWXG | S_IRWXO);
+ rtems_test_assert(rv == 0);
+
+ rv = rtems_rfs_format(rda, &rfs_config);
+ rtems_test_assert(rv == 0);
+
+ test_mount(true);
+
+ rv = mknod(file, S_IFREG | S_IRWXU | S_IRWXG | S_IRWXO, 0);
+ rtems_test_assert(rv == 0);
+
+ rv = unmount(mnt);
+ rtems_test_assert(rv == 0);
+}
+
+static void test_rofs(void)
+{
+ int rv;
+ int fd;
+ char buf [1];
+ ssize_t n;
+
+ test_mount(false);
+
+ fd = open(file, O_RDONLY | O_CREAT, S_IRWXU | S_IRWXG | S_IRWXO);
+ rtems_test_assert(fd >= 0);
+
+ n = read(fd, buf, sizeof(buf));
+ rtems_test_assert(n == 0);
+
+ errno = 0;
+ n = write(fd, buf, sizeof(buf));
+ rtems_test_assert(n == -1);
+ rtems_test_assert(errno == EBADF);
+
+ errno = 0;
+ rv = ftruncate(fd, 0);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EINVAL);
+
+ errno = 0;
+ rv = fchmod(fd, 0);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = fchown(fd, 0, 0);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ rv = close(fd);
+ rtems_test_assert(rv == 0);
+
+ errno = 0;
+ fd = open(not_exist, O_RDONLY | O_CREAT, S_IRWXU | S_IRWXG | S_IRWXO);
+ rtems_test_assert(fd == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = mknod(not_exist, S_IFREG | S_IRWXU | S_IRWXG | S_IRWXO, 0);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = mkdir(not_exist, S_IRWXU | S_IRWXG | S_IRWXO);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = rename(file, not_exist);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = link(file, not_exist);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = unlink(file);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ errno = 0;
+ rv = symlink(file, not_exist);
+ rtems_test_assert(rv == -1);
+ rtems_test_assert(errno == EROFS);
+
+ rv = unmount(mnt);
+ rtems_test_assert(rv == 0);
+}
+
+static void Init(rtems_task_argument arg)
+{
+ printf("\n\n*** TEST FSROFS 1 ***\n");
+
+ test_create_file_system();
+ test_rofs();
+
+ printf("*** END OF TEST FSROFS 1 ***\n");
+
+ rtems_test_exit(0);
+}
+
+rtems_ramdisk_config rtems_ramdisk_configuration [] = {
+ { .block_size = 512, .block_num = 1024 }
+};
+
+size_t rtems_ramdisk_configuration_size = 1;
+
+#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+#define CONFIGURE_APPLICATION_EXTRA_DRIVERS RAMDISK_DRIVER_TABLE_ENTRY
+#define CONFIGURE_APPLICATION_NEEDS_LIBBLOCK
+
+#define CONFIGURE_LIBIO_MAXIMUM_FILE_DESCRIPTORS 5
+
+#define CONFIGURE_USE_IMFS_AS_BASE_FILESYSTEM
+#define CONFIGURE_FILESYSTEM_RFS
+
+#define CONFIGURE_MAXIMUM_TASKS 2
+
+#define CONFIGURE_EXTRA_TASK_STACKS (8 * 1024)
+
+#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
+
+#define CONFIGURE_INIT
+
+#include <rtems/confdefs.h>
diff --git a/testsuites/psxtests/psxfchx01/init.c b/testsuites/psxtests/psxfchx01/init.c
index 7ef030e5dc..56ff3c500b 100644
--- a/testsuites/psxtests/psxfchx01/init.c
+++ b/testsuites/psxtests/psxfchx01/init.c
@@ -184,10 +184,9 @@ rtems_task Init(
fd = open( "/newfile", O_RDONLY | O_CREAT, S_IRWXU );
rtems_test_assert( fd != -1 );
- puts( "Init - fchown, with the opened file descriptor - expect EINVAL" );
+ puts( "Init - fchown, with the opened file descriptor - OK" );
status = fchown( fd, 0, 0 );
- rtems_test_assert( status == -1 );
- rtems_test_assert( errno == EINVAL );
+ rtems_test_assert( status == 0 );
puts( "Init - close and remove /newfile" );
status = close( fd );
diff --git a/testsuites/psxtests/psxmount/test.c b/testsuites/psxtests/psxmount/test.c
index 1e80376685..6a113c725b 100644
--- a/testsuites/psxtests/psxmount/test.c
+++ b/testsuites/psxtests/psxmount/test.c
@@ -242,18 +242,41 @@ int main(
* Create a directory that passes through the read only file system.
*/
- printf("create c/y/my_mount_point/../../y/my_mount_point/new_dir\n");
- status = mkdir("c/y/my_mount_point/../../y/my_mount_point/new_dir",S_IRWXU );
+ printf("create c/y/my_mount_point/../../y/new_dir\n");
+ status = mkdir("c/y/my_mount_point/../../y/new_dir",S_IRWXU );
rtems_test_assert( status == 0 );
- status = stat("c/y/my_mount_point/../../y/my_mount_point/new_dir",&statbuf );
+ status = stat("c/y/my_mount_point/../../y/new_dir",&statbuf );
rtems_test_assert( status == 0 );
- status = stat("c/y/my_mount_point/new_dir/..", &statbuf );
+ status = stat("c/y/new_dir", &statbuf );
rtems_test_assert( status == 0 );
/*
* Attempt to mount a second file system at a used mount point.
*/
+ printf("Verify a mount point returns EROFS for another mount\n");
+ status = mount(
+ "null",
+ "/c/y/my_mount_point",
+ "imfs",
+ RTEMS_FILESYSTEM_READ_ONLY,
+ NULL );
+ rtems_test_assert( status == -1 );
+ rtems_test_assert( errno == EROFS);
+
+ printf("Unmount /c/y/my_mount_point\n");
+ status = unmount( "/c/y/my_mount_point" );
+ rtems_test_assert( status == 0 );
+
+ printf("Mount a read-write file system at /c/y/my_mount_point\n");
+ status = mount(
+ "null",
+ "/c/y/my_mount_point",
+ "imfs",
+ RTEMS_FILESYSTEM_READ_WRITE,
+ NULL );
+ rtems_test_assert( status == 0 );
+
printf("Verify a mount point returns EBUSY for another mount\n");
status = mount(
"null",
@@ -330,7 +353,7 @@ int main(
"null",
"/c/y/my_mount_point",
"imfs",
- RTEMS_FILESYSTEM_READ_ONLY,
+ RTEMS_FILESYSTEM_READ_WRITE,
NULL );
rtems_test_assert( status == 0 );