RegressionTests__PipeStreamTest.st
author Jan Vrany <jan.vrany@labware.com>
Thu, 01 Jul 2021 16:09:20 +0100
branchjv
changeset 2602 1e701f1808a7
parent 1974 f2eaf05205d6
permissions -rwxr-xr-x
Fix `CompilerTest >> testNot` after cherry-picking from 84348e65ca8d in d0679511ef19
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1974
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     1
"
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     2
 COPYRIGHT (c) Claus Gittinger / eXept Software AG
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     3
 COPYRIGHT (c) 2015-2017 Jan Vrany
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     4
              All Rights Reserved
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     5
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     6
 This software is furnished under a license and may be used
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     7
 only in accordance with the terms of that license and with the
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     8
 inclusion of the above copyright notice.   This software may not
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
     9
 be provided or otherwise made available to, or used by, any
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    10
 other person.  No title to or ownership of the software is
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    11
 hereby transferred.
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    12
"
1499
26a16a04219b Package renamed from exept:regression to stx:goodies/regression. Hooray!
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1478
diff changeset
    13
"{ Package: 'stx:goodies/regression' }"
1289
e1b9697a5b5e class: RegressionTests::PipeStreamTest
Stefan Vogel <sv@exept.de>
parents: 1215
diff changeset
    14
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
"{ NameSpace: RegressionTests }"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
TestCase subclass:#PipeStreamTest
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
	instanceVariableNames:''
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	classVariableNames:''
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	poolDictionaries:''
1082
a46d9682d459 category change
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
    21
	category:'tests-Regression-Streams'
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
1974
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    24
!PipeStreamTest class methodsFor:'documentation'!
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    25
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    26
copyright
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    27
"
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    28
 COPYRIGHT (c) Claus Gittinger / eXept Software AG
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    29
 COPYRIGHT (c) 2015-2017 Jan Vrany
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    30
              All Rights Reserved
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    31
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    32
 This software is furnished under a license and may be used
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    33
 only in accordance with the terms of that license and with the
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    35
 be provided or otherwise made available to, or used by, any
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    36
 other person.  No title to or ownership of the software is
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    37
 hereby transferred.
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    38
"
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1605
diff changeset
    39
! !
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
!PipeStreamTest methodsFor:'tests'!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    43
testPipeWriteRead
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    44
    | makeReader makeWriter count threads ok blocker |
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
    count := 1000.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    47
    threads := 200.
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    48
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    49
    (OperatingSystem isMSWINDOWSlike) ifTrue:[
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    50
        "/ Sigh, when having too much threads on Windows,
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    51
        "/ this test lead to deadlock. This has to be investigated
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    52
        "/ and fixed. See
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    53
        "/ 
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    54
        "/    https://swing.fit.cvut.cz/projects/stx-jv/ticket/104
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    55
        threads := 20.
1110
a38d8f5208fd class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1109
diff changeset
    56
    ].
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    57
    ok := true.
1289
e1b9697a5b5e class: RegressionTests::PipeStreamTest
Stefan Vogel <sv@exept.de>
parents: 1215
diff changeset
    58
    blocker := Semaphore new: 2 - threads.
