RegressionTests__PipeStreamTest.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Thu, 27 Mar 2014 17:33:11 +0100
changeset 1110 a38d8f5208fd
parent 1109 ad8866ade273
child 1215 6c8217e7f690
permissions -rw-r--r--
class: RegressionTests::PipeStreamTest changed: #testPipeWriteRead - limit number of thread on Windows (there's limit in BCC5.5 libc)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"{ Package: 'exept:regression' }"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"{ NameSpace: RegressionTests }"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
TestCase subclass:#PipeStreamTest
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	instanceVariableNames:''
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
	classVariableNames:''
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	poolDictionaries:''
1082
a46d9682d459 category change
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
     9
	category:'tests-Regression-Streams'
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
!PipeStreamTest methodsFor:'tests'!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    15
testPipeWriteRead
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    16
    | makeReader makeWriter count threads ok blocker |
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    17
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    18
    count := 1000.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    19
    threads := 200.
1110
a38d8f5208fd class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1109
diff changeset
    20
    "/ There's limit to 50 open files in BCC5.5 libc, sigh.
a38d8f5208fd class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1109
diff changeset
    21
    OperatingSystem isMSWINDOWSlike ifTrue:[
a38d8f5208fd class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1109
diff changeset
    22
        threads := 20.
a38d8f5208fd class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1109
diff changeset
    23
    ].
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    24
    ok := true.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    25
    blocker := Semaphore new: threads negated + 1.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    26
    makeReader := [ :stream | 
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    27
        [
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    28
            | c |
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    29
            c := 0.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    30
            [ stream atEnd ] whileFalse:[ 
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    31
                stream next.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    32
                c := c + 1.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    33
            ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    34
            ok := ok and:[ count == c ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    35
            blocker signal.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    36
        ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    37
    ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    38
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    39
    makeWriter := [ :stream | 
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    40
        [ 
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    41
            [ count timesRepeat:[stream nextPut: $P] ] on: Error do:[ 
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    42
                ok := false 
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    43
            ]
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    44
        ]
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    45
    ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    46
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    47
    threads timesRepeat:[
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    48
       | pipe rs ws|
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    49
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    50
        pipe := NonPositionableExternalStream makePipe.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    51
        rs := pipe at:1.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    52
        ws := pipe at:2.     
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    53
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    54
        (makeReader value: rs) fork.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    55
        (makeWriter value: ws) fork.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    56
    ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    57
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    58
    blocker wait.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    59
    self assert: ok.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    60
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    61
    "Created: / 27-03-2014 / 16:21:52 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    62
!
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    63
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
testReadCheckPipe4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
    "readCheck a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    | s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
    72
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    s := PipeStream readingFrom:'sleep 5'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    p := [
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
        s readWait.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
        'readWait finished' printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
    [p isDead] whileFalse:[
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
        Delay waitForMilliseconds:5.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
        p interruptWith:[count := count + 1].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
     self new testReadCheckPipe4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
testReadCheckPipe5
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
    "readCheck a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    | s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   105
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
    s := PipeStream readingFrom:'sleep 5; echo hello'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
    p := [
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
        s readWait.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
        'readWait finished' printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
    [p isDead] whileFalse:[
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
        Delay waitForMilliseconds:5.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
        p interruptWith:[count := count + 1].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
     self new testReadCheckPipe5
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
testReadPipe6
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    "read a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
    | s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   138
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
    s := PipeStream readingFrom:'sleep 5'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    p := [
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
        'read: ' print. s nextLine printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
    [p isDead] whileFalse:[
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
        Delay waitForMilliseconds:5.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
        p interruptWith:[count := count + 1].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
     self new testReadPipe6
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
testReadPipe7
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
    "read a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
    |sz s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   170
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
    s := PipeStream readingFrom:'sleep 5; echo hello'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
    p := [
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
        'read: ' print. s nextLine printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
    [p isDead] whileFalse:[
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
        Delay waitForMilliseconds:5.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
        p interruptWith:[count := count + 1].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
     self test7
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
! !
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
!PipeStreamTest class methodsFor:'documentation'!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
version
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
    ^ '$Header$'
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
! !
1082
a46d9682d459 category change
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
   199