tests/libpakfire/db \
tests/libpakfire/dependencies \
tests/libpakfire/downloader \
+ tests/libpakfire/file \
tests/libpakfire/jail \
tests/libpakfire/key \
tests/libpakfire/makefile \
tests_libpakfire_downloader_LDADD = \
$(TESTSUITE_LDADD)
+dist_tests_libpakfire_file_SOURCES = \
+ tests/libpakfire/file.c
+
+tests_libpakfire_file_CPPFLAGS = \
+ $(TESTSUITE_CPPFLAGS)
+
+tests_libpakfire_file_CFLAGS = \
+ $(TESTSUITE_CFLAGS)
+
+tests_libpakfire_file_LDADD = \
+ $(TESTSUITE_LDADD)
+
dist_tests_libpakfire_jail_SOURCES = \
tests/libpakfire/jail.c
--- /dev/null
+/*#############################################################################
+# #
+# Pakfire - The IPFire package management system #
+# Copyright (C) 2022 Pakfire development team #
+# #
+# This program is free software: you can redistribute it and/or modify #
+# it under the terms of the GNU General Public License as published by #
+# the Free Software Foundation, either version 3 of the License, or #
+# (at your option) any later version. #
+# #
+# This program is distributed in the hope that it will be useful, #
+# but WITHOUT ANY WARRANTY; without even the implied warranty of #
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
+# GNU General Public License for more details. #
+# #
+# You should have received a copy of the GNU General Public License #
+# along with this program. If not, see <http://www.gnu.org/licenses/>. #
+# #
+#############################################################################*/
+
+#include <pakfire/file.h>
+
+#include "../testsuite.h"
+
+static int test_create(const struct test* t) {
+ struct pakfire_file* file = NULL;
+
+ // Create a new file
+ ASSERT_SUCCESS(pakfire_file_create(&file, t->pakfire));
+
+ // Set path & check
+ ASSERT_SUCCESS(pakfire_file_set_path(file, "/abc"));
+ ASSERT_STRING_EQUALS(pakfire_file_get_path(file), "/abc");
+
+ // Destroy it
+ ASSERT_NULL(pakfire_file_unref(file));
+
+ return EXIT_SUCCESS;
+
+FAIL:
+ return EXIT_FAILURE;
+}
+
+static int test_create_invalid(const struct test* t) {
+ struct pakfire_file* file = NULL;
+
+ // Create a new file
+ ASSERT_SUCCESS(pakfire_file_create(&file, t->pakfire));
+
+ // Set path
+ ASSERT_ERRNO(pakfire_file_set_path(file, NULL), EINVAL);
+
+ // It should not be possible to set relative paths
+ ASSERT_ERRNO(pakfire_file_set_path(file, "abc/abc"), EINVAL);
+ ASSERT_ERRNO(pakfire_file_set_abspath(file, "abc/abc"), EINVAL);
+
+ // Destroy it
+ ASSERT_NULL(pakfire_file_unref(file));
+
+ return EXIT_SUCCESS;
+
+FAIL:
+ return EXIT_FAILURE;
+}
+
+
+int main(int argc, const char* argv[]) {
+ testsuite_add_test(test_create);
+ testsuite_add_test(test_create_invalid);
+
+ return testsuite_run(argc, argv);
+}