summaryrefslogtreecommitdiff
path: root/source4/torture/rpc/autoidl.c
diff options
context:
space:
mode:
Diffstat (limited to 'source4/torture/rpc/autoidl.c')
-rw-r--r--source4/torture/rpc/autoidl.c66
1 files changed, 47 insertions, 19 deletions
diff --git a/source4/torture/rpc/autoidl.c b/source4/torture/rpc/autoidl.c
index 9e27ca7b58..5f89970d17 100644
--- a/source4/torture/rpc/autoidl.c
+++ b/source4/torture/rpc/autoidl.c
@@ -23,6 +23,42 @@
#include "includes.h"
+/*
+ get a handle - doesn't really matter what type
+*/
+static BOOL get_policy_handle(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx,
+ struct policy_handle *handle)
+{
+ NTSTATUS status;
+ struct samr_Connect r;
+
+ r.in.system_name = 0;
+ r.in.access_mask = SEC_RIGHTS_MAXIMUM_ALLOWED;
+ r.out.handle = handle;
+
+ status = dcerpc_samr_Connect(p, mem_ctx, &r);
+ if (!NT_STATUS_IS_OK(status)) {
+ printf("samr_Connect failed - %s\n", nt_errstr(status));
+ return False;
+ }
+
+ return True;
+}
+
+static void fill_blob_handle(DATA_BLOB *blob, TALLOC_CTX *mem_ctx,
+ struct policy_handle *handle)
+{
+ DATA_BLOB b2;
+
+ if (blob->length < 20) {
+ return;
+ }
+
+ ndr_push_struct_blob(&b2, mem_ctx, handle, (ndr_push_flags_fn_t)ndr_push_policy_handle);
+
+ memcpy(blob->data, b2.data, 20);
+}
+
static void reopen(struct dcerpc_pipe **p, const struct dcerpc_interface_table *iface)
{
NTSTATUS status;
@@ -79,19 +115,27 @@ static void test_scan_call(TALLOC_CTX *mem_ctx, const struct dcerpc_interface_ta
int i;
NTSTATUS status;
struct dcerpc_pipe *p = NULL;
+ struct policy_handle handle;
reopen(&p, iface);
+ get_policy_handle(p, mem_ctx, &handle);
+
/* work out the minimum amount of input data */
- for (i=0;i<100;i++) {
+ for (i=0;i<2000;i++) {
stub_in = data_blob(NULL, i);
data_blob_clear(&stub_in);
+#if 1
+ fill_blob_handle(&stub_in, mem_ctx, &handle);
+#endif
+
status = dcerpc_request(p, opnum, mem_ctx, &stub_in, &stub_out);
if (NT_STATUS_IS_OK(status)) {
printf("opnum %d min_input %d - output %d\n",
opnum, stub_in.length, stub_out.length);
+ dump_data(0, stub_out.data, stub_out.length);
dcerpc_pipe_close(p);
test_ptr_scan(mem_ctx, iface, opnum, stub_in.length);
return;
@@ -115,21 +159,15 @@ static void test_scan_call(TALLOC_CTX *mem_ctx, const struct dcerpc_interface_ta
static void test_auto_scan(TALLOC_CTX *mem_ctx, const struct dcerpc_interface_table *iface)
{
- int i;
- for (i=0;i<100;i++) {
- test_scan_call(mem_ctx, iface, i);
- }
+ test_scan_call(mem_ctx, iface, 0x26);
}
BOOL torture_rpc_autoidl(int dummy)
{
- NTSTATUS status;
TALLOC_CTX *mem_ctx;
const struct dcerpc_interface_table *iface;
- char *host = lp_parm_string(-1, "torture", "host");
- char *transport = lp_parm_string(-1, "torture", "transport");
- iface = idl_iface_by_name("browser");
+ iface = idl_iface_by_name("samr");
if (!iface) {
printf("Unknown interface!\n");
return False;
@@ -139,16 +177,6 @@ BOOL torture_rpc_autoidl(int dummy)
printf("\nProbing pipe '%s'\n", iface->name);
- /* on TCP we need to find the right endpoint */
- if (strcasecmp(transport, "ncacn_ip_tcp") == 0) {
- uint32 port;
- status = dcerpc_epm_map_tcp_port(host, iface->uuid, iface->if_version, &port);
- if (!NT_STATUS_IS_OK(status)) {
- return False;
- }
- lp_set_cmdline("torture:share", talloc_asprintf(mem_ctx, "%u", port));
- }
-
test_auto_scan(mem_ctx, iface);
return True;