commit - 54be8251170ea16b244d270abfc498e266117d84
commit + ddb547b4ba4b22af3a10702f0f596151fbbf1e31
blob - /dev/null
blob + 957eacee13af6f70b82176c5e8ef18cfd848f6f1 (mode 644)
--- /dev/null
+++ regress/idset/Makefile
+.PATH:${.CURDIR}/../../lib
+
+PROG = idset_test
+SRCS = error.c object.c privsep.c sha1.c pack.c zbuf.c path.c opentemp.c \
+ delta.c repository.c reference.c worktree.c fileindex.c \
+ object_idset.c idset_test.c
+
+CPPFLAGS = -I${.CURDIR}/../../include -I${.CURDIR}/../../lib
+LDADD = -lutil -lz
+DEBUG = -O0 -g
+CFLAGS += -Werror -Wall -Wstrict-prototypes -Wunused-variable
+
+NOMAN = yes
+
+.include <bsd.regress.mk>
blob - /dev/null
blob + de713b3d72a9ae2f5014853f72ff74cc83309b6f (mode 644)
--- /dev/null
+++ regress/idset/idset_test.c
+/*
+ * Copyright (c) 2018 Stefan Sperling <stsp@openbsd.org>
+ *
+ * Permission to use, copy, modify, and 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 <sys/queue.h>
+
+#include <stdarg.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <err.h>
+#include <sha1.h>
+#include <zlib.h>
+
+#include "got_error.h"
+#include "got_object.h"
+
+#include "got_lib_object_idset.h"
+#include "got_lib_sha1.h"
+#include "got_lib_zbuf.h"
+#include "got_lib_delta.h"
+#include "got_lib_object.h"
+
+static int verbose;
+
+void
+test_printf(char *fmt, ...)
+{
+ va_list ap;
+
+ if (!verbose)
+ return;
+
+ va_start(ap, fmt);
+ vprintf(fmt, ap);
+ va_end(ap);
+}
+
+static const char *id_str1 = "1111111111111111111111111111111111111111";
+static const char *id_str2 = "2222222222222222222222222222222222222222";
+static const char *id_str3 = "ffffffffffffffffffffffffffffffffffffffff";
+static struct got_object_id id1, id2, id3;
+static const char *data1 = "data1", *data2 = "data2", *data3 = "data3";
+static int iter_count;
+
+static void
+idset_cb(struct got_object_id *id, void *data) {
+ if (iter_count == 0 &&
+ (got_object_id_cmp(id, &id1) != 0 || data != (void *)data1))
+ abort();
+ if (iter_count == 1 &&
+ (got_object_id_cmp(id, &id3) != 0 || data != (void *)data3))
+ abort();
+ iter_count++;
+}
+
+static int
+idset_add_remove_iter(void)
+{
+ const struct got_error *err = NULL;
+ struct got_object_idset *set;
+
+ set = got_object_idset_alloc();
+ if (set == NULL) {
+ err = got_error_from_errno();
+ goto done;
+ }
+
+ if (!got_parse_sha1_digest(id1.sha1, id_str1)) {
+ err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
+ goto done;
+ }
+ if (!got_parse_sha1_digest(id2.sha1, id_str2)) {
+ err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
+ goto done;
+ }
+ if (!got_parse_sha1_digest(id3.sha1, id_str3)) {
+ err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
+ goto done;
+ }
+
+ err = got_object_idset_add(set, &id1, (void *)data1);
+ if (err)
+ goto done;
+
+ if (!got_object_idset_contains(set, &id1)) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+
+ err = got_object_idset_add(set, &id2, (void *)data2);
+ if (err)
+ goto done;
+ err = got_object_idset_add(set, &id2, NULL);
+ if (err->code != GOT_ERR_OBJ_EXISTS)
+ goto done;
+ err = NULL;
+
+ if (!got_object_idset_contains(set, &id1)) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+ if (!got_object_idset_contains(set, &id2)) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+
+ err = got_object_idset_add(set, &id3, (void *)data3);
+ if (err)
+ goto done;
+
+ if (got_object_idset_get_data(set, &id1) != (void *)data1) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+ if (got_object_idset_get_data(set, &id2) != (void *)data2) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+ if (got_object_idset_get_data(set, &id3) != (void *)data3) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+
+ err = got_object_idset_remove(set, &id2);
+ if (err)
+ goto done;
+ if (got_object_idset_contains(set, &id2)) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+ if (got_object_idset_get_data(set, &id2) != NULL) {
+ err = got_error(GOT_ERR_BAD_OBJ_DATA);
+ goto done;
+ }
+
+ got_object_idset_for_each(set, idset_cb);
+ got_object_idset_free(set);
+done:
+ return (err == NULL);
+}
+
+#define RUN_TEST(expr, name) \
+ { test_ok = (expr); \
+ printf("test %s %s\n", (name), test_ok ? "ok" : "failed"); \
+ failure = (failure || !test_ok); }
+
+void
+usage(void)
+{
+ fprintf(stderr, "usage: id_test [-v]\n");
+}
+
+int
+main(int argc, char *argv[])
+{
+ int test_ok = 0, failure = 0;
+ int ch;
+
+ if (pledge("stdio", NULL) == -1)
+ err(1, "pledge");
+
+ while ((ch = getopt(argc, argv, "v")) != -1) {
+ switch (ch) {
+ case 'v':
+ verbose = 1;
+ break;
+ default:
+ usage();
+ return 1;
+ }
+ }
+ argc -= optind;
+ argv += optind;
+
+ RUN_TEST(idset_add_remove_iter(), "idset_add_remove_iter");
+
+ return failure ? 1 : 0;
+}