diff tests/test-vfs-zip.c @ 335:68287c7bcdb5

core: implement vfs-zip (read-only)
author David Demelier <markand@malikania.fr>
date Wed, 13 Oct 2021 15:58:02 +0200
parents
children 460c78706989
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/test-vfs-zip.c	Wed Oct 13 15:58:02 2021 +0200
@@ -0,0 +1,60 @@
+/*
+ * test-zip-directory.c -- test VFS zip
+ *
+ * Copyright (c) 2020-2021 David Demelier <markand@malikania.fr>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <rexo.h>
+
+#include <core/vfs-zip.h>
+#include <core/vfs.h>
+
+RX_SET_UP(setup)
+{
+	if (vfs_zip(RX_DATA, DIRECTORY "/vfs/data.zip", "r") < 0)
+		return RX_ERROR;
+
+	return RX_SUCCESS;
+}
+
+RX_TEAR_DOWN(teardown)
+{
+	vfs_finish(RX_DATA);
+}
+
+RX_FIXTURE(basics_fixture, struct vfs, .set_up = setup, .tear_down = teardown);
+
+RX_TEST_CASE(basics, read, .fixture = basics_fixture)
+{
+	struct vfs_file file;
+	char data[256] = {0};
+
+	RX_INT_REQUIRE_EQUAL(vfs_open(RX_DATA, &file, "texts/hello.txt", "r"), 0);
+	RX_UINT_REQUIRE_EQUAL(vfs_file_read(&file, data, sizeof (data)), 21U);
+	RX_STR_REQUIRE_EQUAL(data, "Hello from zip file!\n");
+}
+
+RX_TEST_CASE(basics, notfound, .fixture = basics_fixture)
+{
+	struct vfs_file file;
+
+	RX_INT_REQUIRE_EQUAL(vfs_open(RX_DATA, &file, "notfound.txt", "r"), -1);
+}
+
+int
+main(int argc, char **argv)
+{
+	return rx_main(0, NULL, argc, (const char **)argv) == RX_SUCCESS ? 0 : 1;
+}