diff options
author | Eric Anholt <eric@anholt.net> | 2008-04-23 11:32:31 -0700 |
---|---|---|
committer | Eric Anholt <eric@anholt.net> | 2008-04-23 11:36:03 -0700 |
commit | c1fec43b553ea93460b58995a1229e84d8bb45b4 (patch) | |
tree | 80eb2592e5bfb70ad00abcf15d04a2b0613b9023 /tests | |
parent | 8665b666c7e2ecdee7d27e1ad540910a0223ba6d (diff) |
Extend the mmfs basic test to do a couple of ioctls.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/mmfs_basic.c | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/tests/mmfs_basic.c b/tests/mmfs_basic.c index 907dc5855..b0ae8905f 100644 --- a/tests/mmfs_basic.c +++ b/tests/mmfs_basic.c @@ -27,9 +27,11 @@ #include <stdlib.h> #include <stdio.h> +#include <string.h> #include <assert.h> #include <fcntl.h> #include <inttypes.h> +#include <errno.h> #include <sys/stat.h> #include "mmfs.h" @@ -51,6 +53,65 @@ create_mmfs_device() errx(1, "mknod()"); } +static void +test_bad_unref(int fd) +{ + struct mmfs_unreference_args unref; + int ret; + + printf("Testing error return on bad unreference ioctl.\n"); + + unref.handle = 0x10101010; + ret = ioctl(fd, MMFS_IOCTL_UNREFERENCE, &unref); + + assert(ret == -1 && errno == EINVAL); +} + +static void +test_bad_ioctl(int fd) +{ + int ret; + + printf("Testing error return on bad ioctl.\n"); + + ret = ioctl(fd, _IO(MMFS_IOCTL_BASE, 0xf0), 0); + + assert(ret == -1 && errno == EINVAL); +} + +static void +test_alloc_unref(int fd) +{ + struct mmfs_alloc_args alloc; + struct mmfs_unreference_args unref; + int ret; + + printf("Testing allocating and unreferencing an object.\n"); + + memset(&alloc, 0, sizeof(alloc)); + alloc.size = 16 * 1024; + ret = ioctl(fd, MMFS_IOCTL_ALLOC, &alloc); + assert(ret == 0); + + unref.handle = alloc.handle; + ret = ioctl(fd, MMFS_IOCTL_UNREFERENCE, &unref); +} + +static void +test_alloc_close(int fd) +{ + struct mmfs_alloc_args alloc; + int ret; + + printf("Testing closing with an object allocated.\n"); + + memset(&alloc, 0, sizeof(alloc)); + alloc.size = 16 * 1024; + ret = ioctl(fd, MMFS_IOCTL_ALLOC, &alloc); + assert(ret == 0); + + close(fd); +} int main(int argc, char **argv) { @@ -62,6 +123,11 @@ int main(int argc, char **argv) if (fd == -1) errx(1, "open()"); + test_bad_ioctl(fd); + test_bad_unref(fd); + test_alloc_unref(fd); + test_alloc_close(fd); + close(fd); return 0; |