e1b9697a5b5e class: RegressionTests::PipeStreamTest
Stefan Vogel <sv@exept.de>
parents: 1215
diff changeset
    59
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
    60
    makeReader := [ :stream |
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    61
        [
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    62
            | c |
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    63
            c := 0.
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    64
            [ stream atEnd ] whileFalse:[
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    65
                stream next.
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    66
                c := c + 1.
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    67
            ].
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    68
            ok := ok and:[ count == c ].
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    69
            blocker signal.
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    70
        ].
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    71
    ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    72
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
    73
    makeWriter := [ :stream |
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    74
        [
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    75
            [ count timesRepeat:[stream nextPut: $P] ] on: Error do:[ :ex |
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    76
                Transcript showCR: 'ERROR in writer: ',  ex description.
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    77
                ex suspendedContext fullPrintOn: Transcript.
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    78
                ok := false
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    79
            ] ensure:[ 
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    80
                stream close.
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    81
            ]
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    82
        ]                                                   
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    83
    ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    84
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    85
    2 to: threads do:[:i |
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    86
       | pipe rs rp ws wp |
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    87
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    88
        pipe := NonPositionableExternalStream makePipe.
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    89
        rs := pipe at:1.
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
    90
        ws := pipe at:2.
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    91
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    92
        rp := (makeReader value: rs) newProcess.
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    93
        rp name: i printString , ' R ' , testSelector.
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    94
        wp := (makeWriter value: ws) newProcess.
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    95
        wp name: i printString , ' W ' , testSelector.
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    96
        rp resume.
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
    97
        wp resume.
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    98
    ].
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
    99
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
   100
    blocker wait.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
   101
    self assert: ok.
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
   102
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
   103
    "Created: / 27-03-2014 / 16:21:52 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
   104
    "Modified: / 28-12-2015 / 13:17:45 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1532
c540e1f444ea Issue #104: Temporarily lower the number of threads in #testPipeReadWrite
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1500
diff changeset
   105
    "Modified: / 04-09-2016 / 03:23:36 / jv"
1109
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
   106
!
ad8866ade273 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1082
diff changeset
   107
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
testReadCheckPipe4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
    "readCheck a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
     Do this and interrupt the reading thread heavily"
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 p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   116
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
    s := PipeStream readingFrom:'sleep 5'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   121
	s readWait.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   122
	'readWait finished' printCR.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   127
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   128
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    s close.
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
     self new testReadCheckPipe4
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
testReadCheckPipe5
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    "readCheck a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
    | s p count nLoop|
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   149
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
    s := PipeStream readingFrom:'sleep 5; echo hello'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   154
	s readWait.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   155
	'readWait finished' printCR.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   160
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   161
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
    ('readWait interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
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 testReadCheckPipe5
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
testReadPipe6
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
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   180
    error := nil.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   183
    "/ self createTestFile.
121
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 := PipeStream readingFrom:'sleep 5'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   188
	[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   189
	    'read: ' print. s nextLine printCR.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   190
	] on: Error do:[:ex|
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   191
	    error := ex.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   192
	]
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   197
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   198
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   204
    self assert: error isNil
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   205
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
     self new testReadPipe6
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
    "Modified: / 12.8.1998 / 13:42:13 / cg"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
testReadPipe7
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
    "read a pipe.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
     Do this and interrupt the reading thread heavily"
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   217
    |s p count nLoop error |
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
    nLoop := 1000.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
170
247b3696e4cd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 121
diff changeset
   221
    "/ self createTestFile.
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
    s := PipeStream readingFrom:'sleep 5; echo hello'.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
    p := [
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   226
	[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   227
	    'read: ' print. s nextLine printCR.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   228
	] on: Error do:[:ex|
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   229
	    error := ex.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   230
	]
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
    ] forkAt:7.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
    count := 0.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
    [p isDead] whileFalse:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   235
	Delay waitForMilliseconds:5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   236
	p interruptWith:[count := count + 1].
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   237
    ].
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
    ('read interrupted <1p> times' expandMacrosWith:count) printCR.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
    s close.
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   242
    self assert: error isNil
1215
6c8217e7f690 class: RegressionTests::PipeStreamTest
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1110
diff changeset
   243
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
     self test7
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
    "
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
    "Modified: / 12.8.1998 / 13:42:13 / cg"
1605
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   249
!
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   250
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   251
testTTY
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   252
    "Test TTY / PTY related methods on pipes (should throw error)"
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   253
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   254
    | s |
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   255
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   256
    s := PipeStream readingFrom:'echo hello'.
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   257
    [ 
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   258
        self deny: s isTTY.
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   259
        self should: [ s getTTYAttributes ] raise: OsError.
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   260
        s nextLine
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   261
    ] ensure:[
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   262
        s close.
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   263
    ]
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   264
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   265
    "Created: / 31-05-2017 / 07:35:18 / Jan Vrany <jan.vrany@fit.cvut.cz>"
5ff1befbd463 Added tests for (UNIX) TTY / PTY attribute support.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1532
diff changeset
   266
    "Modified: / 01-06-2017 / 21:27:13 / jv"
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
! !
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
!PipeStreamTest class methodsFor:'documentation'!
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
version
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
    ^ '$Header$'
1476
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
   273
!
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
   274
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
   275
version_HG
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
   276
cd772f7900fe RegressionTests::PipeStreamTest>>testPipeWriteRead refactored.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1289
diff changeset
   277
    ^ '$Changeset: <not expanded> $'
121
3e9313b9af20 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
! !
1082
a46d9682d459 category change
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
   279