diff options
-rw-r--r-- | source4/librpc/idl/samr.idl | 6 | ||||
-rw-r--r-- | source4/torture/rpc/samr.c | 25 |
2 files changed, 30 insertions, 1 deletions
diff --git a/source4/librpc/idl/samr.idl b/source4/librpc/idl/samr.idl index 348d58bec4..14371f56ae 100644 --- a/source4/librpc/idl/samr.idl +++ b/source4/librpc/idl/samr.idl @@ -374,7 +374,11 @@ /************************/ /* Function 0x15 */ - NTSTATUS samr_SET_GROUPINFO(); + NTSTATUS samr_SetGroupInfo( + [in,ref] policy_handle *handle, + [in] uint16 level, + [in,switch_is(level),ref] samr_GroupInfo *info + ); /************************/ /* Function 0x16 */ diff --git a/source4/torture/rpc/samr.c b/source4/torture/rpc/samr.c index 6e593bc2c5..1e38b8ad70 100644 --- a/source4/torture/rpc/samr.c +++ b/source4/torture/rpc/samr.c @@ -859,7 +859,9 @@ static BOOL test_QueryGroupInfo(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx, { NTSTATUS status; struct samr_QueryGroupInfo r; + struct samr_SetGroupInfo s; uint16 levels[] = {1, 2, 3, 4}; + uint16 set_ok[] = {0, 1, 1, 1}; int i; BOOL ret = True; @@ -875,6 +877,29 @@ static BOOL test_QueryGroupInfo(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx, levels[i], nt_errstr(status)); ret = False; } + + printf("Testing SetGroupInfo level %u\n", levels[i]); + + s.in.handle = handle; + s.in.level = levels[i]; + s.in.info = r.out.info; + + status = dcerpc_samr_SetGroupInfo(p, mem_ctx, &s); + if (set_ok[i]) { + if (!NT_STATUS_IS_OK(status)) { + printf("SetGroupInfo level %u failed - %s\n", + r.in.level, nt_errstr(status)); + ret = False; + continue; + } + } else { + if (!NT_STATUS_EQUAL(NT_STATUS_INVALID_INFO_CLASS, status)) { + printf("SetGroupInfo level %u gave %s - should have been NT_STATUS_INVALID_INFO_CLASS\n", + r.in.level, nt_errstr(status)); + ret = False; + continue; + } + } } return ret; |