diff options
author | Günther Deschner <gd@samba.org> | 2010-04-23 11:27:51 +0200 |
---|---|---|
committer | Günther Deschner <gd@samba.org> | 2010-04-23 11:41:24 +0200 |
commit | 4be5d59c4f034ef9a125fe813e9e02ba5c2c833b (patch) | |
tree | 7380ae6f32d6ff9c7d3c7cf4e4e1ea3d91173936 /source4/torture/rpc | |
parent | c82fd3ed30ef2c804b6370d9d2ff1e1a6d2797f5 (diff) | |
download | samba-4be5d59c4f034ef9a125fe813e9e02ba5c2c833b.tar.gz samba-4be5d59c4f034ef9a125fe813e9e02ba5c2c833b.tar.bz2 samba-4be5d59c4f034ef9a125fe813e9e02ba5c2c833b.zip |
s4-smbtorture: allow to upload or remove any file belonging to a driver.
Guenther
Diffstat (limited to 'source4/torture/rpc')
-rw-r--r-- | source4/torture/rpc/spoolss.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/source4/torture/rpc/spoolss.c b/source4/torture/rpc/spoolss.c index 711f4df1e5..e4235f9ede 100644 --- a/source4/torture/rpc/spoolss.c +++ b/source4/torture/rpc/spoolss.c @@ -7116,6 +7116,10 @@ static bool upload_printer_driver_file(struct torture_context *tctx, const char *local_name = talloc_asprintf(tctx, "%s/%s", d->local.driver_directory, file_name); const char *remote_name = talloc_asprintf(tctx, "%s\\%s", remote_dir, file_name); + if (!file_name) { + return true; + } + torture_comment(tctx, "Uploading %s to %s\n", local_name, remote_name); fnum = smbcli_open(cli->tree, remote_name, O_RDWR|O_CREAT|O_TRUNC, DENY_NONE); @@ -7202,6 +7206,7 @@ static bool upload_printer_driver(struct torture_context *tctx, { struct smbcli_state *cli; const char *share_name = driver_directory_share(tctx, d->remote.driver_directory); + int i; torture_assert(tctx, connect_printer_driver_share(tctx, server_name, share_name, &cli), @@ -7219,6 +7224,16 @@ static bool upload_printer_driver(struct torture_context *tctx, torture_assert(tctx, upload_printer_driver_file(tctx, cli, d, d->info8.config_file), "failed to upload config_file"); + torture_assert(tctx, + upload_printer_driver_file(tctx, cli, d, d->info8.help_file), + "failed to upload help_file"); + if (d->info8.dependent_files) { + for (i=0; d->info8.dependent_files->string && d->info8.dependent_files->string[i] != NULL; i++) { + torture_assert(tctx, + upload_printer_driver_file(tctx, cli, d, d->info8.dependent_files->string[i]), + "failed to upload dependent_files"); + } + } talloc_free(cli); @@ -7233,6 +7248,10 @@ static bool remove_printer_driver_file(struct torture_context *tctx, const char *remote_name; const char *remote_dir = driver_directory_dir(d->remote.driver_directory); + if (!file_name) { + return true; + } + remote_name = talloc_asprintf(tctx, "%s\\%s", remote_dir, file_name); torture_comment(tctx, "Removing %s\n", remote_name); @@ -7250,6 +7269,7 @@ static bool remove_printer_driver(struct torture_context *tctx, { struct smbcli_state *cli; const char *share_name = driver_directory_share(tctx, d->remote.driver_directory); + int i; torture_assert(tctx, connect_printer_driver_share(tctx, server_name, share_name, &cli), @@ -7267,6 +7287,16 @@ static bool remove_printer_driver(struct torture_context *tctx, torture_assert(tctx, remove_printer_driver_file(tctx, cli, d, d->info8.config_file), "failed to remove config_file"); + torture_assert(tctx, + remove_printer_driver_file(tctx, cli, d, d->info8.help_file), + "failed to remove help_file"); + if (d->info8.dependent_files) { + for (i=0; d->info8.dependent_files->string && d->info8.dependent_files->string[i] != NULL; i++) { + torture_assert(tctx, + remove_printer_driver_file(tctx, cli, d, d->info8.dependent_files->string[i]), + "failed to remove dependent_files"); + } + } talloc_free(cli); |