From 8c3b54f01dfc7275c7ff0ec194cd68ea072a8186 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Fri, 22 Sep 2006 04:04:46 +0000 Subject: r18808: added SMB2-MAXWRITE test and SMB2-DIR tests expanded size of dangerous level for write in SMB2-CONNECT test (This used to be commit 355c6e78a91f4e934479829e722f873ca7e66baf) --- source4/torture/smb2/config.mk | 2 + source4/torture/smb2/connect.c | 9 ++- source4/torture/smb2/dir.c | 94 ++++++++++++++++++++++++++++++ source4/torture/smb2/maxwrite.c | 126 ++++++++++++++++++++++++++++++++++++++++ source4/torture/smb2/smb2.c | 2 + 5 files changed, 230 insertions(+), 3 deletions(-) create mode 100644 source4/torture/smb2/dir.c create mode 100644 source4/torture/smb2/maxwrite.c (limited to 'source4') diff --git a/source4/torture/smb2/config.mk b/source4/torture/smb2/config.mk index 6403f231f5..b24c1642a1 100644 --- a/source4/torture/smb2/config.mk +++ b/source4/torture/smb2/config.mk @@ -8,6 +8,8 @@ PRIVATE_PROTO_HEADER = \ proto.h OBJ_FILES = \ connect.o \ + dir.o \ + maxwrite.o \ scan.o \ util.o \ getinfo.o \ diff --git a/source4/torture/smb2/connect.c b/source4/torture/smb2/connect.c index 9f36e4d707..bb6ba0c39d 100644 --- a/source4/torture/smb2/connect.c +++ b/source4/torture/smb2/connect.c @@ -75,7 +75,7 @@ static NTSTATUS torture_smb2_write(struct smb2_tree *tree, struct smb2_handle ha int i; if (lp_parm_bool(-1, "torture", "dangerous", False)) { - data = data_blob_talloc(tree, NULL, 160000); + data = data_blob_talloc(tree, NULL, 16000000); } else if (lp_parm_bool(-1, "target", "samba4", False)) { data = data_blob_talloc(tree, NULL, UINT16_MAX); } else { @@ -90,6 +90,8 @@ static NTSTATUS torture_smb2_write(struct smb2_tree *tree, struct smb2_handle ha w.in.offset = 0; w.in.data = data; + printf("writing %d bytes\n", data.length); + status = smb2_write(tree, &w); if (!NT_STATUS_IS_OK(status)) { printf("write failed - %s\n", nt_errstr(status)); @@ -120,6 +122,8 @@ static NTSTATUS torture_smb2_write(struct smb2_tree *tree, struct smb2_handle ha r.in.length = data.length; r.in.offset = 0; + printf("reading %d bytes\n", data.length); + status = smb2_read(tree, tree, &r); if (!NT_STATUS_IS_OK(status)) { printf("read failed - %s\n", nt_errstr(status)); @@ -139,8 +143,7 @@ static NTSTATUS torture_smb2_write(struct smb2_tree *tree, struct smb2_handle ha /* send a create */ -static struct smb2_handle torture_smb2_create(struct smb2_tree *tree, - const char *fname) +struct smb2_handle torture_smb2_create(struct smb2_tree *tree, const char *fname) { struct smb2_create io; NTSTATUS status; diff --git a/source4/torture/smb2/dir.c b/source4/torture/smb2/dir.c new file mode 100644 index 0000000000..c30adb1e41 --- /dev/null +++ b/source4/torture/smb2/dir.c @@ -0,0 +1,94 @@ +/* + Unix SMB/CIFS implementation. + + SMB2 dir list test suite + + Copyright (C) Andrew Tridgell 2005 + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +*/ + +#include "includes.h" +#include "libcli/smb2/smb2.h" +#include "libcli/smb2/smb2_calls.h" + +#include "torture/torture.h" +#include "torture/smb2/proto.h" + +/* + test find continue +*/ +static BOOL torture_smb2_find_dir(struct smb2_tree *tree) +{ + struct smb2_handle handle; + NTSTATUS status; + int i; + struct smb2_find f; + BOOL ret = True; + union smb_search_data *d; + uint_t count; + + status = smb2_util_roothandle(tree, &handle); + if (!NT_STATUS_IS_OK(status)) { + return False; + } + + ZERO_STRUCT(f); + f.in.file.handle = handle; + f.in.pattern = "*"; + f.in.continue_flags = SMB2_CONTINUE_FLAG_SINGLE; + f.in.max_response_size = 0x100; + f.in.level = SMB2_FIND_BOTH_DIRECTORY_INFO; + + do { + status = smb2_find_level(tree, tree, &f, &count, &d); + if (!NT_STATUS_IS_OK(status)) { + printf("SMB2_FIND_ID_BOTH_DIRECTORY_INFO failed - %s\n", nt_errstr(status)); + break; + } + + printf("Got %d files\n", count); + for (i=0;i min) { + TALLOC_CTX *tmp_ctx = talloc_new(mem_ctx); + + + len = 1+(min+max)/2; + + ZERO_STRUCT(w); + w.in.file.handle = handle; + w.in.offset = 0; + w.in.data = data_blob_talloc(tmp_ctx, NULL, len); + + for (i=0;i