diff options
author | Andrew Tridgell <tridge@samba.org> | 2004-11-17 00:39:20 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2004-11-17 00:39:20 +0000 |
commit | 971cba0dd335d47e866c889b88a3964424a4efaf (patch) | |
tree | 303a6cc55123b91381af8c1cdd82c60abdb62cb6 /source/torture/raw/streams.c | |
parent | a6e719f262b55f7692fd4eda2cf2a8362c60dabd (diff) | |
download | samba-971cba0dd335d47e866c889b88a3964424a4efaf.tar.gz samba-971cba0dd335d47e866c889b88a3964424a4efaf.tar.xz samba-971cba0dd335d47e866c889b88a3964424a4efaf.zip |
r3793: add some streams tests that show how the :$DATA suffix is handled
Diffstat (limited to 'source/torture/raw/streams.c')
-rw-r--r-- | source/torture/raw/streams.c | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/source/torture/raw/streams.c b/source/torture/raw/streams.c index 4614367abf1..239955fd931 100644 --- a/source/torture/raw/streams.c +++ b/source/torture/raw/streams.c @@ -98,10 +98,11 @@ static BOOL test_stream_io(struct smbcli_state *cli, TALLOC_CTX *mem_ctx) const char *fname = BASEDIR "\\stream.txt"; const char *sname1, *sname2; BOOL ret = True; - int fnum, fnum2; + int fnum; ssize_t retsize; sname1 = talloc_asprintf(mem_ctx, "%s:%s", fname, "Stream One"); + sname2 = talloc_asprintf(mem_ctx, "%s:%s:$DaTa", fname, "Second Stream"); printf("opening non-existant directory stream\n"); io.generic.level = RAW_OPEN_NTCREATEX; @@ -149,7 +150,28 @@ static BOOL test_stream_io(struct smbcli_state *cli, TALLOC_CTX *mem_ctx) smbcli_close(cli->tree, fnum); + ret &= check_stream(cli, mem_ctx, fname, "Stream One:$FOO", NULL); + + printf("creating a stream2 on a existing file\n"); + io.ntcreatex.in.fname = sname2; + io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF; + status = smb_raw_open(cli->tree, mem_ctx, &io); + CHECK_STATUS(status, NT_STATUS_OK); + fnum = io.ntcreatex.out.fnum; + + printf("modifying stream\n"); + retsize = smbcli_write(cli->tree, fnum, 0, "SECOND STREAM", 0, 13); + CHECK_VALUE(retsize, 13); + + smbcli_close(cli->tree, fnum); + ret &= check_stream(cli, mem_ctx, fname, "Stream One", "test MORE DATA "); + ret &= check_stream(cli, mem_ctx, fname, "Stream One:$DATA", "test MORE DATA "); + ret &= check_stream(cli, mem_ctx, fname, "Stream One:", NULL); + ret &= check_stream(cli, mem_ctx, fname, "Second Stream", "SECOND STREAM"); + ret &= check_stream(cli, mem_ctx, fname, "Second Stream:$DATA", "SECOND STREAM"); + ret &= check_stream(cli, mem_ctx, fname, "Second Stream:", NULL); + ret &= check_stream(cli, mem_ctx, fname, "Second Stream:$FOO", NULL); printf("deleting stream\n"); status = smbcli_unlink(cli->tree, sname1); |