RegressionTests__FileStreamTest.st
author Claus Gittinger <cg@exept.de>
Tue, 11 May 1999 14:05:19 +0200
changeset 1 0ad7950613c8
parent 0 cce7631f99b0
child 30 22531aeb4ce5
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"{ NameSpace: RegressionTests }"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
Object subclass:#FileStreamTest
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
	instanceVariableNames:''
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
	classVariableNames:''
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	poolDictionaries:''
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
     7
	category:'Tests - Streams'
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
!FileStreamTest class methodsFor:'tests'!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
createTestFile
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
    "create a test file (100k size)"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
    |f bytes|
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 := 'testFile' asFilename writeStream binary.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
    bytes := ByteArray new:1024.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
    1 to:bytes size do:[:i |
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    21
	bytes at:i put:(i \\ 256).
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
    100 timesRepeat:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    25
	f nextPutAll:bytes.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
    f close.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
     self createTestFile
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
    "Created: / 12.8.1998 / 13:25:25 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
readFileExpecting:expect
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
    "read test file, expect n bytes"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    |f buffer n nRead|
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 := 'testFile' asFilename readStream binary.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    buffer := ByteArray new:128.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    n := 0.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
    [f atEnd] whileFalse:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    47
	nRead := f nextBytes:128 into:buffer.
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    48
	n := n + nRead.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    f close.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    expect ~~ n ifTrue:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    52
	self halt:('got <1p>; expected:<2p>' expandMacrosWith:n with:expect)
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    "Created: / 12.8.1998 / 13:29:41 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
    "Modified: / 12.8.1998 / 13:36:40 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
test1
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
    "read a file - check count read with files size."
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
    |sz|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
    self createTestFile.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
    sz := 'testFile' asFilename fileSize.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    self readFileExpecting:sz.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
     self test1
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    "Modified: / 12.8.1998 / 13:29:55 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
test2
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
    "read a file - check count read with files size.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
     Do this in 20 threads"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    |sz|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
    self createTestFile.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
    sz := 'testFile' asFilename fileSize.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
    20 timesRepeat:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
    88
	[self readFileExpecting:sz. 'done' printCR.] fork.
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
     self test2
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
    "Modified: / 12.8.1998 / 13:30:55 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
test3
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
    "read a file - check count read with files size.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
     Do this and interrupt the reading thread heavily"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
    |sz p count nLoop|
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
    nLoop := 1000.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
    self createTestFile.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
    sz := 'testFile' asFilename fileSize.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
    p := [
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
   111
	nLoop timesRepeat:[
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
   112
	    self readFileExpecting:sz.
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
   113
	].
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    ] forkAt:7.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
    count := 0.
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
    [p isDead] whileFalse:[
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
   118
	Delay waitForMilliseconds:10.
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
   119
	p interruptWith:[count := count + 1].
0
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    ].
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
    ('read file <1p> times; interrupted <2p> times' 
1
0ad7950613c8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
   122
	expandMacrosWith:nLoop with:count) printCR
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
     self test3
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
    "
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
    "Modified: / 12.8.1998 / 13:42:13 / cg"
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
! !
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
!FileStreamTest class methodsFor:'documentation'!
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
version
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
    ^ '$Header$'
cce7631f99b0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
! !