RegressionTests__FileStreamTest.st
author Claus Gittinger <cg@exept.de>
Tue, 11 Dec 2001 16:31:26 +0100
changeset 119 11246c09ec93
parent 118 2618cf1cd493
child 120 01f2cb81dc38
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
69
ffbf7492f5e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 59
diff changeset
     1
"{ Package: 'exept:regression' }"
ffbf7492f5e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 59
diff changeset
     2
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"{ NameSpace: RegressionTests }"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
118
2618cf1cd493 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 76
diff changeset
     5
TestCase subclass:#FileStreamTest
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	instanceVariableNames:''
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
	classVariableNames:''
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	poolDictionaries:''
59
5dfe7fc71559 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 30
diff changeset
     9
	category:'Tests-Regression'
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
118
2618cf1cd493 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 76
diff changeset
    13
!FileStreamTest methodsFor:'tests'!
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
createTestFile
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
    "create a test file (100k size)"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
    |f bytes|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
    f := 'testFile' asFilename writeStream binary.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
    bytes := ByteArray new:1024.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
    1 to:bytes size do:[:i |
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    23
        bytes at:i put:(i \\ 256).
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
    100 timesRepeat:[
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    27
        f nextPutAll:bytes.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
    f close.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    33
     self new createTestFile
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
    "Created: / 12.8.1998 / 13:25:25 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
readFileExpecting:expect
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    "read test file, expect n bytes"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    |f buffer n nRead|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
    f := 'testFile' asFilename readStream binary.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    buffer := ByteArray new:128.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    n := 0.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    [f atEnd] whileFalse:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    49
	nRead := f nextBytes:128 into:buffer.
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    50
	n := n + nRead.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    f close.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
    expect ~~ n ifTrue:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    54
	self halt:('got <1p>; expected:<2p>' expandMacrosWith:n with:expect)
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    "Created: / 12.8.1998 / 13:29:41 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
    "Modified: / 12.8.1998 / 13:36:40 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    61
testAppend1
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    62
    "basic open for appending."
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    63
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    64
    |file s sz actualContents expectedContents|
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    65
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    66
    file := Filename newTemporary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    67
    s := file writeStream.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    68
    s binary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    69
    s nextPutAll:(1 to:100).
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    70
    s close.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    71
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    72
    sz := file fileSize.
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    73
    self should:[ sz = 100 ]. "/ size mismatch
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    74
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    75
    s := file appendingWriteStream.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    76
    s binary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    77
    s nextPutAll:(101 to:200).
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    78
    s close.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    79
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    80
    sz := file fileSize.
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    81
    self should:[ sz = 200 ]. "/ size mismatch
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    82
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    83
    actualContents := file binaryContentsOfEntireFile.
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    84
    expectedContents := (1 to:200) asByteArray.
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    85
    self should:[ (actualContents = expectedContents) ].   "/ contents mismatch
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    86
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    87
    file delete.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    88
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    89
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
    90
     self new testAppend1
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    91
    "
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    92
!
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    93
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    94
testOpenRead1
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    95
    "basic open for reading."
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    96
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    97
    |sz|
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    98
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
    99
    self createTestFile.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   100
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   101
    sz := 'testFile' asFilename fileSize.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   102
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   103
    self readFileExpecting:sz.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   104
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   105
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   106
     self new testOpenRead1
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   107
    "
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   108
!
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   109
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   110
testRead1
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
    "read a file - check count read with files size."
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
    |sz|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
    self createTestFile.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
    sz := 'testFile' asFilename fileSize.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
    self readFileExpecting:sz.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   122
     self new testRead1
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    "Modified: / 12.8.1998 / 13:29:55 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   128
testRead2
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    "read a file - check count read with files size.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
     Do this in 20 threads"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    |sz|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
    self createTestFile.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    sz := 'testFile' asFilename fileSize.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
    20 timesRepeat:[
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   139
        [self readFileExpecting:sz. 'done' printCR.] fork.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   143
     self new testRead2
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
    "Modified: / 12.8.1998 / 13:30:55 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   149
testRead3
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    "read a file - check count read with files size.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
     Do this and interrupt the reading thread heavily"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
    |sz p count nLoop|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
    nLoop := 1000.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    self createTestFile.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    sz := 'testFile' asFilename fileSize.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
    p := [
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   162
        nLoop timesRepeat:[
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   163
            self readFileExpecting:sz.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   164
        ].
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   165
    ] forkAt:7.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   166
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   167
    count := 0.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   168
    [p isDead] whileFalse:[
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   169
        Delay waitForMilliseconds:5.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   170
        p interruptWith:[count := count + 1].
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   171
    ].
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   172
    ('read file <1p> times; interrupted <2p> times' 
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   173
        expandMacrosWith:nLoop with:count) printCR
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   174
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   175
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   176
     self new testRead3
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   177
    "
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   178
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   179
    "Modified: / 12.8.1998 / 13:42:13 / cg"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   180
!
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   181
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   182
testReadCheckPipe4
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   183
    "readCheck a pipe.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   184
     Do this and interrupt the reading thread heavily"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   185
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   186
    | s p count nLoop|
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   187
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   188
    nLoop := 1000.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   189
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   190
    self createTestFile.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   191
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   192
    s := PipeStream readingFrom:'sleep 5'.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   193
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   194
    p := [
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   195
        s readWait.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   196
        'readWait finished' printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   197
    ] forkAt:7.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   198
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   199
    count := 0.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   200
    [p isDead] whileFalse:[
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   201
        Delay waitForMilliseconds:5.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   202
        p interruptWith:[count := count + 1].
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   203
    ].
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   204
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   205
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   206
    s close.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   207
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   208
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   209
     self new testReadCheckPipe4
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   210
    "
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   211
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   212
    "Modified: / 12.8.1998 / 13:42:13 / cg"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   213
!
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   214
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   215
testReadCheckPipe5
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   216
    "readCheck a pipe.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   217
     Do this and interrupt the reading thread heavily"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   218
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   219
    | s p count nLoop|
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   220
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   221
    nLoop := 1000.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   222
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   223
    self createTestFile.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   224
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   225
    s := PipeStream readingFrom:'sleep 5; echo hello'.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   226
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   227
    p := [
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   228
        s readWait.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   229
        'readWait finished' printCR.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
    ] forkAt:7.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
    count := 0.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
    [p isDead] whileFalse:[
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   234
        Delay waitForMilliseconds:5.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   235
        p interruptWith:[count := count + 1].
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
    ].
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   237
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   238
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   239
    s close.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   242
     self new testReadCheckPipe5
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   243
    "
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   244
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   245
    "Modified: / 12.8.1998 / 13:42:13 / cg"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   246
!
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   247
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   248
testReadPipe6
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   249
    "read a pipe.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   250
     Do this and interrupt the reading thread heavily"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   251
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   252
    | s p count nLoop|
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   253
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   254
    nLoop := 1000.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   255
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   256
    self createTestFile.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   257
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   258
    s := PipeStream readingFrom:'sleep 5'.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   259
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   260
    p := [
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   261
        'read: ' print. s nextLine printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   262
    ] forkAt:7.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   263
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   264
    count := 0.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   265
    [p isDead] whileFalse:[
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   266
        Delay waitForMilliseconds:5.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   267
        p interruptWith:[count := count + 1].
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   268
    ].
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   269
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   270
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   271
    s close.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   272
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   273
    "
119
11246c09ec93 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 118
diff changeset
   274
     self new testReadPipe6
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   275
    "
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   276
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   277
    "Modified: / 12.8.1998 / 13:42:13 / cg"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   278
!
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   279
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   280
testReadPipe7
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   281
    "read a pipe.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   282
     Do this and interrupt the reading thread heavily"
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   283
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   284
    |sz s p count nLoop|
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   285
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   286
    nLoop := 1000.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   287
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   288
    self createTestFile.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   289
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   290
    s := PipeStream readingFrom:'sleep 5; echo hello'.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   291
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   292
    p := [
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   293
        'read: ' print. s nextLine printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   294
    ] forkAt:7.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   295
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   296
    count := 0.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   297
    [p isDead] whileFalse:[
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   298
        Delay waitForMilliseconds:5.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   299
        p interruptWith:[count := count + 1].
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   300
    ].
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   301
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
30
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   302
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   303
    s close.
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   304
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   305
    "
22531aeb4ce5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1
diff changeset
   306
     self test7
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
    "Modified: / 12.8.1998 / 13:42:13 / cg"
75
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   310
!
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   311
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   312
testRewrite1
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   313
    "basic open for writing (with truncation)."
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   314
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   315
    |file s sz|
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   316
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   317
    file := Filename newTemporary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   318
    s := file writeStream.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   319
    s binary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   320
    s nextPutAll:(1 to:200).
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   321
    s close.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   322
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   323
    sz := file fileSize.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   324
    sz ~= 200 ifTrue:[self error:'size mismatch'].
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   325
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   326
    s := file writeStream.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   327
    s binary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   328
    s nextPutAll:(101 to:200).
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   329
    s close.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   330
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   331
    sz := file fileSize.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   332
    sz ~= 100 ifTrue:[self error:'size mismatch'].
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   333
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   334
    (file binaryContentsOfEntireFile ~= (101 to:200) asByteArray) ifTrue:[
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   335
        self error:'contents mismatch'
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   336
    ].
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   337
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   338
    file delete.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   339
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   340
    "
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   341
     self testRewrite1
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   342
    "
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   343
!
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   344
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   345
testRewrite2
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   346
    "basic open for re-writing (without truncation)."
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   347
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   348
    |file s sz|
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   349
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   350
    file := Filename newTemporary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   351
    s := file writeStream.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   352
    s binary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   353
    s nextPutAll:(1 to:200).
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   354
    s close.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   355
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   356
    sz := file fileSize.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   357
    sz ~= 200 ifTrue:[self error:'size mismatch'].
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   358
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   359
    s := file readWriteStream.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   360
    s binary.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   361
    s nextPutAll:(101 to:200).
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   362
    s close.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   363
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   364
    sz := file fileSize.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   365
    sz ~= 200 ifTrue:[self error:'size mismatch'].
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   366
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   367
    (file binaryContentsOfEntireFile ~= 
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   368
        ((101 to:200) asByteArray , (101 to:200) asByteArray)) ifTrue:[
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   369
        self error:'contents mismatch'
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   370
    ].
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   371
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   372
    file delete.
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   373
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   374
    "
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   375
     self testRewrite2
1a7d48169a36 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 69
diff changeset
   376
    "
76
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   377
!
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   378
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   379
testWrite1
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   380
    "basic writing"
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   381
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   382
    self testWrite:1024.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   383
    self testWrite:2048.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   384
    self testWrite:4096.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   385
    self testWrite:8192.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   386
    self testWrite:8192*2.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   387
    self testWrite:8192*4.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   388
    self testWrite:8192*8.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   389
    self testWrite:8192*16.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   390
    self testWrite:8192*32.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   391
    self testWrite:8192*64.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   392
    self testWrite:8192*128.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   393
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   394
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   395
     self testWrite1
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   396
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   397
!
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   398
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   399
testWrite2
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   400
    "basic writing"
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   401
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   402
    10 timesRepeat:[
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   403
        self testWrite1.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   404
    ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   405
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   406
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   407
     self testWrite2
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   408
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   409
!
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   410
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   411
testWrite3
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   412
    "basic writing"
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   413
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   414
    |interruptor|
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   415
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   416
    interruptor := [
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   417
        [true] whileTrue:[
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   418
            Delay waitForMilliseconds:10.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   419
        ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   420
    ] forkAt:9.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   421
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   422
    [
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   423
        50 timesRepeat:[
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   424
            self testWrite1.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   425
        ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   426
    ] valueNowOrOnUnwindDo:[
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   427
        interruptor terminate
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   428
    ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   429
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   430
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   431
     self testWrite3
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   432
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   433
!
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   434
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   435
testWrite:size
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   436
    "basic writing"
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   437
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   438
    |file s sz buffer byte|
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   439
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   440
    buffer := ByteArray new:size.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   441
    1 to:buffer size do:[:idx |
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   442
        buffer at:idx put:(idx \\ 256)
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   443
    ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   444
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   445
    file := Filename newTemporary.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   446
    s := file writeStream.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   447
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   448
    s binary.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   449
    s nextPutAll:buffer.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   450
    s close.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   451
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   452
    sz := file fileSize.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   453
    sz ~= size ifTrue:[self error:'size mismatch'].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   454
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   455
    s := file readStream.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   456
    s binary.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   457
    1 to:size do:[:idx |
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   458
        byte := s next.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   459
        byte ~~ (idx \\ 256) ifTrue:[self error:'read data mismatch'].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   460
    ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   461
    s close.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   462
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   463
    (file binaryContentsOfEntireFile ~= buffer) ifTrue:[
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   464
        self error:'read data mismatch2'
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   465
    ].
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   466
    file delete.
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   467
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   468
    "
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   469
     self testWrite:1024
90adfa44fa2c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 75
diff changeset
   470
    "
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   471
! !
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   472
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   473
!FileStreamTest class methodsFor:'documentation'!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   474
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   475
version
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   476
    ^ '$Header$'
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   477
! !