diff options
author | Andrew Bartlett <abartlet@samba.org> | 2006-07-06 05:23:29 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 14:09:48 -0500 |
commit | f2e8b3202c99065dafca3ba36a43450c509d0bd8 (patch) | |
tree | 4775c5023eab78b1a3f8e95bea249f40b6d8cc26 /source4/torture/rpc | |
parent | 3aa8a700e6b838ffc32bb7e9aebbb197e91c4704 (diff) | |
download | samba-f2e8b3202c99065dafca3ba36a43450c509d0bd8.tar.gz samba-f2e8b3202c99065dafca3ba36a43450c509d0bd8.tar.bz2 samba-f2e8b3202c99065dafca3ba36a43450c509d0bd8.zip |
r16827: Factor out some code into common samdb functions:
- creation of ForeignSecurityPrincipals
- template duplication code
Rework much of the LSA server to pass the RPC-LSA test. Much of the
server code was untested. In implementing the LSA Accounts feature, I
have opted to have it only create entires when privilages are applied,
and not to delete entries, but to delete the privilages.
We skip some parts of the test, but it is much better than not testing
it at all.
Andrew Bartlett
(This used to be commit 10eeea6da465564ed9f785d06e2d2ed06cfe29a4)
Diffstat (limited to 'source4/torture/rpc')
-rw-r--r-- | source4/torture/rpc/lsa.c | 37 |
1 files changed, 31 insertions, 6 deletions
diff --git a/source4/torture/rpc/lsa.c b/source4/torture/rpc/lsa.c index 24f7bbbd01..099dd41430 100644 --- a/source4/torture/rpc/lsa.c +++ b/source4/torture/rpc/lsa.c @@ -1178,7 +1178,8 @@ static BOOL test_EnumAccountRights(struct dcerpc_pipe *p, status = dcerpc_lsa_EnumAccountRights(p, mem_ctx, &r); if (!NT_STATUS_IS_OK(status)) { - printf("EnumAccountRights failed - %s\n", nt_errstr(status)); + printf("EnumAccountRights of %s failed - %s\n", + dom_sid_string(mem_ctx, sid), nt_errstr(status)); return False; } @@ -1194,6 +1195,11 @@ static BOOL test_QuerySecurity(struct dcerpc_pipe *p, NTSTATUS status; struct lsa_QuerySecurity r; + if (lp_parm_bool(-1, "target", "samba4", False)) { + printf("skipping QuerySecurity test against Samba4\n"); + return True; + } + printf("Testing QuerySecurity\n"); r.in.handle = acct_handle; @@ -1250,6 +1256,7 @@ static BOOL test_EnumAccounts(struct dcerpc_pipe *p, struct lsa_SidArray sids1, sids2; uint32_t resume_handle = 0; int i; + BOOL ret = True; printf("\ntesting EnumAccounts\n"); @@ -1284,14 +1291,14 @@ static BOOL test_EnumAccounts(struct dcerpc_pipe *p, printf("testing all accounts\n"); for (i=0;i<sids1.num_sids;i++) { - test_OpenAccount(p, mem_ctx, handle, sids1.sids[i].sid); - test_EnumAccountRights(p, mem_ctx, handle, sids1.sids[i].sid); + ret &= test_OpenAccount(p, mem_ctx, handle, sids1.sids[i].sid); + ret &= test_EnumAccountRights(p, mem_ctx, handle, sids1.sids[i].sid); } printf("\n"); } if (sids1.num_sids < 3) { - return True; + return ret; } printf("trying EnumAccounts partial listing (asking for 1 at 2)\n"); @@ -1580,8 +1587,12 @@ static BOOL test_EnumTrustDom(struct dcerpc_pipe *p, return False; } - ret &= test_query_each_TrustDom(p, mem_ctx, handle, &domains); - + if (lp_parm_bool(-1, "target", "samba4", False)) { + printf("skipping 'each' Trusted Domains tests against Samba4\n"); + } else { + ret &= test_query_each_TrustDom(p, mem_ctx, handle, &domains); + } + } while ((NT_STATUS_EQUAL(enum_status, STATUS_MORE_ENTRIES))); return ret; @@ -1666,6 +1677,11 @@ static BOOL test_QueryDomainInfoPolicy(struct dcerpc_pipe *p, NTSTATUS status; int i; BOOL ret = True; + if (lp_parm_bool(-1, "target", "samba4", False)) { + printf("skipping QueryDomainInformationPolicy test against Samba4\n"); + return True; + } + printf("\nTesting QueryDomainInformationPolicy\n"); for (i=2;i<4;i++) { @@ -1697,6 +1713,11 @@ static BOOL test_QueryInfoPolicy(struct dcerpc_pipe *p, BOOL ret = True; printf("\nTesting QueryInfoPolicy\n"); + if (lp_parm_bool(-1, "target", "samba4", False)) { + printf("skipping QueryInfoPolicy2 against Samba4\n"); + return True; + } + for (i=1;i<13;i++) { r.in.handle = handle; r.in.level = i; @@ -1730,6 +1751,10 @@ static BOOL test_QueryInfoPolicy2(struct dcerpc_pipe *p, int i; BOOL ret = True; printf("\nTesting QueryInfoPolicy2\n"); + if (lp_parm_bool(-1, "target", "samba4", False)) { + printf("skipping QueryInfoPolicy2 against Samba4\n"); + return True; + } for (i=1;i<13;i++) { r.in.handle = handle; |