s4-smbtorture: add test_netprintjobgetinfo().
authorGünther Deschner <gd@samba.org>
Fri, 30 Apr 2010 15:06:29 +0000 (17:06 +0200)
committerGünther Deschner <gd@samba.org>
Fri, 30 Apr 2010 15:06:59 +0000 (17:06 +0200)
Guenther

source4/torture/rap/printing.c

index cebacd42907bf19cbe9dbf3e1311b78b885b1b83..6161239b15165be98896eba84d2abd6983fccf0b 100644 (file)
@@ -302,6 +302,60 @@ static bool test_netprintjobenum_one(struct torture_context *tctx,
        return true;
 }
 
+static bool test_netprintjobgetinfo_byid(struct torture_context *tctx,
+                                        struct smbcli_state *cli,
+                                        uint16_t JobID)
+{
+       struct rap_NetPrintJobGetInfo r;
+       uint16_t levels[] = { 0, 1, 2 };
+       NTSTATUS status;
+       int i;
+
+       r.in.JobID = JobID;
+       r.in.bufsize = 8192;
+
+       for (i=0; i < ARRAY_SIZE(levels); i++) {
+
+               r.in.level = levels[i];
+
+               torture_comment(tctx, "Testing rap_NetPrintJobGetInfo(%d) level %d\n", r.in.JobID, r.in.level);
+
+               status = smbcli_rap_netprintjobgetinfo(cli->tree, lp_iconv_convenience(tctx->lp_ctx), tctx, &r);
+               if (!NT_STATUS_IS_OK(status)) {
+                       torture_warning(tctx, "smbcli_rap_netprintjobgetinfo failed with %s\n", nt_errstr(status));
+                       continue;
+               }
+       }
+
+       return true;
+}
+
+static bool test_netprintjobgetinfo_byqueue(struct torture_context *tctx,
+                                           struct smbcli_state *cli,
+                                           const char *PrintQueueName)
+{
+       struct rap_NetPrintJobEnum r;
+       int i;
+
+       r.in.PrintQueueName = PrintQueueName;
+       r.in.bufsize = 8192;
+       r.in.level = 0;
+
+       torture_assert_ntstatus_ok(tctx,
+               smbcli_rap_netprintjobenum(cli->tree, lp_iconv_convenience(tctx->lp_ctx), tctx, &r),
+               "failed to enumerate jobs");
+
+       for (i=0; i < r.out.count; i++) {
+
+               torture_assert(tctx,
+                       test_netprintjobgetinfo_byid(tctx, cli, r.out.info[i].info0.JobID),
+                       "failed to get job info");
+       }
+
+       return true;
+}
+
+
 static bool test_netprintjobenum(struct torture_context *tctx,
                                 struct smbcli_state *cli)
 {
@@ -327,6 +381,31 @@ static bool test_netprintjobenum(struct torture_context *tctx,
        return true;
 }
 
+static bool test_netprintjobgetinfo(struct torture_context *tctx,
+                                   struct smbcli_state *cli)
+{
+       struct rap_NetPrintQEnum r;
+       int i;
+
+       r.in.level = 5;
+       r.in.bufsize = 8192;
+
+       torture_assert_ntstatus_ok(tctx,
+               smbcli_rap_netprintqenum(cli->tree, lp_iconv_convenience(tctx->lp_ctx), tctx, &r),
+               "failed to enum printq");
+
+       for (i=0; i < r.out.count; i++) {
+
+               const char *printqname = r.out.info[i].info5.PrintQueueName;
+
+               torture_assert(tctx,
+                       test_netprintjobgetinfo_byqueue(tctx, cli, printqname),
+                       "failed to enumerate printjobs on print queue");
+       }
+
+       return true;
+}
+
 static bool test_rap_print(struct torture_context *tctx,
                           struct smbcli_state *cli)
 {
@@ -349,9 +428,10 @@ struct torture_suite *torture_rap_printing(TALLOC_CTX *mem_ctx)
        torture_suite_add_1smb_test(suite, "rap_print", test_rap_print);
        torture_suite_add_1smb_test(suite, "rap_printq_enum", test_netprintqenum);
        torture_suite_add_1smb_test(suite, "rap_printq_getinfo", test_netprintqgetinfo);
+       torture_suite_add_1smb_test(suite, "rap_printq", test_netprintq);
        torture_suite_add_1smb_test(suite, "rap_printjob_enum", test_netprintjobenum);
+       torture_suite_add_1smb_test(suite, "rap_printjob_getinfo", test_netprintjobgetinfo);
        torture_suite_add_1smb_test(suite, "rap_printjob", test_netprintjob);
-       torture_suite_add_1smb_test(suite, "rap_printq", test_netprintq);
 
        return suite;
 }