1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-11 05:18:09 +03:00

s3:torture: add SMB2-ANONYMOUS which asserts no GUEST bit for anonymous

BUG: https://bugzilla.samba.org/show_bug.cgi?id=13328

Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Ralph Boehme <slow@samba.org>
This commit is contained in:
Stefan Metzmacher 2018-03-15 17:40:07 +01:00 committed by Ralph Boehme
parent c37fbfcb24
commit 82d8aa3b9c
3 changed files with 44 additions and 0 deletions

View File

@ -95,6 +95,7 @@ bool run_nttrans_create(int dummy);
bool run_nttrans_fsctl(int dummy); bool run_nttrans_fsctl(int dummy);
bool run_smb2_basic(int dummy); bool run_smb2_basic(int dummy);
bool run_smb2_negprot(int dummy); bool run_smb2_negprot(int dummy);
bool run_smb2_anonymous(int dummy);
bool run_smb2_session_reconnect(int dummy); bool run_smb2_session_reconnect(int dummy);
bool run_smb2_tcon_dependence(int dummy); bool run_smb2_tcon_dependence(int dummy);
bool run_smb2_multi_channel(int dummy); bool run_smb2_multi_channel(int dummy);

View File

@ -24,6 +24,7 @@
#include "../libcli/smb/smbXcli_base.h" #include "../libcli/smb/smbXcli_base.h"
#include "libcli/security/security.h" #include "libcli/security/security.h"
#include "libsmb/proto.h" #include "libsmb/proto.h"
#include "auth/credentials/credentials.h"
#include "auth/gensec/gensec.h" #include "auth/gensec/gensec.h"
#include "auth_generic.h" #include "auth_generic.h"
#include "../librpc/ndr/libndr.h" #include "../librpc/ndr/libndr.h"
@ -274,6 +275,47 @@ bool run_smb2_negprot(int dummy)
return true; return true;
} }
bool run_smb2_anonymous(int dummy)
{
struct cli_state *cli = NULL;
NTSTATUS status;
struct cli_credentials *anon_creds = NULL;
bool guest = false;
printf("Starting SMB2-ANONYMOUS\n");
if (!torture_init_connection(&cli)) {
return false;
}
status = smbXcli_negprot(cli->conn, cli->timeout,
PROTOCOL_SMB2_02, PROTOCOL_LATEST);
if (!NT_STATUS_IS_OK(status)) {
printf("smbXcli_negprot returned %s\n", nt_errstr(status));
return false;
}
anon_creds = cli_credentials_init_anon(talloc_tos());
if (anon_creds == NULL) {
printf("cli_credentials_init_anon failed\n");
return false;
}
status = cli_session_setup_creds(cli, anon_creds);
if (!NT_STATUS_IS_OK(status)) {
printf("cli_session_setup returned %s\n", nt_errstr(status));
return false;
}
guest = smbXcli_session_is_guest(cli->smb2.session);
if (guest) {
printf("anonymous session should not have guest authentication\n");
return false;
}
return true;
}
bool run_smb2_session_reconnect(int dummy) bool run_smb2_session_reconnect(int dummy)
{ {
struct cli_state *cli1; struct cli_state *cli1;

View File

@ -11588,6 +11588,7 @@ static struct {
{ "NOTIFY-ONLINE", run_notify_online }, { "NOTIFY-ONLINE", run_notify_online },
{ "SMB2-BASIC", run_smb2_basic }, { "SMB2-BASIC", run_smb2_basic },
{ "SMB2-NEGPROT", run_smb2_negprot }, { "SMB2-NEGPROT", run_smb2_negprot },
{ "SMB2-ANONYMOUS", run_smb2_anonymous },
{ "SMB2-SESSION-RECONNECT", run_smb2_session_reconnect }, { "SMB2-SESSION-RECONNECT", run_smb2_session_reconnect },
{ "SMB2-TCON-DEPENDENCE", run_smb2_tcon_dependence }, { "SMB2-TCON-DEPENDENCE", run_smb2_tcon_dependence },
{ "SMB2-MULTI-CHANNEL", run_smb2_multi_channel }, { "SMB2-MULTI-CHANNEL", run_smb2_multi_channel },