From 8daa83a594a2e98f39d764422bfbdbc62c9efd44 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 19:20:00 +0200 Subject: Adding upstream version 2:4.20.0+dfsg. Signed-off-by: Daniel Baumann --- source3/torture/test_tdb_validate.c | 68 +++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 source3/torture/test_tdb_validate.c (limited to 'source3/torture/test_tdb_validate.c') diff --git a/source3/torture/test_tdb_validate.c b/source3/torture/test_tdb_validate.c new file mode 100644 index 0000000..4768512 --- /dev/null +++ b/source3/torture/test_tdb_validate.c @@ -0,0 +1,68 @@ +/* + * Unix SMB/CIFS implementation. + * + * 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 . + */ + +#include "source3/include/includes.h" +#include +#include "source3/torture/proto.h" +#include "source3/lib/tdb_validate.h" + +static int validate_fn(struct tdb_context *tdb, TDB_DATA key, TDB_DATA value, + void *private_data) +{ + struct tdb_validation_status *state = private_data; + state->success = false; + printf("validate_fn called\n"); + return -1; +} + +bool run_tdb_validate(int dummy) +{ + const char tdb_name[] = "tdb_validate.tdb"; + bool result = false; + struct tdb_context *tdb = NULL; + char buf[] = "data"; + TDB_DATA data = { .dptr = (uint8_t *)buf, .dsize = sizeof(buf), }; + int ret; + + unlink(tdb_name); + + tdb = tdb_open(tdb_name, 0, 0, O_CREAT|O_EXCL|O_RDWR, 0600); + if (tdb == NULL) { + perror("Could not open tdb"); + goto done; + } + + ret = tdb_store(tdb, data, data, 0); + if (ret == -1) { + perror("tdb_store failed"); + goto done; + } + + ret = tdb_validate(tdb, validate_fn); + if (ret == 0) { + fprintf(stderr, + "tdb_validate succeeded where it should have " + "failed\n"); + goto done; + } + + result = true; +done: + tdb_close(tdb); + unlink(tdb_name); + return result; +} -- cgit v1.2.3