mirror of
https://github.com/samba-team/samba.git
synced 2025-03-27 22:50:26 +03:00
s4-smbtorture: add test for rap_NetUserDelete().
Guenther
This commit is contained in:
parent
5def6f0eca
commit
9ef1a8cf4c
@ -10,3 +10,4 @@ samba3.raw.mux.* #This test is flaky on the async lock time
|
||||
samba3.smbtorture_s3.*OPLOCK4 # fails sometimes on sn-devel
|
||||
samba3.posix_s3.nbt.dgram.*netlogon2
|
||||
samba3.*rap.sam.*.useradd # Not provided by Samba 3
|
||||
samba3.*rap.sam.*.userdelete # Not provided by Samba 3
|
||||
|
@ -299,6 +299,54 @@ static bool test_useradd(struct torture_context *tctx,
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool test_userdelete(struct torture_context *tctx,
|
||||
struct smbcli_state *cli)
|
||||
{
|
||||
|
||||
struct rap_NetUserDelete r;
|
||||
|
||||
{
|
||||
struct rap_NetUserAdd a;
|
||||
const char *pwd;
|
||||
|
||||
ZERO_STRUCT(a.in.info.info1);
|
||||
|
||||
pwd = generate_random_password(tctx, 9, 16);
|
||||
|
||||
a.in.level = 1;
|
||||
a.in.bufsize = 0xffff;
|
||||
a.in.pwdlength = strlen(pwd);
|
||||
a.in.unknown = 0;
|
||||
a.in.info.info1.Name = TEST_RAP_USER;
|
||||
a.in.info.info1.Priv = USER_PRIV_USER;
|
||||
|
||||
memcpy(a.in.info.info1.Password, pwd, MIN(strlen(pwd), 16));
|
||||
|
||||
torture_assert_ntstatus_ok(tctx,
|
||||
smbcli_rap_netuseradd(cli->tree, tctx, &a),
|
||||
"smbcli_rap_netuseradd failed");
|
||||
}
|
||||
|
||||
r.in.UserName = TEST_RAP_USER;
|
||||
|
||||
torture_comment(tctx,
|
||||
"Testing rap_NetUserDelete(%s)\n", r.in.UserName);
|
||||
|
||||
torture_assert_ntstatus_ok(tctx,
|
||||
smbcli_rap_netuserdelete(cli->tree, tctx, &r),
|
||||
"smbcli_rap_netuserdelete failed");
|
||||
torture_assert_werr_ok(tctx, W_ERROR(r.out.status),
|
||||
"smbcli_rap_netuserdelete failed");
|
||||
|
||||
torture_assert_ntstatus_ok(tctx,
|
||||
smbcli_rap_netuserdelete(cli->tree, tctx, &r),
|
||||
"2nd smbcli_rap_netuserdelete failed");
|
||||
torture_assert_werr_equal(tctx, W_ERROR(r.out.status), WERR_USER_NOT_FOUND,
|
||||
"2nd smbcli_rap_netuserdelete failed");
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
struct torture_suite *torture_rap_sam(TALLOC_CTX *mem_ctx)
|
||||
{
|
||||
struct torture_suite *suite = torture_suite_create(mem_ctx, "sam");
|
||||
@ -307,6 +355,7 @@ struct torture_suite *torture_rap_sam(TALLOC_CTX *mem_ctx)
|
||||
torture_suite_add_1smb_test(suite, "oemchangepassword", test_oemchangepassword);
|
||||
torture_suite_add_1smb_test(suite, "usergetinfo", test_usergetinfo);
|
||||
torture_suite_add_1smb_test(suite, "useradd", test_useradd);
|
||||
torture_suite_add_1smb_test(suite, "userdelete", test_userdelete);
|
||||
|
||||
return suite;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user