summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2000-01-08 11:37:45 +0000
committerAndrew Tridgell <tridge@samba.org>2000-01-08 11:37:45 +0000
commitc01663c1a941d867a148aed522e6735504c6f64b (patch)
tree7cf4d5842b0b4de35a587f14aad0022c860a8482
parentf2fc3a2dca56fcca71e0b677625d3cdb7946d5c1 (diff)
downloadsamba-c01663c1a941d867a148aed522e6735504c6f64b.tar.gz
samba-c01663c1a941d867a148aed522e6735504c6f64b.tar.bz2
samba-c01663c1a941d867a148aed522e6735504c6f64b.zip
extent smbtorture to test with both an exe file and a dat file
(This used to be commit dd2ce575047eb57288bff11669512132fd347fda)
-rw-r--r--source3/utils/torture.c80
1 files changed, 43 insertions, 37 deletions
diff --git a/source3/utils/torture.c b/source3/utils/torture.c
index e45f4cb568..4375cbe231 100644
--- a/source3/utils/torture.c
+++ b/source3/utils/torture.c
@@ -716,9 +716,9 @@ static void run_locktest3(int dummy)
static void run_denytest(int dummy)
{
static struct cli_state cli1, cli2;
- char *fname = "\\lockt1.lck";
int fnum1, fnum2;
- int d1, d2, o1, o2, x=0;
+ int f, d1, d2, o1, o2, x=0;
+ char *fnames[] = {"denytest.exe", "denytest.dat", NULL};
struct {
int v;
char *name;
@@ -747,49 +747,55 @@ static void run_denytest(int dummy)
printf("starting denytest\n");
- cli_unlink(&cli1, fname);
-
- fnum1 = cli_open(&cli1, fname, O_RDWR|O_CREAT, DENY_NONE);
- cli_write(&cli1, fnum1, 0, fname, 0, strlen(fname));
- cli_close(&cli1, fnum1);
-
- for (d1=0;deny_modes[d1].name;d1++) for (o1=0;open_modes[o1].name;o1++)
- for (d2=0;deny_modes[d2].name;d2++) for (o2=0;open_modes[o2].name;o2++) {
+ for (f=0;fnames[f];f++) {
+ cli_unlink(&cli1, fnames[f]);
- fnum1 = cli_open(&cli1, fname, open_modes[o1].v, deny_modes[d1].v);
- fnum2 = cli_open(&cli2, fname,
- open_modes[o2].v | O_CREAT,
- deny_modes[d2].v);
-
- printf("%8s %10s %8s %10s ",
- open_modes[o1].name,
- deny_modes[d1].name,
- open_modes[o2].name,
- deny_modes[d2].name);
+ fnum1 = cli_open(&cli1, fnames[f], O_RDWR|O_CREAT, DENY_NONE);
+ cli_write(&cli1, fnum1, 0, fnames[f], 0, strlen(fnames[f]));
+ cli_close(&cli1, fnum1);
- if (fnum1 == -1) {
- printf("X");
- } else if (fnum2 == -1) {
- printf("-");
- } else {
- if (cli_read(&cli2, fnum2, (void *)&x, 0, 1) == 1) {
- printf("R");
- }
- if (cli_write(&cli2, fnum2, 0, (void *)&x, 0, 1) == 1) {
- printf("W");
+ for (d1=0;deny_modes[d1].name;d1++)
+ for (o1=0;open_modes[o1].name;o1++)
+ for (d2=0;deny_modes[d2].name;d2++)
+ for (o2=0;open_modes[o2].name;o2++) {
+ fnum1 = cli_open(&cli1, fnames[f],
+ open_modes[o1].v,
+ deny_modes[d1].v);
+ fnum2 = cli_open(&cli2, fnames[f],
+ open_modes[o2].v,
+ deny_modes[d2].v);
+
+ printf("%s %8s %10s %8s %10s ",
+ fnames[f],
+ open_modes[o1].name,
+ deny_modes[d1].name,
+ open_modes[o2].name,
+ deny_modes[d2].name);
+
+ if (fnum1 == -1) {
+ printf("X");
+ } else if (fnum2 == -1) {
+ printf("-");
+ } else {
+ if (cli_read(&cli2, fnum2, (void *)&x, 0, 1) == 1) {
+ printf("R");
+ }
+ if (cli_write(&cli2, fnum2, 0, (void *)&x, 0, 1) == 1) {
+ printf("W");
+ }
}
- }
- printf("\n");
- cli_close(&cli1, fnum1);
- cli_close(&cli2, fnum2);
+ printf("\n");
+ cli_close(&cli1, fnum1);
+ cli_close(&cli2, fnum2);
+ }
+
+ cli_unlink(&cli1, fnames[f]);
}
- cli_unlink(&cli1, fname);
-
close_connection(&cli1);
close_connection(&cli2);
-
+
printf("finshed denytest\n");
}