RegressionTests__PipeStreamTest.st
author sr
Wed, 15 Nov 2017 16:41:47 +0100
changeset 1890 9367c7639c2d
parent 1594 f3698cd71e1c
child 1903 dcd4e2bf4c31
permissions -rw-r--r--
removed not existing Class from project definition
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
     1
"{ Package: 'stx:goodies/regression' }"
121
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
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    16
    | makeReader makeWriter count threads ok blocker|
1109
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:[
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    22
        threads := 20.
1110
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.
1289
e1b9697a5b5e class: RegressionTests::PipeStreamTest
Stefan Vogel <sv@exept.de>
parents: 1215
diff changeset
    25
    blocker := Semaphore new: 2 - threads.
e1b9697a5b5e class: RegressionTests::PipeStreamTest
Stefan Vogel <sv@exept.de>
parents: 1215
diff changeset
    26
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    27
    makeReader := [:stream |
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    28
            [
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    29
                | c |
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    30
                c := 0.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    31
                [ stream atEnd ] whileFalse:[
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    32
                    stream next.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    33
                    c := c + 1.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    34
                ].
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    35
                stream close.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    36
                ok := ok and:[ count == c ].
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    37
                blocker signal.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    38
            ]
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    39
        ].
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    40
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    41
    makeWriter := [:stream |
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    42
            [
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    43
                [ 
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    44
                    count timesRepeat:[stream nextPut: $P] 
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    45
                ] on: Error do:[
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    46
                    ok := false
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    47
                ].
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    48
                stream close.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    49
            ]
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    50
        ].
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    51
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    52
    threads timesRepeat:[
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    53
        |pipe rs ws|
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    54
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    55
        pipe := NonPositionableExternalStream makePipe.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    56
        rs := pipe at:1.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    57
        ws := pipe at:2.
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    58
1594
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    59
        (makeReader value: rs) fork.
f3698cd71e1c #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 1447
diff changeset
    60
        (makeWriter value: ws) fork.
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    61
    ].
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
    blocker wait.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    64
    self assert: ok.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    65
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    66
    "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
    67
!
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    68
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
testReadCheckPipe4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    "readCheck a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
    | s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
    77
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    s := PipeStream readingFrom:'sleep 5'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
    82
	s readWait.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
    83
	'readWait finished' printCR.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
    88
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
    89
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
     self new testReadCheckPipe4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
testReadCheckPipe5
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
    "readCheck a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
    | s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   110
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
    s := PipeStream readingFrom:'sleep 5; echo hello'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   115
	s readWait.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   116
	'readWait finished' printCR.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   121
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   122
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
     self new testReadCheckPipe5
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
testReadPipe6
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    "read a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   139
    | s p count nLoop error |
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   141
    error := nil.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   144
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
    s := PipeStream readingFrom:'sleep 5'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   149
	[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   150
	    'read: ' print. s nextLine printCR.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   151
	] on: Error do:[:ex|
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   152
	    error := ex.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   153
	]
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   158
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   159
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   165
    self assert: error isNil
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   166
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
     self new testReadPipe6
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
testReadPipe7
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
    "read a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   178
    |s p count nLoop error |
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   182
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
    s := PipeStream readingFrom:'sleep 5; echo hello'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   187
	[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   188
	    'read: ' print. s nextLine printCR.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   189
	] on: Error do:[:ex|
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   190
	    error := ex.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   191
	]
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   196
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   197
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   203
    self assert: error isNil
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   204
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
     self test7
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
! !
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
!PipeStreamTest class methodsFor:'documentation'!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
version
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
    ^ '$Header$'
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
! !
1082
a46d9682d459 category change
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
   217