mirror of
https://github.com/samba-team/samba.git
synced 2025-03-11 16:58:40 +03:00
torture3: Add tdb-validate test
Bug: https://bugzilla.samba.org/show_bug.cgi?id=14789 Signed-off-by: Volker Lendecke <vl@samba.org> Reviewed-by: Andreas Schneider <asn@samba.org> Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
parent
47f401095e
commit
12c8b67ef6
selftest/knownfail.d
source3
1
selftest/knownfail.d/tdb-validate
Normal file
1
selftest/knownfail.d/tdb-validate
Normal file
@ -0,0 +1 @@
|
|||||||
|
samba3.smbtorture_s3.LOCAL-TDB-VALIDATE.smbtorture
|
@ -503,6 +503,7 @@ local_tests = [
|
|||||||
"LOCAL-G-LOCK8",
|
"LOCAL-G-LOCK8",
|
||||||
"LOCAL-NAMEMAP-CACHE1",
|
"LOCAL-NAMEMAP-CACHE1",
|
||||||
"LOCAL-IDMAP-CACHE1",
|
"LOCAL-IDMAP-CACHE1",
|
||||||
|
"LOCAL-TDB-VALIDATE",
|
||||||
"LOCAL-hex_encode_buf",
|
"LOCAL-hex_encode_buf",
|
||||||
"LOCAL-remove_duplicate_addrs2"]
|
"LOCAL-remove_duplicate_addrs2"]
|
||||||
|
|
||||||
|
@ -176,5 +176,6 @@ bool run_hidenewfiles_showdirs(int dummy);
|
|||||||
bool run_readdir_timestamp(int dummy);
|
bool run_readdir_timestamp(int dummy);
|
||||||
bool run_ctdbd_conn1(int dummy);
|
bool run_ctdbd_conn1(int dummy);
|
||||||
bool run_rpc_scale(int dummy);
|
bool run_rpc_scale(int dummy);
|
||||||
|
bool run_tdb_validate(int dummy);
|
||||||
|
|
||||||
#endif /* __TORTURE_H__ */
|
#endif /* __TORTURE_H__ */
|
||||||
|
68
source3/torture/test_tdb_validate.c
Normal file
68
source3/torture/test_tdb_validate.c
Normal file
@ -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 <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "source3/include/includes.h"
|
||||||
|
#include <tdb.h>
|
||||||
|
#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;
|
||||||
|
}
|
@ -15635,6 +15635,10 @@ static struct {
|
|||||||
.name = "rpc-scale",
|
.name = "rpc-scale",
|
||||||
.fn = run_rpc_scale,
|
.fn = run_rpc_scale,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.name = "LOCAL-TDB-VALIDATE",
|
||||||
|
.fn = run_tdb_validate,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.name = NULL,
|
.name = NULL,
|
||||||
},
|
},
|
||||||
|
@ -59,6 +59,7 @@ bld.SAMBA3_BINARY('smbtorture' + bld.env.suffix3,
|
|||||||
test_hidenewfiles.c
|
test_hidenewfiles.c
|
||||||
test_readdir_timestamp.c
|
test_readdir_timestamp.c
|
||||||
test_rpc_scale.c
|
test_rpc_scale.c
|
||||||
|
test_tdb_validate.c
|
||||||
''' + TORTURE3_ADDITIONAL_SOURCE,
|
''' + TORTURE3_ADDITIONAL_SOURCE,
|
||||||
deps='''
|
deps='''
|
||||||
talloc
|
talloc
|
||||||
@ -75,6 +76,7 @@ bld.SAMBA3_BINARY('smbtorture' + bld.env.suffix3,
|
|||||||
libcli_lsa3
|
libcli_lsa3
|
||||||
samba-cluster-support
|
samba-cluster-support
|
||||||
util_sd
|
util_sd
|
||||||
|
TDB_VALIDATE
|
||||||
''',
|
''',
|
||||||
cflags='-DWINBINDD_SOCKET_DIR=\"%s\"' % bld.env.WINBINDD_SOCKET_DIR,
|
cflags='-DWINBINDD_SOCKET_DIR=\"%s\"' % bld.env.WINBINDD_SOCKET_DIR,
|
||||||
for_selftest=True)
|
for_selftest=True)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user