diff options
author | Andrew Tridgell <tridge@samba.org> | 2004-09-01 23:36:22 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 12:58:29 -0500 |
commit | 01f704e5ecbf371e60640c45c7e9d3f66a5a9fe0 (patch) | |
tree | 9475fcc61c17ddce198958a3e4e1d5e5bec3b2b6 /source4 | |
parent | 3e454a5891b73c9b021406bdb662127e1a3180dc (diff) | |
download | samba-01f704e5ecbf371e60640c45c7e9d3f66a5a9fe0.tar.gz samba-01f704e5ecbf371e60640c45c7e9d3f66a5a9fe0.tar.bz2 samba-01f704e5ecbf371e60640c45c7e9d3f66a5a9fe0.zip |
r2179: two more lsa torture tests from Richard Renard. Thanks!
(This used to be commit 25f85efd75bd54ff142027a8741edaa94725ca9a)
Diffstat (limited to 'source4')
-rw-r--r-- | source4/torture/rpc/lsa.c | 71 |
1 files changed, 70 insertions, 1 deletions
diff --git a/source4/torture/rpc/lsa.c b/source4/torture/rpc/lsa.c index 5279393d59..5eaabce3cd 100644 --- a/source4/torture/rpc/lsa.c +++ b/source4/torture/rpc/lsa.c @@ -635,6 +635,66 @@ static BOOL test_EnumAccounts(struct dcerpc_pipe *p, return True; } +static BOOL test_LookupPrivDisplayName(struct dcerpc_pipe *p, + TALLOC_CTX *mem_ctx, + struct policy_handle *handle, + struct lsa_Name *priv_name) +{ + struct lsa_LookupPrivDisplayName r; + struct lsa_Name disp_name; + NTSTATUS status; + + ZERO_STRUCT(disp_name); + + printf("testing LookupPrivDisplayName(%s)\n", priv_name->name); + + r.in.handle = handle; + r.in.name = priv_name; + r.in.unknown = 0; + r.in.unknown2 = 0; + r.out.disp_name = &disp_name; + + status = dcerpc_lsa_LookupPrivDisplayName(p, mem_ctx, &r); + if (!NT_STATUS_IS_OK(status)) { + printf("LookupPrivDisplayName failed - %s\n", nt_errstr(status)); + return False; + } + + return True; +} + +static BOOL test_EnumAccountsWithUserRight(struct dcerpc_pipe *p, + TALLOC_CTX *mem_ctx, + struct policy_handle *handle, + struct lsa_Name *priv_name) +{ + struct lsa_EnumAccountsWithUserRight r; + struct lsa_SidArray sids; + NTSTATUS status; + + ZERO_STRUCT(sids); + + printf("testing EnumAccountsWithUserRight(%s)\n", priv_name->name); + + r.in.handle = handle; + r.in.name = priv_name; + r.out.sids = &sids; + + status = dcerpc_lsa_EnumAccountsWithUserRight(p, mem_ctx, &r); + + /* NT_STATUS_NO_MORE_ENTRIES means noone has this privilege */ + if (NT_STATUS_EQUAL(status, NT_STATUS_NO_MORE_ENTRIES)) { + return True; + } + + if (!NT_STATUS_IS_OK(status)) { + printf("EnumAccountsWithUserRight failed - %s\n", nt_errstr(status)); + return False; + } + + return True; +} + static BOOL test_EnumPrivs(struct dcerpc_pipe *p, TALLOC_CTX *mem_ctx, @@ -644,6 +704,8 @@ static BOOL test_EnumPrivs(struct dcerpc_pipe *p, struct lsa_EnumPrivs r; struct lsa_PrivArray privs1; uint32_t resume_handle = 0; + int i; + BOOL ret = True; printf("\ntesting EnumPrivs\n"); @@ -660,7 +722,14 @@ static BOOL test_EnumPrivs(struct dcerpc_pipe *p, return False; } - return True; + for (i = 0; i< privs1.count; i++) { + test_LookupPrivDisplayName(p, mem_ctx, handle, &privs1.privs[i].name); + if (!test_EnumAccountsWithUserRight(p, mem_ctx, handle, &privs1.privs[i].name)) { + ret = False; + } + } + + return ret; } |