1
0
mirror of https://github.com/samba-team/samba.git synced 2024-12-27 03:21:53 +03:00
samba-mirror/source4/torture/rpc/atsvc.c
Andrew Tridgell 86a604429e a fairly major upgrade to the dcerpc system
* added a NDR validator. The way it works is that when the
   DCERPC_DEBUG_VALIDATE_* flags are set the dcerpc system will
   perform NDR buffer validation. On sending a request the packet is
   first marshalled, then unmarahslled, then marshalled again, and it is
   confirmed that the two marshalling results are idential. This
   ensures that our pull and push routines are absolutely in sync, so
   that we can be very confident that if a routine works in the client
   then the corresponding routine must work on the server side. A
   similar validation is performed on all replies.

 * a result of this change is that pidl is fussier about the [ref]
   tag. You can only use it on pointers (which is the only place it
   makes sense)

 * fixed a basic alignment bug in the push side of the NDR code

 * added server side pull/push support. Our dcerpc system is now fully
   ready to be used on the server side.

 * fixed the relative offset pointer list. It must be traversed in
   reverse order on push

 * added automatic value setting for the size parameter in outgoing
   SdBuf structures.

 * expanded the ndr debugging code to always give a message on any
   failure

 * fixed the subcontext push code

 * fixed some memory leaks in smbtorture RPC tests
(This used to be commit 8ecf720206)
2003-11-22 08:11:32 +00:00

168 lines
3.8 KiB
C

/*
Unix SMB/CIFS implementation.
test suite for atsvc rpc operations
Copyright (C) Tim Potter 2003
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 2 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, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include "includes.h"
static BOOL test_JobGetInfo(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx, uint32 job_id)
{
NTSTATUS status;
struct atsvc_JobGetInfo r;
r.in.servername = dcerpc_server_name(p);
r.in.job_id = job_id;
status = dcerpc_atsvc_JobGetInfo(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("JobGetInfo failed - %s\n", nt_errstr(status));
return False;
}
return True;
}
static BOOL test_JobDel(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx, uint32 min_job_id,
uint32 max_job_id)
{
NTSTATUS status;
struct atsvc_JobDel r;
r.in.servername = dcerpc_server_name(p);
r.in.min_job_id = min_job_id;
r.in.max_job_id = max_job_id;
status = dcerpc_atsvc_JobDel(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("JobDel failed - %s\n", nt_errstr(status));
return False;
}
return True;
}
static BOOL test_JobEnum(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct atsvc_JobEnum r;
struct atsvc_enum_ctr ctr;
uint32 resume_handle = 0, i;
BOOL ret = True;
printf("\ntesting JobEnum\n");
r.in.servername = dcerpc_server_name(p);
ctr.entries_read = 0;
ctr.first_entry = NULL;
r.in.ctr = r.out.ctr = &ctr;
r.in.preferred_max_len = 0xffffffff;
r.in.resume_handle = r.out.resume_handle = &resume_handle;
status = dcerpc_atsvc_JobEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("JobEnum failed - %s\n", nt_errstr(status));
return False;
}
for (i = 0; r.out.ctr && i < r.out.ctr->entries_read; i++) {
if (!test_JobGetInfo(p, mem_ctx, r.out.ctr->first_entry[i].job_id)) {
ret = False;
}
}
return ret;
}
static BOOL test_JobAdd(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct atsvc_JobAdd r;
struct atsvc_JobInfo info;
printf("\ntesting JobAdd\n");
r.in.servername = dcerpc_server_name(p);
info.job_time = 0x050ae4c0; /* 11:30pm */
info.days_of_month = 0; /* n/a */
info.days_of_week = 0x02; /* Tuesday */
info.flags = 0x11; /* periodic, non-interactive */
info.command = "foo.exe";
r.in.job_info = &info;
status = dcerpc_atsvc_JobAdd(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("JobAdd failed - %s\n", nt_errstr(status));
return False;
}
/* Run EnumJobs again in case there were no jobs to begin with */
if (!test_JobEnum(p, mem_ctx)) {
return False;
}
if (!test_JobGetInfo(p, mem_ctx, r.out.job_id)) {
return False;
}
if (!test_JobDel(p, mem_ctx, r.out.job_id, r.out.job_id)) {
return False;
}
return True;
}
BOOL torture_rpc_atsvc(int dummy)
{
NTSTATUS status;
struct dcerpc_pipe *p;
TALLOC_CTX *mem_ctx;
BOOL ret = True;
mem_ctx = talloc_init("torture_rpc_atsvc");
status = torture_rpc_connection(&p,
DCERPC_ATSVC_NAME,
DCERPC_ATSVC_UUID,
DCERPC_ATSVC_VERSION);
if (!NT_STATUS_IS_OK(status)) {
return False;
}
p->flags |= DCERPC_DEBUG_PRINT_BOTH;
if (!test_JobEnum(p, mem_ctx)) {
return False;
}
if (!test_JobAdd(p, mem_ctx)) {
return False;
}
talloc_destroy(mem_ctx);
torture_rpc_close(p);
return ret;
}