[SCM] Samba Shared Repository - branch master updated

Günther Deschner gd at samba.org
Wed Dec 9 07:35:14 MST 2009


The branch, master has been updated
       via  d2f13dd... s4-smbtorture: enhance spoolss_EnumPrinterKey torture test.
      from  c7e3a2d... s3: check for PAM_RADIO_TYPE.

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master


- Log -----------------------------------------------------------------
commit d2f13dd6882079f82d45847eda72c75d6de55a21
Author: Günther Deschner <gd at samba.org>
Date:   Wed Dec 9 15:31:51 2009 +0100

    s4-smbtorture: enhance spoolss_EnumPrinterKey torture test.
    
    This demonstrates that s3 still does not have that call implemented correctly.
    
    Guenther

-----------------------------------------------------------------------

Summary of changes:
 source4/torture/rpc/spoolss.c |   40 ++++++++++++++++++++++++++--------------
 1 files changed, 26 insertions(+), 14 deletions(-)


Changeset truncated at 500 lines:

diff --git a/source4/torture/rpc/spoolss.c b/source4/torture/rpc/spoolss.c
index 1b3f8d1..7468278 100644
--- a/source4/torture/rpc/spoolss.c
+++ b/source4/torture/rpc/spoolss.c
@@ -3354,30 +3354,42 @@ static bool test_EnumPrinterKey(struct torture_context *tctx,
 	struct spoolss_EnumPrinterKey r;
 	uint32_t needed;
 	struct spoolss_StringArray2 key_buffer;
+	uint32_t offered[] = { 0, 512, 1024, 2048 };
+	int i;
 
 	r.in.handle = handle;
 	r.in.key_name = key_name;
-	r.in.offered = 0;
 	r.out.key_buffer = &key_buffer;
 	r.out.needed = &needed;
 
-	torture_comment(tctx, "Testing EnumPrinterKey(%s)\n", r.in.key_name);
+	for (i=0; i < ARRAY_SIZE(offered); i++) {
+		r.in.offered = offered[i];
+
+		torture_comment(tctx, "Testing EnumPrinterKey(%s) with %d offered\n", r.in.key_name, r.in.offered);
 
-	torture_assert_ntstatus_ok(tctx, dcerpc_spoolss_EnumPrinterKey(p, tctx, &r),
-		"failed to call EnumPrinterKey");
-	if (W_ERROR_EQUAL(r.out.result, WERR_MORE_DATA)) {
-		torture_assert(tctx, (key_buffer._ndr_size == 0),
-			talloc_asprintf(tctx, "EnumPrinterKey did not return 0 _ndr_size (but %d), windows clients would abort here!", key_buffer._ndr_size));
-		r.in.offered = needed;
 		torture_assert_ntstatus_ok(tctx, dcerpc_spoolss_EnumPrinterKey(p, tctx, &r),
 			"failed to call EnumPrinterKey");
-	}
-	torture_assert_werr_ok(tctx, r.out.result,
-		"failed to call EnumPrinterKey");
+		if (W_ERROR_EQUAL(r.out.result, WERR_MORE_DATA)) {
+			torture_assert(tctx, (key_buffer._ndr_size == 0),
+				talloc_asprintf(tctx, "EnumPrinterKey did not return 0 _ndr_size (but %d), windows clients would abort here!", key_buffer._ndr_size));
+			r.in.offered = needed;
+			torture_assert_ntstatus_ok(tctx, dcerpc_spoolss_EnumPrinterKey(p, tctx, &r),
+				"failed to call EnumPrinterKey");
+		}
+		torture_assert_werr_ok(tctx, r.out.result,
+			"failed to call EnumPrinterKey");
+
+		torture_assert(tctx, (key_buffer._ndr_size * 2 == r.in.offered),
+			talloc_asprintf(tctx, "EnumPrinterKey size mismatch, _ndr_size %d (expected %d)",
+				key_buffer._ndr_size, r.in.offered/2));
 
-	torture_assert(tctx, (key_buffer._ndr_size * 2 == needed),
-		talloc_asprintf(tctx, "EnumPrinterKey size mismatch, _ndr_size %d (expected %d)",
-		key_buffer._ndr_size, needed/2));
+		torture_assert(tctx, (*r.out.needed <= r.in.offered),
+			talloc_asprintf(tctx, "EnumPrinterKey size mismatch: needed %d is not <= offered %d", *r.out.needed, r.in.offered));
+
+		torture_assert(tctx, (*r.out.needed <= key_buffer._ndr_size * 2),
+			talloc_asprintf(tctx, "EnumPrinterKey size mismatch: needed %d is not <= _ndr_size %d * 2", *r.out.needed, key_buffer._ndr_size));
+
+	}
 
 	if (array) {
 		*array = key_buffer.string;


-- 
Samba Shared Repository


More information about the samba-cvs mailing list