From 582847412a1f4d7d971b96551cd07ff738e9ff82 Mon Sep 17 00:00:00 2001 From: Günther Deschner Date: Tue, 1 Jun 2010 16:46:37 +0200 Subject: s4-smbtorture: Make sure RPC-SPOOLSS and RPC-SPOOLSS-PRINTER pass against s3. Printjobs are extremely fragile beasts on paused virtual printers within make test. Very often the printq updater in the background is not fast enough, so subsequent tests don't get to the updated information. Something to remember and to work on later... Guenther --- source4/torture/rpc/spoolss.c | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/source4/torture/rpc/spoolss.c b/source4/torture/rpc/spoolss.c index d5b0f0ea77..233d6e7ec8 100644 --- a/source4/torture/rpc/spoolss.c +++ b/source4/torture/rpc/spoolss.c @@ -3258,6 +3258,35 @@ static bool test_DoPrintTest(struct torture_context *tctx, uint32_t *job_ids; int i; + torture_comment(tctx, "Testing real print operations\n"); + + job_ids = talloc_zero_array(tctx, uint32_t, num_jobs); + + for (i=0; i < num_jobs; i++) { + ret &= test_DoPrintTest_add_one_job(tctx, b, handle, &job_ids[i]); + } + + for (i=0; i < num_jobs; i++) { + ret &= test_SetJob(tctx, b, handle, job_ids[i], NULL, SPOOLSS_JOB_CONTROL_DELETE); + } + + if (ret == true) { + torture_comment(tctx, "real print operations test succeeded\n\n"); + } + + return ret; +} + +static bool test_DoPrintTest_extended(struct torture_context *tctx, + struct dcerpc_binding_handle *b, + struct policy_handle *handle) +{ + bool ret = true; + uint32_t num_jobs = 8; + uint32_t *job_ids; + int i; + torture_comment(tctx, "Testing real print operations (extended)\n"); + job_ids = talloc_zero_array(tctx, uint32_t, num_jobs); for (i=0; i < num_jobs; i++) { @@ -3270,6 +3299,10 @@ static bool test_DoPrintTest(struct torture_context *tctx, ret &= test_SetJob(tctx, b, handle, job_ids[i], NULL, SPOOLSS_JOB_CONTROL_DELETE); } + if (ret == true) { + torture_comment(tctx, "real print operations (extended) test succeeded\n\n"); + } + return ret; } @@ -6347,6 +6380,10 @@ static bool test_one_printer(struct torture_context *tctx, ret = false; } + if (!test_DoPrintTest_extended(tctx, b, handle)) { + torture_comment(tctx, "extended printing test failed!\n"); + } + if (!test_ResumePrinter(tctx, b, handle)) { ret = false; } -- cgit v1.2.3