mirror of
https://github.com/samba-team/samba.git
synced 2024-12-29 11:21:54 +03:00
r26142: Cleanup IDL and add torture test for wkssvc_NetWkstaEnumUsers.
Guenther
(This used to be commit 638ce91b0f
)
This commit is contained in:
parent
98c3f90cae
commit
ce0af45ef1
@ -152,39 +152,42 @@ import "srvsvc.idl";
|
||||
/*****************************/
|
||||
/* Function 0x02 */
|
||||
typedef struct {
|
||||
[string,charset(UTF16)] uint16 *user;
|
||||
} USER_INFO_0;
|
||||
[string,charset(UTF16)] uint16 *user_name;
|
||||
} wkssvc_NetrWkstaUserInfo0;
|
||||
|
||||
typedef struct {
|
||||
uint32 entries_read;
|
||||
[size_is(entries_read)] USER_INFO_0 *user0;
|
||||
} USER_INFO_0_CONTAINER;
|
||||
[size_is(entries_read)] wkssvc_NetrWkstaUserInfo0 *user0;
|
||||
} wkssvc_NetWkstaEnumUsersCtr0;
|
||||
|
||||
typedef struct {
|
||||
[string,charset(UTF16)] uint16 *user_name;
|
||||
[string,charset(UTF16)] uint16 *logon_domain;
|
||||
[string,charset(UTF16)] uint16 *other_domains;
|
||||
[string,charset(UTF16)] uint16 *logon_server;
|
||||
} USER_INFO_1;
|
||||
} wkssvc_NetrWkstaUserInfo1;
|
||||
|
||||
typedef struct {
|
||||
uint32 entries_read;
|
||||
[size_is(entries_read)] USER_INFO_1 *user1;
|
||||
} USER_INFO_1_CONTAINER;
|
||||
[size_is(entries_read)] wkssvc_NetrWkstaUserInfo1 *user1;
|
||||
} wkssvc_NetWkstaEnumUsersCtr1;
|
||||
|
||||
typedef [switch_type(uint32)] union {
|
||||
[case(0)] USER_INFO_0_CONTAINER *user0;
|
||||
[case(1)] USER_INFO_1_CONTAINER *user1;
|
||||
} WKS_USER_ENUM_UNION;
|
||||
[case(0)] wkssvc_NetWkstaEnumUsersCtr0 *user0;
|
||||
[case(1)] wkssvc_NetWkstaEnumUsersCtr1 *user1;
|
||||
} wkssvc_NetWkstaEnumUsersCtr;
|
||||
|
||||
typedef struct {
|
||||
uint32 level;
|
||||
[switch_is(level)] wkssvc_NetWkstaEnumUsersCtr ctr;
|
||||
} wkssvc_NetWkstaEnumUsersInfo;
|
||||
|
||||
WERROR wkssvc_NetWkstaEnumUsers(
|
||||
[in] [string,charset(UTF16)] uint16 *server_name,
|
||||
[in] uint32 level,
|
||||
[in] [out] [ref] WKS_USER_ENUM_UNION *users,
|
||||
[in,out,ref] wkssvc_NetWkstaEnumUsersInfo *info,
|
||||
[in] uint32 prefmaxlen,
|
||||
[out] uint32 *entriesread,
|
||||
[out] uint32 *totalentries,
|
||||
[in] [out] [ref] uint32 *resumehandle
|
||||
[out,ref] uint32 *entries_read,
|
||||
[in,out] uint32 *resume_handle
|
||||
);
|
||||
|
||||
/*****************************/
|
||||
|
@ -77,6 +77,58 @@ static bool test_NetWkstaTransportEnum(struct torture_context *tctx,
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool test_NetWkstaEnumUsers(struct torture_context *tctx,
|
||||
struct dcerpc_pipe *p)
|
||||
{
|
||||
NTSTATUS status;
|
||||
struct wkssvc_NetWkstaEnumUsers r;
|
||||
uint32_t handle = 0;
|
||||
uint32_t entries_read = 0;
|
||||
struct wkssvc_NetWkstaEnumUsersInfo info;
|
||||
struct wkssvc_NetWkstaEnumUsersCtr0 *user0;
|
||||
struct wkssvc_NetWkstaEnumUsersCtr1 *user1;
|
||||
uint32_t levels[] = { 0, 1 };
|
||||
int i;
|
||||
|
||||
for (i=0; i<ARRAY_SIZE(levels); i++) {
|
||||
|
||||
ZERO_STRUCT(info);
|
||||
|
||||
info.level = levels[i];
|
||||
switch (info.level) {
|
||||
case 0:
|
||||
user0 = talloc_zero(tctx,
|
||||
struct wkssvc_NetWkstaEnumUsersCtr0);
|
||||
info.ctr.user0 = user0;
|
||||
break;
|
||||
case 1:
|
||||
user1 = talloc_zero(tctx,
|
||||
struct wkssvc_NetWkstaEnumUsersCtr1);
|
||||
info.ctr.user1 = user1;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
r.in.server_name = dcerpc_server_name(p);
|
||||
r.in.prefmaxlen = (uint32_t)-1;
|
||||
r.in.info = r.out.info = &info;
|
||||
r.in.resume_handle = r.out.resume_handle = &handle;
|
||||
|
||||
r.out.entries_read = &entries_read;
|
||||
|
||||
torture_comment(tctx, "testing NetWkstaEnumUsers level %u\n",
|
||||
levels[i]);
|
||||
|
||||
status = dcerpc_wkssvc_NetWkstaEnumUsers(p, tctx, &r);
|
||||
torture_assert_ntstatus_ok(tctx, status,
|
||||
"NetWkstaEnumUsers failed");
|
||||
torture_assert_werr_ok(tctx, r.out.result,
|
||||
"NetWkstaEnumUsers failed");
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
struct torture_suite *torture_rpc_wkssvc(TALLOC_CTX *mem_ctx)
|
||||
{
|
||||
struct torture_suite *suite;
|
||||
@ -86,8 +138,12 @@ struct torture_suite *torture_rpc_wkssvc(TALLOC_CTX *mem_ctx)
|
||||
tcase = torture_suite_add_rpc_iface_tcase(suite, "wkssvc",
|
||||
&ndr_table_wkssvc);
|
||||
|
||||
torture_rpc_tcase_add_test(tcase, "NetWkstaGetInfo", test_NetWkstaGetInfo);
|
||||
torture_rpc_tcase_add_test(tcase, "NetWkstaGetInfo",
|
||||
test_NetWkstaGetInfo);
|
||||
torture_rpc_tcase_add_test(tcase, "NetWkstaTransportEnum",
|
||||
test_NetWkstaTransportEnum);
|
||||
torture_rpc_tcase_add_test(tcase, "NetWkstaEnumUsers",
|
||||
test_NetWkstaEnumUsers);
|
||||
|
||||
return suite;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user