mirror of
https://github.com/samba-team/samba.git
synced 2025-01-26 10:04:02 +03:00
r15456: Inspired by a short discussion with abartlet on IRC.
- create "async" parameter for smbtorture to categorise async tests potentially hard for windows servers - create "num-async" parameter to specify the number of simultaneous async requests to be made - move RPC-ASYNCBIND test from "dangerous" to "async" (I should probably do the same for many others async tests...) It's an interesting way to determine resources availability on windows servers... rafal
This commit is contained in:
parent
b4c378302b
commit
0d008fbea0
@ -24,6 +24,7 @@
|
|||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
#include "torture/torture.h"
|
#include "torture/torture.h"
|
||||||
#include "lib/events/events.h"
|
#include "lib/events/events.h"
|
||||||
|
#include "libcli/composite/composite.h"
|
||||||
#include "librpc/gen_ndr/ndr_lsa.h"
|
#include "librpc/gen_ndr/ndr_lsa.h"
|
||||||
#include "lib/cmdline/popt_common.h"
|
#include "lib/cmdline/popt_common.h"
|
||||||
#include "librpc/rpc/dcerpc.h"
|
#include "librpc/rpc/dcerpc.h"
|
||||||
@ -43,23 +44,30 @@ BOOL torture_async_bind(struct torture_context *torture)
|
|||||||
int i;
|
int i;
|
||||||
const char *binding_string;
|
const char *binding_string;
|
||||||
struct cli_credentials *creds;
|
struct cli_credentials *creds;
|
||||||
|
extern int torture_numasync;
|
||||||
|
|
||||||
#define ASYNC_COUNT 100
|
struct composite_context **bind_req;
|
||||||
struct composite_context *bind_req[ASYNC_COUNT];
|
struct dcerpc_pipe **pipe;
|
||||||
struct dcerpc_pipe *pipe[ASYNC_COUNT];
|
const struct dcerpc_interface_table **table;
|
||||||
struct dcerpc_interface_table *table[ASYNC_COUNT];
|
|
||||||
|
|
||||||
if (!lp_parm_bool(-1, "torture", "dangerous", False)) {
|
if (!lp_parm_bool(-1, "torture", "async", False)) {
|
||||||
printf("async bind test disabled - enable dangerous tests to use\n");
|
printf("async bind test disabled - enable dangerous tests to use\n");
|
||||||
return True;
|
return True;
|
||||||
}
|
}
|
||||||
|
|
||||||
binding_string = lp_parm_string(-1, "torture", "binding");
|
binding_string = lp_parm_string(-1, "torture", "binding");
|
||||||
|
|
||||||
/* talloc context */
|
/* talloc context */
|
||||||
mem_ctx = talloc_init("torture_async_bind");
|
mem_ctx = talloc_init("torture_async_bind");
|
||||||
if (mem_ctx == NULL) return False;
|
if (mem_ctx == NULL) return False;
|
||||||
|
|
||||||
|
bind_req = talloc_array(torture, struct composite_context*, torture_numasync);
|
||||||
|
if (bind_req == NULL) return False;
|
||||||
|
pipe = talloc_array(torture, struct dcerpc_pipe*, torture_numasync);
|
||||||
|
if (pipe == NULL) return False;
|
||||||
|
table = talloc_array(torture, const struct dcerpc_interface_table*, torture_numasync);
|
||||||
|
if (table == NULL) return False;
|
||||||
|
|
||||||
/* event context */
|
/* event context */
|
||||||
evt_ctx = event_context_init(mem_ctx);
|
evt_ctx = event_context_init(mem_ctx);
|
||||||
if (evt_ctx == NULL) return False;
|
if (evt_ctx == NULL) return False;
|
||||||
@ -67,15 +75,20 @@ BOOL torture_async_bind(struct torture_context *torture)
|
|||||||
/* credentials */
|
/* credentials */
|
||||||
creds = cmdline_credentials;
|
creds = cmdline_credentials;
|
||||||
|
|
||||||
for (i = 0; i < ASYNC_COUNT; i++) {
|
/* send bind requests */
|
||||||
|
for (i = 0; i < torture_numasync; i++) {
|
||||||
table[i] = &dcerpc_table_lsarpc;
|
table[i] = &dcerpc_table_lsarpc;
|
||||||
bind_req[i] = dcerpc_pipe_connect_send(mem_ctx, &pipe[i], binding_string,
|
bind_req[i] = dcerpc_pipe_connect_send(mem_ctx, &pipe[i], binding_string,
|
||||||
table[i], creds, evt_ctx);
|
table[i], creds, evt_ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < ASYNC_COUNT; i++) {
|
/* recv bind requests */
|
||||||
|
for (i = 0; i < torture_numasync; i++) {
|
||||||
status = dcerpc_pipe_connect_recv(bind_req[i], mem_ctx, &pipe[i]);
|
status = dcerpc_pipe_connect_recv(bind_req[i], mem_ctx, &pipe[i]);
|
||||||
if (!NT_STATUS_IS_OK(status)) return False;
|
if (!NT_STATUS_IS_OK(status)) {
|
||||||
|
printf("async rpc connection failed: %s\n", nt_errstr(status));
|
||||||
|
return False;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
talloc_free(mem_ctx);
|
talloc_free(mem_ctx);
|
||||||
|
@ -265,7 +265,7 @@ const static struct torture_ui_ops std_ui_ops = {
|
|||||||
char **argv_new;
|
char **argv_new;
|
||||||
poptContext pc;
|
poptContext pc;
|
||||||
enum {OPT_LOADFILE=1000,OPT_UNCLIST,OPT_TIMELIMIT,OPT_DNS,
|
enum {OPT_LOADFILE=1000,OPT_UNCLIST,OPT_TIMELIMIT,OPT_DNS,
|
||||||
OPT_DANGEROUS,OPT_SMB_PORTS};
|
OPT_DANGEROUS,OPT_SMB_PORTS,OPT_ASYNC};
|
||||||
|
|
||||||
struct poptOption long_options[] = {
|
struct poptOption long_options[] = {
|
||||||
POPT_AUTOHELP
|
POPT_AUTOHELP
|
||||||
@ -281,7 +281,12 @@ const static struct torture_ui_ops std_ui_ops = {
|
|||||||
{"timelimit", 't', POPT_ARG_STRING, NULL, OPT_TIMELIMIT, "timelimit", NULL},
|
{"timelimit", 't', POPT_ARG_STRING, NULL, OPT_TIMELIMIT, "timelimit", NULL},
|
||||||
{"failures", 'f', POPT_ARG_INT, &torture_failures, 0, "failures", NULL},
|
{"failures", 'f', POPT_ARG_INT, &torture_failures, 0, "failures", NULL},
|
||||||
{"parse-dns", 'D', POPT_ARG_STRING, NULL, OPT_DNS, "parse-dns", NULL},
|
{"parse-dns", 'D', POPT_ARG_STRING, NULL, OPT_DNS, "parse-dns", NULL},
|
||||||
{"dangerous", 'X', POPT_ARG_NONE, NULL, OPT_DANGEROUS, "dangerous", NULL},
|
{"dangerous", 'X', POPT_ARG_NONE, NULL, OPT_DANGEROUS,
|
||||||
|
"run dangerous tests (eg. wiping out password database)", NULL},
|
||||||
|
{"async", 'a', POPT_ARG_NONE, NULL, OPT_ASYNC,
|
||||||
|
"run async tests", NULL},
|
||||||
|
{"num-async", 0, POPT_ARG_INT, &torture_numasync, 0,
|
||||||
|
"number of simultaneous async requests", NULL},
|
||||||
{"maximum-runtime", 0, POPT_ARG_INT, &max_runtime, 0,
|
{"maximum-runtime", 0, POPT_ARG_INT, &max_runtime, 0,
|
||||||
"set maximum time for smbtorture to live", "seconds"},
|
"set maximum time for smbtorture to live", "seconds"},
|
||||||
POPT_COMMON_SAMBA
|
POPT_COMMON_SAMBA
|
||||||
@ -320,6 +325,9 @@ const static struct torture_ui_ops std_ui_ops = {
|
|||||||
case OPT_DANGEROUS:
|
case OPT_DANGEROUS:
|
||||||
lp_set_cmdline("torture:dangerous", "Yes");
|
lp_set_cmdline("torture:dangerous", "Yes");
|
||||||
break;
|
break;
|
||||||
|
case OPT_ASYNC:
|
||||||
|
lp_set_cmdline("torture:async", "Yes");
|
||||||
|
break;
|
||||||
case OPT_SMB_PORTS:
|
case OPT_SMB_PORTS:
|
||||||
lp_set_cmdline("smb ports", poptGetOptArg(pc));
|
lp_set_cmdline("smb ports", poptGetOptArg(pc));
|
||||||
break;
|
break;
|
||||||
|
@ -55,6 +55,7 @@ _PUBLIC_ int torture_numops=10;
|
|||||||
_PUBLIC_ int torture_entries=1000;
|
_PUBLIC_ int torture_entries=1000;
|
||||||
_PUBLIC_ int torture_failures=1;
|
_PUBLIC_ int torture_failures=1;
|
||||||
_PUBLIC_ int torture_seed=0;
|
_PUBLIC_ int torture_seed=0;
|
||||||
|
_PUBLIC_ int torture_numasync=100;
|
||||||
_PUBLIC_ BOOL use_oplocks;
|
_PUBLIC_ BOOL use_oplocks;
|
||||||
static int procnum; /* records process count number when forking */
|
static int procnum; /* records process count number when forking */
|
||||||
static struct smbcli_state *current_cli;
|
static struct smbcli_state *current_cli;
|
||||||
|
@ -40,6 +40,7 @@ extern int torture_nprocs;
|
|||||||
extern int torture_seed;
|
extern int torture_seed;
|
||||||
extern int torture_numops;
|
extern int torture_numops;
|
||||||
extern int torture_failures;
|
extern int torture_failures;
|
||||||
|
extern int torture_numasync;
|
||||||
extern BOOL use_level_II_oplocks;
|
extern BOOL use_level_II_oplocks;
|
||||||
|
|
||||||
struct torture_test;
|
struct torture_test;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user