diff options
author | Tony Solomonik <tony.solomonik@gmail.com> | 2024-01-23 22:52:44 +0200 |
---|---|---|
committer | Tony Solomonik <tony.solomonik@gmail.com> | 2024-01-31 18:18:51 +0200 |
commit | 41950c154dc667625fb3fa437b95f5abcc1cc6bb (patch) | |
tree | a0f5fa07dbb60d7d3e2c570329ca928d927812e2 | |
parent | d4af166dac257fa85b6e81802ba54ddbaf3dabb8 (diff) | |
download | liburing-41950c154dc667625fb3fa437b95f5abcc1cc6bb.tar.gz |
test/truncate: Add test for failure on truncate path
Signed-off-by: Tony Solomonik <tony.solomonik@gmail.com>
-rw-r--r-- | test/truncate.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/test/truncate.c b/test/truncate.c index ea557a19..0d88b49f 100644 --- a/test/truncate.c +++ b/test/truncate.c @@ -19,6 +19,44 @@ #define ONE_GIG_SIZE ((loff_t)1024 * 1024 * 1024) #define HALF_GIG_SIZE ((loff_t)512 * 1024 * 1024) +static int test_truncate(struct io_uring *ring, int fd) +{ + struct io_uring_cqe *cqe; + struct io_uring_sqe *sqe; + int ret = -1; + + sqe = io_uring_get_sqe(ring); + if (!sqe) { + fprintf(stderr, "get sqe failed\n"); + goto err; + } + + memset(sqe, 0, sizeof(*sqe)); + + io_uring_prep_rw(IORING_OP_FTRUNCATE, sqe, fd, "fail", 0, 4); + + ret = io_uring_submit(ring); + if (ret <= 0) { + fprintf(stderr, "sqe submit failed: %d\n", ret); + goto err; + } + + ret = io_uring_wait_cqe(ring, &cqe); + if (ret < 0) { + fprintf(stderr, "wait completion %d\n", ret); + goto err; + } + ret = cqe->res; + io_uring_cqe_seen(ring, cqe); + if (ret != -EINVAL) { + fprintf(stderr, "unexpected truncate res %d\n", ret); + goto err; + } + +err: + return ret; +} + static int test_ftruncate(struct io_uring *ring, int fd, loff_t len) { struct io_uring_cqe *cqe; @@ -126,6 +164,10 @@ int main(int argc, char *argv[]) } } + ret = test_truncate(&ring, fd); + if (ret < 0) + goto err; + out: close(fd); return T_EXIT_PASS; |