[SCM] Samba Shared Repository - branch master updated
Günther Deschner
gd at samba.org
Fri Feb 19 07:28:58 MST 2010
The branch, master has been updated
via ec0aa8a... s4-smbtorture: more work on devicemode tests.
via 0e95a6a... s4-smbtorture: explain failure conditions in printer device mode tests a little more.
via f2ecec3... s4-smbtorture: add --option=torture:spoolss_check_size=yes.
from 299e5bc... s4-smbtorture: print more comments while running SD and DM tests in RPC-SPOOLSS-PRINTER.
http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master
- Log -----------------------------------------------------------------
commit ec0aa8a5c92c634ca3264b65c987b2072875df5c
Author: Günther Deschner <gd at samba.org>
Date: Fri Feb 19 15:25:42 2010 +0100
s4-smbtorture: more work on devicemode tests.
Guenther
commit 0e95a6a09cda6579be7d01c9e4c78f9f7f7cc54e
Author: Günther Deschner <gd at samba.org>
Date: Fri Feb 19 14:27:31 2010 +0100
s4-smbtorture: explain failure conditions in printer device mode tests a little more.
Guenther
commit f2ecec3dcdafd63cd72d13019a998bf99539a9ba
Author: Günther Deschner <gd at samba.org>
Date: Fri Feb 19 14:25:19 2010 +0100
s4-smbtorture: add --option=torture:spoolss_check_size=yes.
This disables the size calculation comparison by default.
Guenther
-----------------------------------------------------------------------
Summary of changes:
source4/torture/rpc/spoolss.c | 127 +++++++++++++++++++++++++++--------------
1 files changed, 85 insertions(+), 42 deletions(-)
Changeset truncated at 500 lines:
diff --git a/source4/torture/rpc/spoolss.c b/source4/torture/rpc/spoolss.c
index 6cc6727..0a915a7 100644
--- a/source4/torture/rpc/spoolss.c
+++ b/source4/torture/rpc/spoolss.c
@@ -120,30 +120,36 @@ struct test_spoolss_context {
#define DO_ROUND(size, n) (((size)+((n)-1)) & ~((n)-1))
#define CHECK_NEEDED_SIZE_ENUM_LEVEL(fn, info, level, count, ic, needed, align) do { \
+ if (torture_setting_bool(tctx, "spoolss_check_size", false)) {\
uint32_t size = ndr_size_##fn##_info(tctx, ic, level, count, info);\
uint32_t round_size = DO_ROUND(size, align);\
if (round_size != needed) {\
torture_warning(tctx, __location__": "#fn" level %d (count: %d) got unexpected needed size: %d, we calculated: %d", level, count, needed, round_size);\
CHECK_ALIGN(size, align);\
}\
+ }\
} while(0)
#define CHECK_NEEDED_SIZE_ENUM(fn, info, count, ic, needed, align) do { \
+ if (torture_setting_bool(tctx, "spoolss_check_size", false)) {\
uint32_t size = ndr_size_##fn##_info(tctx, ic, count, info);\
uint32_t round_size = DO_ROUND(size, align);\
if (round_size != needed) {\
torture_warning(tctx, __location__": "#fn" (count: %d) got unexpected needed size: %d, we calculated: %d", count, needed, round_size);\
CHECK_ALIGN(size, align);\
}\
+ }\
} while(0)
#define CHECK_NEEDED_SIZE_LEVEL(fn, info, level, ic, needed, align) do { \
+ if (torture_setting_bool(tctx, "spoolss_check_size", false)) {\
uint32_t size = ndr_size_##fn(info, level, ic, 0);\
uint32_t round_size = DO_ROUND(size, align);\
if (round_size != needed) {\
torture_warning(tctx, __location__": "#fn" level %d got unexpected needed size: %d, we calculated: %d", level, needed, round_size);\
CHECK_ALIGN(size, align);\
}\
+ }\
} while(0)
static bool test_OpenPrinter_server(struct torture_context *tctx,
@@ -1658,7 +1664,8 @@ static bool test_PrinterInfo_SDs(struct torture_context *tctx,
sd2 = info.info3.secdesc;
- torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2), "");
+ torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2),
+ "SD level 2 != SD level 3");
/* query level 2, set level 2, query level 2 */
@@ -1677,7 +1684,8 @@ static bool test_PrinterInfo_SDs(struct torture_context *tctx,
sd1->type &= ~SEC_DESC_DACL_DEFAULTED;
}
- torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2), "");
+ torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2),
+ "SD level 2 != SD level 2 after SD has been set via level 2");
/* query level 2, set level 3, query level 2 */
@@ -1692,8 +1700,8 @@ static bool test_PrinterInfo_SDs(struct torture_context *tctx,
sd2 = info.info2.secdesc;
- torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2), "");
-
+ torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2),
+ "SD level 2 != SD level 2 after SD has been set via level 3");
/* set modified sd level 3, query level 2 */
@@ -1718,7 +1726,9 @@ static bool test_PrinterInfo_SDs(struct torture_context *tctx,
sd1->type &= ~SEC_DESC_DACL_DEFAULTED;
}
- torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2), "");
+ torture_assert(tctx, test_security_descriptor_equal(tctx, sd1, sd2),
+ "modified SD level 2 != SD level 2 after SD has been set via level 3");
+
return true;
}
@@ -1910,82 +1920,113 @@ static bool test_PrinterInfo_DevModes(struct torture_context *tctx,
devmode2 = info.info2.devmode;
- torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2), "");
+ torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2),
+ "DM level 8 != DM level 2");
- /* change formname upon open and see if it persists in getprinter calls */
+ /* set devicemode level 8 and see if it persists */
- devmode->formname = talloc_strdup(tctx, "A4");
+ devmode->copies = 93;
+ devmode->formname = talloc_strdup(tctx, "Legal");
- torture_assert(tctx, call_OpenPrinterEx(tctx, p, name, devmode, &handle_devmode),
- "failed to open printer handle");
+ torture_assert(tctx, test_devmode_set_level(tctx, p, handle, 8, devmode), "");
- torture_assert(tctx, test_GetPrinter_level(tctx, p, &handle_devmode, 8, &info), "");
+ torture_assert(tctx, test_GetPrinter_level(tctx, p, handle, 8, &info), "");
devmode2 = info.info8.devmode;
- if (strequal(devmode->devicename, devmode2->devicename)) {
- torture_fail(tctx, "devicename is the same");
- }
-
- if (strequal(devmode->formname, devmode2->formname)) {
- torture_fail(tctx, "formname is the same");
- }
+ torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2),
+ "modified DM level 8 != DM level 8 after DM has been set via level 8");
- torture_assert(tctx, test_GetPrinter_level(tctx, p, &handle_devmode, 2, &info), "");
+ torture_assert(tctx, test_GetPrinter_level(tctx, p, handle, 2, &info), "");
devmode2 = info.info2.devmode;
- if (strequal(devmode->devicename, devmode2->devicename)) {
- torture_fail(tctx, "devicename is the same");
- }
+ torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2),
+ "modified DM level 8 != DM level 2");
- if (strequal(devmode->formname, devmode2->formname)) {
- torture_fail(tctx, "formname is the same");
- }
- test_ClosePrinter(tctx, p, &handle_devmode);
-
-
- /* set devicemode level 8 and see if it persists */
+ /* set devicemode level 2 and see if it persists */
- devmode->copies = 93;
- devmode->formname = talloc_strdup(tctx, "Legal");
+ devmode->copies = 39;
+ devmode->formname = talloc_strdup(tctx, "Executive");
- torture_assert(tctx, test_devmode_set_level(tctx, p, handle, 8, devmode), "");
+ torture_assert(tctx, test_devmode_set_level(tctx, p, handle, 2, devmode), "");
torture_assert(tctx, test_GetPrinter_level(tctx, p, handle, 8, &info), "");
devmode2 = info.info8.devmode;
- torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2), "");
+ torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2),
+ "modified DM level 8 != DM level 8 after DM has been set via level 2");
torture_assert(tctx, test_GetPrinter_level(tctx, p, handle, 2, &info), "");
devmode2 = info.info2.devmode;
- torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2), "");
+ torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2),
+ "modified DM level 8 != DM level 2");
- /* set devicemode level 2 and see if it persists */
+ /* change formname upon open and see if it persists in getprinter calls */
- devmode->copies = 39;
- devmode->formname = talloc_strdup(tctx, "Letter");
+ devmode->formname = talloc_strdup(tctx, "A4");
+ devmode->copies = 42;
- torture_assert(tctx, test_devmode_set_level(tctx, p, handle, 8, devmode), "");
+ torture_assert(tctx, call_OpenPrinterEx(tctx, p, name, devmode, &handle_devmode),
+ "failed to open printer handle");
- torture_assert(tctx, test_GetPrinter_level(tctx, p, handle, 8, &info), "");
+ torture_assert(tctx, test_GetPrinter_level(tctx, p, &handle_devmode, 8, &info), "");
devmode2 = info.info8.devmode;
- torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2), "");
+ if (strequal(devmode->devicename, devmode2->devicename)) {
+ torture_comment(tctx, "devicenames are the same\n");
+ } else {
+ torture_comment(tctx, "devicename passed in for open: %s\n", devmode->devicename);
+ torture_comment(tctx, "devicename after level 8 get: %s\n", devmode2->devicename);
+ }
- torture_assert(tctx, test_GetPrinter_level(tctx, p, handle, 2, &info), "");
+ if (strequal(devmode->formname, devmode2->formname)) {
+ torture_warning(tctx, "formname are the same\n");
+ } else {
+ torture_comment(tctx, "formname passed in for open: %s\n", devmode->formname);
+ torture_comment(tctx, "formname after level 8 get: %s\n", devmode2->formname);
+ }
+
+ if (devmode->copies == devmode2->copies) {
+ torture_warning(tctx, "copies are the same\n");
+ } else {
+ torture_comment(tctx, "copies passed in for open: %d\n", devmode->copies);
+ torture_comment(tctx, "copies after level 8 get: %d\n", devmode2->copies);
+ }
+
+ torture_assert(tctx, test_GetPrinter_level(tctx, p, &handle_devmode, 2, &info), "");
devmode2 = info.info2.devmode;
- torture_assert(tctx, test_devicemode_equal(tctx, devmode, devmode2), "");
+ if (strequal(devmode->devicename, devmode2->devicename)) {
+ torture_comment(tctx, "devicenames are the same\n");
+ } else {
+ torture_comment(tctx, "devicename passed in for open: %s\n", devmode->devicename);
+ torture_comment(tctx, "devicename after level 2 get: %s\n", devmode2->devicename);
+ }
+ if (strequal(devmode->formname, devmode2->formname)) {
+ torture_warning(tctx, "formname is the same\n");
+ } else {
+ torture_comment(tctx, "formname passed in for open: %s\n", devmode->formname);
+ torture_comment(tctx, "formname after level 2 get: %s\n", devmode2->formname);
+ }
+
+ if (devmode->copies == devmode2->copies) {
+ torture_warning(tctx, "copies are the same\n");
+ } else {
+ torture_comment(tctx, "copies passed in for open: %d\n", devmode->copies);
+ torture_comment(tctx, "copies after level 2 get: %d\n", devmode2->copies);
+ }
+
+ test_ClosePrinter(tctx, p, &handle_devmode);
return true;
}
@@ -4318,6 +4359,8 @@ bool test_printer_keys(struct torture_context *tctx,
const char **key_array = NULL;
int i;
+ torture_comment(tctx, "\nTesting Printer Keys\n");
+
torture_assert(tctx, test_EnumPrinterKey(tctx, p, handle, "", &key_array),
"failed to call test_EnumPrinterKey");
--
Samba Shared Repository
More information about the samba-cvs
mailing list