|
|
2c83a8 |
From d036dce0c804a6d91790dd8e6aa4f2ca08e703d9 Mon Sep 17 00:00:00 2001
|
|
|
2c83a8 |
From: Matej Habrnal <mhabrnal@redhat.com>
|
|
|
2c83a8 |
Date: Tue, 29 Mar 2016 12:11:23 +0200
|
|
|
2c83a8 |
Subject: [PATCH] testsuite: problem_data: add problem_data_reproducible
|
|
|
2c83a8 |
testcase
|
|
|
2c83a8 |
|
|
|
2c83a8 |
Signed-off-by: Matej Habrnal <mhabrnal@redhat.com>
|
|
|
2c83a8 |
---
|
|
|
2c83a8 |
tests/problem_data.at | 415 ++++++++++++++++++++++++++++++++++++++++++++++++++
|
|
|
2c83a8 |
1 file changed, 415 insertions(+)
|
|
|
2c83a8 |
create mode 100644 tests/problem_data.at
|
|
|
2c83a8 |
|
|
|
2c83a8 |
diff --git a/tests/problem_data.at b/tests/problem_data.at
|
|
|
2c83a8 |
new file mode 100644
|
|
|
2c83a8 |
index 0000000..c4ee4de
|
|
|
2c83a8 |
--- /dev/null
|
|
|
2c83a8 |
+++ b/tests/problem_data.at
|
|
|
2c83a8 |
@@ -0,0 +1,415 @@
|
|
|
2c83a8 |
+# -*- Autotest -*-
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+AT_BANNER([problem data])
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+## ---------------- ##
|
|
|
2c83a8 |
+## problem_data_add ##
|
|
|
2c83a8 |
+## ---------------- ##
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+AT_TESTFUN([problem_data_add],
|
|
|
2c83a8 |
+[[
|
|
|
2c83a8 |
+#include "problem_data.h"
|
|
|
2c83a8 |
+#include "internal_libreport.h"
|
|
|
2c83a8 |
+#include <assert.h>
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+#define TEST_NAME "package"
|
|
|
2c83a8 |
+#define TEST_CONTENTS "libreport"
|
|
|
2c83a8 |
+#define TEST_FLAGS (CD_FLAG_TXT | CD_FLAG_ISNOTEDITABLE | CD_FLAG_UNIXTIME)
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+int main(int argc, char **argv)
|
|
|
2c83a8 |
+{
|
|
|
2c83a8 |
+ g_verbose = 3;
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_t *data = problem_data_new();
|
|
|
2c83a8 |
+ problem_data_add(data, TEST_NAME, TEST_CONTENTS, TEST_FLAGS);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ struct problem_item *itm = problem_data_get_item_or_NULL(data, TEST_NAME);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ assert(strcmp(itm->content, TEST_CONTENTS) == 0);
|
|
|
2c83a8 |
+ assert(itm->flags == TEST_FLAGS);
|
|
|
2c83a8 |
+ assert(itm->size == PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_free(data);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ return 0;
|
|
|
2c83a8 |
+}
|
|
|
2c83a8 |
+]])
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+## -------------------- ##
|
|
|
2c83a8 |
+## problem_data_add_ext ##
|
|
|
2c83a8 |
+## -------------------- ##
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+AT_TESTFUN([problem_data_add_ext],
|
|
|
2c83a8 |
+[[
|
|
|
2c83a8 |
+#include "problem_data.h"
|
|
|
2c83a8 |
+#include "internal_libreport.h"
|
|
|
2c83a8 |
+#include <assert.h>
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+#define TEST_NAME "package"
|
|
|
2c83a8 |
+#define TEST_CONTENTS "libreport"
|
|
|
2c83a8 |
+#define TEST_FLAGS (CD_FLAG_TXT | CD_FLAG_ISNOTEDITABLE | CD_FLAG_UNIXTIME)
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+int main(int argc, char **argv)
|
|
|
2c83a8 |
+{
|
|
|
2c83a8 |
+ g_verbose = 3;
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_t *data = problem_data_new();
|
|
|
2c83a8 |
+ struct problem_item *itm = problem_data_add_ext(data, TEST_NAME, TEST_CONTENTS, TEST_FLAGS, strlen(TEST_CONTENTS));
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ struct problem_item *found = problem_data_get_item_or_NULL(data, TEST_NAME);
|
|
|
2c83a8 |
+ assert(itm == found);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ assert(strcmp(itm->content, TEST_CONTENTS) == 0);
|
|
|
2c83a8 |
+ assert(itm->flags == TEST_FLAGS);
|
|
|
2c83a8 |
+ assert(itm->size == strlen(TEST_CONTENTS));
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_free(data);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ return 0;
|
|
|
2c83a8 |
+}
|
|
|
2c83a8 |
+]])
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+## ---------------------- ##
|
|
|
2c83a8 |
+## problem_item_get_size ##
|
|
|
2c83a8 |
+## ---------------------- ##
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+AT_TESTFUN([problem_item_get_size],
|
|
|
2c83a8 |
+[[
|
|
|
2c83a8 |
+#include "problem_data.h"
|
|
|
2c83a8 |
+#include "internal_libreport.h"
|
|
|
2c83a8 |
+#include <assert.h>
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+int main(int argc, char **argv)
|
|
|
2c83a8 |
+{
|
|
|
2c83a8 |
+ g_verbose = 3;
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_t *data = problem_data_new();
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ struct problem_item *itm = problem_data_add_ext(data, "1", "foo", CD_FLAG_TXT | CD_FLAG_ISNOTEDITABLE, PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+ const size_t old_size = strlen(itm->content);
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ size_t current_size = PROBLEM_ITEM_UNINITIALIZED_SIZE;
|
|
|
2c83a8 |
+ assert(problem_item_get_size(itm, ¤t_size) == 0);
|
|
|
2c83a8 |
+ assert(current_size != PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+ assert(current_size == old_size);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ free(itm->content);
|
|
|
2c83a8 |
+ itm->content = NULL;
|
|
|
2c83a8 |
+ size_t current_size = PROBLEM_ITEM_UNINITIALIZED_SIZE;
|
|
|
2c83a8 |
+ assert(problem_item_get_size(itm, ¤t_size) == 0);
|
|
|
2c83a8 |
+ assert(current_size != PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+ assert(current_size == old_size);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char flnm[] = "/tmp/libreport.unittest.XXXXXXX";
|
|
|
2c83a8 |
+ int flds = mkstemp(flnm);
|
|
|
2c83a8 |
+ assert(flds >= 0);
|
|
|
2c83a8 |
+ /* sizeof(flnm) is strlen + '\0' */
|
|
|
2c83a8 |
+ assert(write(flds, flnm, strlen(flnm)) == strlen(flnm));
|
|
|
2c83a8 |
+ fsync(flds);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ struct stat buf;
|
|
|
2c83a8 |
+ assert(fstat(flds, &buf) == 0);
|
|
|
2c83a8 |
+ assert(buf.st_size != 0);
|
|
|
2c83a8 |
+ size_t old_size = buf.st_size;
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ struct problem_item *itm = problem_data_add_ext(data, "2", flnm, CD_FLAG_BIN, PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ size_t current_size = PROBLEM_ITEM_UNINITIALIZED_SIZE;
|
|
|
2c83a8 |
+ assert(problem_item_get_size(itm, ¤t_size) == 0);
|
|
|
2c83a8 |
+ assert(current_size != PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+ assert(current_size == old_size);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ close(flds);
|
|
|
2c83a8 |
+ unlink(flnm);
|
|
|
2c83a8 |
+ assert(stat(flnm, &buf) != 0);
|
|
|
2c83a8 |
+ size_t current_size = PROBLEM_ITEM_UNINITIALIZED_SIZE;
|
|
|
2c83a8 |
+ assert(problem_item_get_size(itm, ¤t_size) == 0);
|
|
|
2c83a8 |
+ assert(current_size != PROBLEM_ITEM_UNINITIALIZED_SIZE);
|
|
|
2c83a8 |
+ assert(current_size == old_size);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_free(data);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ return 0;
|
|
|
2c83a8 |
+}
|
|
|
2c83a8 |
+]])
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+## ------------------------------- ##
|
|
|
2c83a8 |
+## problem_data_load_from_dump_dir ##
|
|
|
2c83a8 |
+## ------------------------------- ##
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+AT_TESTFUN([problem_data_load_from_dump_dir],
|
|
|
2c83a8 |
+[[
|
|
|
2c83a8 |
+#include "problem_data.h"
|
|
|
2c83a8 |
+#include "internal_libreport.h"
|
|
|
2c83a8 |
+#include <assert.h>
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+int main(int argc, char **argv)
|
|
|
2c83a8 |
+{
|
|
|
2c83a8 |
+ g_verbose = 3;
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ char template[] = "/tmp/XXXXXX";
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ if (mkdtemp(template) == NULL) {
|
|
|
2c83a8 |
+ perror("mkdtemp()");
|
|
|
2c83a8 |
+ return EXIT_FAILURE;
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ printf("Dump dir path: %s\n", template);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ struct dump_dir *dd = dd_create(template, (uid_t)-1, 0640);
|
|
|
2c83a8 |
+ assert(dd != NULL || !"Cannot create new dump directory");
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ /* dd_create_basic_files() should create these files:
|
|
|
2c83a8 |
+ FILENAME_TIME, FILENAME_LAST_OCCURRENCE, FILENAME_UID, FILENAME_KERNEL,
|
|
|
2c83a8 |
+ FILENAME_ARCHITECTURE, FILENAME_HOSTNAME, FILENAME_OS_INFO, FILENAME_OS_RELEASE
|
|
|
2c83a8 |
+ */
|
|
|
2c83a8 |
+ dd_create_basic_files(dd, geteuid(), NULL);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_TYPE, "attest");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_ANALYZER, "attest-problem_data");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_DUPHASH, "0123456789ABCDEF");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_UUID, "FEDCBA9876543210");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_USERNAME, "perhaps_tester");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PACKAGE, "1:attest-1.1-3.x86_64");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PKG_EPOCH, "1");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PKG_NAME, "attest");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PKG_VERSION, "1.1");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PKG_RELEASE, "3");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PKG_ARCH, "x86_64");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CMDLINE, "$TESTSUITE.DIR/$NUM/problem_data_load_from_dump_dir foo blah");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_EXECUTABLE, "$TESTSUITE.DIR/$NUM/problem_data_load_from_dump_dir");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_ROOTDIR, "/");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PWD, "$TESTSUITE.DIR");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PID, "12345");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_GLOBAL_PID, "12345");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_TID, "12345");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_COUNT, "1");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_REASON, "Unit testing problem_data_load_from_dump_dir");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_COMMENT, "Random comment");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_BACKTRACE, "Pseudo-backtrace");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_OPEN_FDS, "Opened FDs");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_MAPS, "/proc/[pid]/maps");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_SMAPS, "/proc/[pid]/smaps");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_ENVIRON, "/proc/[pid]/environ");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_LIMITS, "/proc/[pid]/limits");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CGROUP, "/proc/[pid]/cgroup");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_PROC_PID_STATUS, "/proc/[pid]/status");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_MOUNTINFO, "/proc/[pid]/mountinfo");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CRASH_FUNCTION, "main");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_REMOTE, "0");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_RATING, "4");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_EXPLOITABLE, "6");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_TAINTED, "Not tainted");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_TAINTED_SHORT, "Not tainted");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_TAINTED_LONG, "Not tainted");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_NOT_REPORTABLE, "Despite 'not tainted' this problem cannot be reported.");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_REPORTED_TO, "Bugzilla: URL=https://bugzilla.redhat.com/1000000");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_EVENT_LOG, "--- report_Bugzilla has finished successfully ---");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_KICKSTART_CFG, "kickstart.cfg");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_ANACONDA_TB, "anaconda.tb");
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_NAMESPACES, "FILENAME_NAMESPACES");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_OS_INFO_IN_ROOTDIR, "FILENAME_OS_INFO_IN_ROOTDIR");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_OS_RELEASE_IN_ROOTDIR, "FILENAME_OS_RELEASE_IN_ROOTDIR");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_KERNEL_LOG, "FILENAME_KERNEL_LOG");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_DESCRIPTION, "FILENAME_DESCRIPTION");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CORE_BACKTRACE, "FILENAME_CORE_BACKTRACE");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_REMOTE_RESULT, "FILENAME_REMOTE_RESULT");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_ABRT_VERSION, "FILENAME_ABRT_VERSION");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CONTAINER, "FILENAME_CONTAINER");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CONTAINER_ID, "FILENAME_CONTAINER_ID");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CONTAINER_UUID, "FILENAME_CONTAINER_UUID");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CONTAINER_IMAGE, "FILENAME_CONTAINER_IMAGE");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_CONTAINER_CMDLINE, "FILENAME_CONTAINER_CMDLINE");
|
|
|
2c83a8 |
+ dd_save_text(dd, FILENAME_DOCKER_INSPECT, "FILENAME_DOCKER_INSPECT");
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ dd_save_text(dd, "attestsuite-random-file", "random content");
|
|
|
2c83a8 |
+ dd_save_text(dd, "attestsuite-oneliner-newline", "newline\n");
|
|
|
2c83a8 |
+ dd_save_text(dd, "attestsuite-newline-followed", "newline\nfollowed");
|
|
|
2c83a8 |
+ dd_save_text(dd, "attestsuite-multi-line", "newline\nextra\n");
|
|
|
2c83a8 |
+ dd_save_text(dd, "attestsuite-tab", "tab\ttab");
|
|
|
2c83a8 |
+ dd_save_text(dd, "attestsuite-cr", "cr\rcr");
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ char buffer[1024*3];
|
|
|
2c83a8 |
+ memset(buffer, 'x', sizeof(buffer));
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ int fd4k = openat(dd->dd_fd, "attestsuite-over4k", O_WRONLY | O_CREAT | O_TRUNC, 0550);
|
|
|
2c83a8 |
+ assert(fd4k >= 0);
|
|
|
2c83a8 |
+ full_write(fd4k, buffer, sizeof(buffer));
|
|
|
2c83a8 |
+ full_write(fd4k, buffer, sizeof(buffer));
|
|
|
2c83a8 |
+ close(fd4k);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ int bigfd = openat(dd->dd_fd, "attestsuite-bigtext", O_WRONLY | O_CREAT | O_TRUNC, 0550);
|
|
|
2c83a8 |
+ assert(bigfd >= 0);
|
|
|
2c83a8 |
+ for (int i = 3000; i > 0; --i)
|
|
|
2c83a8 |
+ full_write(bigfd, buffer, sizeof(buffer));
|
|
|
2c83a8 |
+ close(bigfd);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ dd_copy_file(dd, FILENAME_BINARY, "/usr/bin/sh");
|
|
|
2c83a8 |
+ dd_copy_file(dd, FILENAME_COREDUMP, "/usr/bin/sh");
|
|
|
2c83a8 |
+ dd_copy_file(dd, FILENAME_VMCORE, "/usr/bin/sh");
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ static const char *const list_elements[] = { FILENAME_UID, FILENAME_PACKAGE,
|
|
|
2c83a8 |
+ FILENAME_CMDLINE, FILENAME_TIME, FILENAME_COUNT, FILENAME_REASON };
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ static const char *const editable_files[] = { FILENAME_COMMENT, FILENAME_BACKTRACE,
|
|
|
2c83a8 |
+ FILENAME_REASON, FILENAME_OPEN_FDS, FILENAME_CMDLINE, FILENAME_MAPS,
|
|
|
2c83a8 |
+ FILENAME_SMAPS, FILENAME_ENVIRON, FILENAME_HOSTNAME, FILENAME_REMOTE,
|
|
|
2c83a8 |
+ FILENAME_KICKSTART_CFG, FILENAME_ANACONDA_TB, };
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ static const char *const binary_files[] = { FILENAME_BINARY, FILENAME_COREDUMP,
|
|
|
2c83a8 |
+ FILENAME_VMCORE, };
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_t *pd = problem_data_new();
|
|
|
2c83a8 |
+ problem_data_load_from_dump_dir(pd, dd, /*excluding*/NULL);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ GHashTableIter pd_iter;
|
|
|
2c83a8 |
+ char *element_name;
|
|
|
2c83a8 |
+ struct problem_item *item;
|
|
|
2c83a8 |
+ g_hash_table_iter_init(&pd_iter, pd);
|
|
|
2c83a8 |
+ while (g_hash_table_iter_next(&pd_iter, (void**)&element_name, (void**)&item))
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ printf("Testing element : %s\n", element_name);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ size_t i;
|
|
|
2c83a8 |
+ for (i = 0; i < ARRAY_SIZE(list_elements); ++i)
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ if (strcmp(element_name, list_elements[i]) == 0)
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ assert((item->flags & CD_FLAG_LIST));
|
|
|
2c83a8 |
+ break;
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ if (i == ARRAY_SIZE(list_elements))
|
|
|
2c83a8 |
+ assert(!(item->flags & CD_FLAG_LIST));
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ for (i = 0; i < ARRAY_SIZE(editable_files); ++i)
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ if (strcmp(element_name, editable_files[i]) == 0)
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ assert((item->flags & CD_FLAG_ISEDITABLE) && !(item->flags & CD_FLAG_ISNOTEDITABLE));
|
|
|
2c83a8 |
+ break;
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ if (i == ARRAY_SIZE(editable_files))
|
|
|
2c83a8 |
+ assert(!(item->flags & CD_FLAG_ISEDITABLE) && (item->flags & CD_FLAG_ISNOTEDITABLE));
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ for (i = 0; i < ARRAY_SIZE(binary_files); ++i)
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ if (strcmp(element_name, binary_files[i]) == 0)
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ assert((item->flags & CD_FLAG_BIN) && !(item->flags & CD_FLAG_TXT) && !(item->flags & CD_FLAG_BIGTXT));
|
|
|
2c83a8 |
+ break;
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+ if (i == ARRAY_SIZE(binary_files))
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ if(strstr(element_name, "bigtext") == 0)
|
|
|
2c83a8 |
+ assert((item->flags & CD_FLAG_TXT) && !(item->flags & CD_FLAG_BIN) && !(item->flags & CD_FLAG_BIGTXT));
|
|
|
2c83a8 |
+ else
|
|
|
2c83a8 |
+ assert((item->flags & CD_FLAG_BIGTXT) && (item->flags & CD_FLAG_BIN) && !(item->flags & CD_FLAG_TXT));
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ if (strcmp(element_name, FILENAME_TIME) == 0)
|
|
|
2c83a8 |
+ assert(item->flags & CD_FLAG_UNIXTIME);
|
|
|
2c83a8 |
+ else
|
|
|
2c83a8 |
+ assert(!(item->flags & CD_FLAG_UNIXTIME));
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char *cnt = problem_data_get_content_or_NULL(pd, "attestsuite-oneliner-newline");
|
|
|
2c83a8 |
+ assert(cnt != NULL && "attestsuite-oneliner-newline");
|
|
|
2c83a8 |
+ assert(strcmp(cnt, "newline") == 0);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char *cnt = problem_data_get_content_or_NULL(pd, "attestsuite-newline-followed");
|
|
|
2c83a8 |
+ assert(cnt != NULL && "attestsuite-newline-followed");
|
|
|
2c83a8 |
+ assert(strcmp(cnt, "newline\nfollowed") == 0);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char *cnt = problem_data_get_content_or_NULL(pd, "attestsuite-multi-line");
|
|
|
2c83a8 |
+ assert(cnt != NULL && "attestsuite-multi-line");
|
|
|
2c83a8 |
+ assert(strcmp(cnt, "newline\nextra\n") == 0);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char *cnt = problem_data_get_content_or_NULL(pd, "attestsuite-over4k");
|
|
|
2c83a8 |
+ assert(cnt != NULL && "attestsuite-over4k");
|
|
|
2c83a8 |
+ assert(strlen(cnt) == (2 * sizeof(buffer)));
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char *cnt = problem_data_get_content_or_NULL(pd, "attestsuite-tab");
|
|
|
2c83a8 |
+ assert(cnt != NULL && "attestsuite-tab");
|
|
|
2c83a8 |
+ assert(strcmp(cnt, "tab\ttab") == 0);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ {
|
|
|
2c83a8 |
+ char *cnt = problem_data_get_content_or_NULL(pd, "attestsuite-cr");
|
|
|
2c83a8 |
+ assert(cnt != NULL && "attestsuite-cr");
|
|
|
2c83a8 |
+ assert(strcmp(cnt, "cr[0D]cr") == 0);
|
|
|
2c83a8 |
+ }
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ return 0;
|
|
|
2c83a8 |
+}
|
|
|
2c83a8 |
+]])
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+## ------------------------- ##
|
|
|
2c83a8 |
+## problem_data_reproducible ##
|
|
|
2c83a8 |
+## ------------------------- ##
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+AT_TESTFUN([problem_data_reproducible],
|
|
|
2c83a8 |
+[[
|
|
|
2c83a8 |
+#include "testsuite.h"
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+#define TEST_FLAGS (CD_FLAG_TXT | CD_FLAG_ISNOTEDITABLE | CD_FLAG_UNIXTIME)
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+TS_MAIN
|
|
|
2c83a8 |
+{
|
|
|
2c83a8 |
+ TS_ASSERT_STRING_NULL_OR_EMPTY(get_problem_data_reproducible_name(-1), "Invalid value");
|
|
|
2c83a8 |
+ TS_ASSERT_PTR_IS_NOT_NULL(get_problem_data_reproducible_name(PROBLEM_REPRODUCIBLE_UNKNOWN));
|
|
|
2c83a8 |
+ TS_ASSERT_PTR_IS_NOT_NULL(get_problem_data_reproducible_name(PROBLEM_REPRODUCIBLE_YES));
|
|
|
2c83a8 |
+ TS_ASSERT_PTR_IS_NOT_NULL(get_problem_data_reproducible_name(PROBLEM_REPRODUCIBLE_RECURRENT));
|
|
|
2c83a8 |
+ TS_ASSERT_STRING_NULL_OR_EMPTY(get_problem_data_reproducible_name(_PROBLEM_REPRODUCIBLE_MAX_), "Upper boundary");
|
|
|
2c83a8 |
+ TS_ASSERT_STRING_NULL_OR_EMPTY(get_problem_data_reproducible_name(_PROBLEM_REPRODUCIBLE_MAX_ + 1), "Upper boundary + 1");
|
|
|
2c83a8 |
+ TS_ASSERT_SIGNED_EQ(_PROBLEM_REPRODUCIBLE_MAX_, 3);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_t *pd = problem_data_new();
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ TS_ASSERT_SIGNED_EQ(get_problem_data_reproducible(pd), -1);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_add(pd, FILENAME_REPRODUCIBLE,
|
|
|
2c83a8 |
+ get_problem_data_reproducible_name(PROBLEM_REPRODUCIBLE_UNKNOWN), TEST_FLAGS);
|
|
|
2c83a8 |
+ TS_ASSERT_SIGNED_EQ(get_problem_data_reproducible(pd), PROBLEM_REPRODUCIBLE_UNKNOWN);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_add(pd, FILENAME_REPRODUCIBLE,
|
|
|
2c83a8 |
+ get_problem_data_reproducible_name(PROBLEM_REPRODUCIBLE_YES), TEST_FLAGS);
|
|
|
2c83a8 |
+ TS_ASSERT_SIGNED_EQ(get_problem_data_reproducible(pd), PROBLEM_REPRODUCIBLE_YES);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_add(pd, FILENAME_REPRODUCIBLE,
|
|
|
2c83a8 |
+ get_problem_data_reproducible_name(PROBLEM_REPRODUCIBLE_RECURRENT), TEST_FLAGS);
|
|
|
2c83a8 |
+ TS_ASSERT_SIGNED_EQ(get_problem_data_reproducible(pd), PROBLEM_REPRODUCIBLE_RECURRENT);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_add(pd, FILENAME_REPRODUCIBLE,
|
|
|
2c83a8 |
+ get_problem_data_reproducible_name(_PROBLEM_REPRODUCIBLE_MAX_), TEST_FLAGS);
|
|
|
2c83a8 |
+ TS_ASSERT_SIGNED_EQ(get_problem_data_reproducible(pd), -1);
|
|
|
2c83a8 |
+
|
|
|
2c83a8 |
+ problem_data_free(pd);
|
|
|
2c83a8 |
+}
|
|
|
2c83a8 |
+TS_RETURN_MAIN
|
|
|
2c83a8 |
+]])
|
|
|
2c83a8 |
--
|
|
|
2c83a8 |
1.8.3.1
|
|
|
2c83a8 |
|