RegressionTests__VMSpawningTestCase.st
author Jan Vrany <jan.vrany@labware.com>
Fri, 18 Jun 2021 17:01:51 +0100
branchjv
changeset 2598 5e6256e136d4
parent 2082 05e1892aadee
permissions -rw-r--r--
Fix `IntegerTest` Do not use #deepCopy with desctructive operations, #deepCopy on numbers is an no-op (they're immutable, except internal destructive helpers)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1974
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
     1
"
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
     2
 COPYRIGHT (c) Claus Gittinger / eXept Software AG
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
     3
 COPYRIGHT (c) 2017-2018 Jan Vrany
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
     4
              All Rights Reserved
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
     5
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
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: 1971
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: 1971
diff changeset
     8
 inclusion of the above copyright notice.   This software may not
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
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: 1971
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: 1971
diff changeset
    11
 hereby transferred.
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    12
"
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    13
"{ Package: 'stx:goodies/regression' }"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    14
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    15
"{ NameSpace: RegressionTests }"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    16
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    17
TestCase subclass:#VMSpawningTestCase
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    18
	instanceVariableNames:''
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    19
	classVariableNames:'EXIT_CODE_SUCCESS EXIT_CODE_FAILURE EXIT_CODE_ERROR
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    20
		EXIT_CODE_SKIPPED'
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    21
	poolDictionaries:''
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    22
	category:'tests-Regression-Abstract'
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    23
!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    24
1974
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    25
!VMSpawningTestCase class methodsFor:'documentation'!
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    26
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    27
copyright
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    28
"
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    29
 COPYRIGHT (c) Claus Gittinger / eXept Software AG
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    30
 COPYRIGHT (c) 2017-2018 Jan Vrany
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    31
              All Rights Reserved
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    32
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    33
 This software is furnished under a license and may be used
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    34
 only in accordance with the terms of that license and with the
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    35
 inclusion of the above copyright notice.   This software may not
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    36
 be provided or otherwise made available to, or used by, any
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    37
 other person.  No title to or ownership of the software is
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    38
 hereby transferred.
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    39
"
f2eaf05205d6 Copyright updates
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1971
diff changeset
    40
! !
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    41
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    42
!VMSpawningTestCase class methodsFor:'initialization'!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    43
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    44
initialize
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    45
    "Invoked at system start or when the class is dynamically loaded."
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    46
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    47
    "/ please change as required (and remove this comment)
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    48
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    49
    EXIT_CODE_SUCCESS := 0.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    50
    EXIT_CODE_FAILURE := 1.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    51
    EXIT_CODE_ERROR := 2.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    52
    "/ Never define EXIT_CODE_SKIPPED as 3. On Windows,
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    53
    "/ 3 is used by abort() so then we'd not be able to
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    54
    "/ tell between skip and crash!! Sigh.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    55
    EXIT_CODE_SKIPPED := 97.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    56
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    57
    "Modified: / 03-09-2016 / 08:23:11 / Jan Vrany <jan.vrany@fit.cvut.cz>"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    58
    "Modified: / 08-09-2016 / 12:44:05 / jv"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    59
! !
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    60
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    61
!VMSpawningTestCase class methodsFor:'queries'!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    62
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    63
isAbstract
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    64
    "Return if this class is an abstract class.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    65
     True is returned here for myself only; false for subclasses.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    66
     Abstract subclasses must redefine this again."
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    67
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    68
    ^ self == RegressionTests::VMSpawningTestCase.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    69
! !
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    70
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    71
!VMSpawningTestCase methodsFor:'private'!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    72
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    73
spawnSelector:selector 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    74
    "Perform selector in freshly spawned Smalltalk."
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    75
    
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    76
    | tempDir |
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    77
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    78
    [
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    79
        tempDir := Filename newTemporary.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    80
        tempDir makeDirectory.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    81
        self spawnSelector:selector inDirectory:tempDir.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    82
    ] ensure:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    83
        (tempDir notNil and:[ tempDir exists ]) ifTrue:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    84
            [
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    85
                tempDir recursiveRemove.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    86
            ] on:Error
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    87
                    do:[:ex | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    88
                OperatingSystem isMSWINDOWSlike ifFalse:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    89
                    ex reject.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    90
                ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    91
            ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    92
        ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    93
    ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    94
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    95
    "Created: / 05-01-2017 / 23:08:38 / Jan Vrany <jan.vrany@fit.cvut.cz>"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    96
    "Modified: / 06-01-2017 / 22:07:27 / Jan Vrany <jan.vrany@fit.cvut.cz>"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    97
!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    98
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    99
spawnSelector:selector inDirectory:directory 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   100
    "Perform `selector` in new smalltalk process. Set new process's working directory to `directory`"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   101
    
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   102
    | testcaseFile script |
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   103
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   104
    directory makeDirectory.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   105
    testcaseFile := directory 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   106
            / ((Smalltalk fileNameForClass:self class) , '.st').
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   107
    self class fileOutAs:testcaseFile.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   108
    script := 'NoHandlerError emergencyHandler:[:ex |
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   109
                    ex suspendedContext fullPrintAllOn: Stdout.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   110
                    Stdout nextPutAll: ''ERROR (unhandled) '', ex printString.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   111
                    Smalltalk exit: %7
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   112
               ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   113
               Smalltalk packagePath: %1.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   114
               Smalltalk loadPackage:%2.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   115
               Smalltalk fileIn: %3.
2082
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   116
               STCCompilerInterface verbose: true.
1613
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   117
               Smalltalk addStartBlock:[
2082
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   118
                   ParserFlags stcModulePath: Filename currentDirectory.
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   119
                   ParserFlags stcKeepCIntermediate: true.
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   120
                   ParserFlags stcKeepSTIntermediate: true.  
1613
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   121
                   Processor exitWhenNoMoreUserProcesses: false.                   
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   122
                   [
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   123
                       (%4 selector: %5) spawnSelectorInternal: %6.                   
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   124
                   ] ensure:[
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   125
                       Smalltalk exit: %7
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   126
                   ]
713eead17134 Added workaround for (maybe) a race condition in `ProcessorScheduler`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1602
diff changeset
   127
               ].
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   128
               ' 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   129
            bindWith:Smalltalk packagePath asArray storeString
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   130
            with:self class package storeString
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   131
            with:testcaseFile pathName storeString
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   132
            with:self class name
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   133
            with:testSelector storeString
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   134
            with:selector storeString
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   135
            with:EXIT_CODE_ERROR storeString.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   136
    (directory / 'run.st') writingFileDo:[:f | f nextPutAll:script. ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   137
    self spawnSmalltalk: { '--abortOnSEGV'. '-I'. '--quick'. '--load'. (directory / 'run.st') pathName } inDirectory: directory
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   138
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   139
    "Created: / 06-01-2017 / 22:06:37 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2082
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   140
    "Modified: / 04-02-2019 / 17:57:53 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   141
!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   142
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   143
spawnSelectorInternal:selector 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   144
    [
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   145
        [
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   146
            self perform:selector.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   147
            Stdout
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   148
                cr;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   149
                nextPutAll:'PASSED';
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   150
                cr.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   151
            Smalltalk exit:EXIT_CODE_SUCCESS
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   152
        ] on:TestResult skipped
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   153
                do:[:skip | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   154
            Stdout
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   155
                cr;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   156
                nextPutAll:'SKIPPED';
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   157
                cr.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   158
            Smalltalk exit:EXIT_CODE_SKIPPED.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   159
        ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   160
    ] on:TestResult failure
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   161
            do:[:failure | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   162
        Stdout
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   163
            cr;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   164
            nextPutAll:'FAILURE: ';
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   165
            nextPutAll:failure description;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   166
            cr.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   167
        Smalltalk exit:EXIT_CODE_FAILURE.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   168
    ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   169
            on:TestResult exError
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   170
            do:[:error | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   171
        Stdout
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   172
            cr;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   173
            nextPutAll:'ERROR: ';
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   174
            nextPutAll:error description;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   175
            cr.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   176
        Smalltalk exit:EXIT_CODE_ERROR.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   177
    ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   178
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   179
    "Created: / 05-01-2017 / 23:02:29 / Jan Vrany <jan.vrany@fit.cvut.cz>"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   180
!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   181
1971
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   182
spawnSmalltalk:argv
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   183
    | tempDir |
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   184
    [
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   185
        tempDir := Filename newTemporary.
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   186
        tempDir makeDirectory.
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   187
        self spawnSmalltalk:argv inDirectory:tempDir.
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   188
    ] ensure:[
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   189
        (tempDir notNil and:[ tempDir exists ]) ifTrue:[
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   190
            [
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   191
                tempDir recursiveRemove.
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   192
            ] on:Error
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   193
                    do:[:ex | 
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   194
                OperatingSystem isMSWINDOWSlike ifFalse:[
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   195
                    ex reject.
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   196
                ].
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   197
            ]
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   198
        ].
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   199
    ].
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   200
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   201
    "Created: / 17-04-2018 / 15:56:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   202
!
de93bc901dba Issue #205: added regression tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1966
diff changeset
   203
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   204
spawnSmalltalk:argv inDirectory:directory 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   205
    "
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   206
     A helper method to spawn a new smalltalk process using current executable and
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   207
     given arguments (in `argv`). Set initial working copy of freskly spawned process
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   208
     to `directory`. Wait until spawned smalltalk finishes and then if process exit status
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   209
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   210
      * is EXIT_CODE_SUCCESS do nothing and return
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   211
      * is EXIT_CODE_SKIPPED then signal skipped test by means of #skipIf:description:
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   212
      * is EXIT_CODE_FAILURE then signal test failure by means of failed #assert:
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   213
      * is anything else then signal test error by means of #error:"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   214
    
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   215
    | exe  args  environment  outputFile  output  pid  blocker  status |
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   216
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   217
    exe := OperatingSystem pathOfSTXExecutable.
1966
99c870d21885 Do not load preferences when spawning a VM
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1959
diff changeset
   218
    args := { exe } , #('--abortOnSEGV') , argv , #('--no-preferences').
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   219
    OperatingSystem isMSWINDOWSlike ifTrue:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   220
        args := String 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   221
                streamContents:[:s | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   222
                    args 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   223
                        do:[:each | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   224
                            s
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   225
                                nextPut:$";
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   226
                                nextPutAll:each;
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   227
                                nextPut:$"
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   228
                        ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   229
                        separatedBy:[ s space ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   230
                ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   231
    ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   232
    outputFile := directory / 'output.txt'.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   233
    output := outputFile writeStream.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   234
    environment := OperatingSystem isUNIXlike ifTrue:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   235
            OperatingSystem getEnvironment copy
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   236
        ] ifFalse:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   237
            environment := Dictionary new
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   238
        ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   239
    blocker := Semaphore new.
2082
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   240
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   241
    "/ Write a little shell / .cmd script to re-execute the test.
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   242
    "/ This script is not used here, but provided for convenience
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   243
    "/ when debugging tests (using GDB or alike)
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   244
    OperatingSystem isMSWINDOWSlike  ifTrue:[
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   245
        (directory / 'run.cmd') writingFileDo:[ :s |
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   246
            s nextPutAll: args
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   247
        ]
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   248
    ] ifFalse:[ 
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   249
        (directory / 'run.sh') writingFileDo:[ :s |
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   250
            args do:[:e | s nextPut: $"; nextPutAll: e; nextPut: $" ]
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   251
                separatedBy: [ s space ]
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   252
        ].
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   253
    ].
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   254
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   255
    Processor 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   256
        monitor:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   257
            pid := OperatingSystem 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   258
                    exec:exe
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   259
                    withArguments:args
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   260
                    environment:environment
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   261
                    fileDescriptors:{
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   262
                            0.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   263
                            output fileDescriptor.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   264
                            output fileDescriptor
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   265
                        }
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   266
                    fork:true
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   267
                    newPgrp:false
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   268
                    inDirectory:directory pathName
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   269
                    showWindow:true
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   270
        ]
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   271
        action:[:s | 
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   272
            status := s.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   273
            blocker signal.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   274
        ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   275
    output close.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   276
    pid isNil ifTrue:[
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   277
        self error:'Failed to spawn test'.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   278
        ^ self.
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   279
    ].
1664
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   280
    [
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   281
        blocker wait.
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   282
        status code == EXIT_CODE_SUCCESS ifFalse:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   283
            status code == EXIT_CODE_SKIPPED ifTrue:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   284
                self skipIf:true description:'Skipped'.
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   285
            ] ifFalse:[
1664
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   286
                status code == EXIT_CODE_FAILURE ifTrue:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   287
                    "
1959
d05ea54888ee Added tests for `Context >> #unwindAndRestart` and `Context >> resend`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1664
diff changeset
   288
                    (directory / 'output.txt') contents asString
1664
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   289
                    "
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   290
                    self writeFile: outputFile to: Stdout labeled: 'TEST FAILED'.
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   291
                    self assert:false description:'Assertion failed, see log'.
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   292
                ] ifFalse:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   293
                    "
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   294
                    directory inspect
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   295
                    "
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   296
                    self writeFile: outputFile to: Stdout labeled: 'TEST ERROR'.                 
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   297
                    self error:'Error occured'.
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   298
                ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   299
            ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   300
        ].
1664
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   301
    ] on: TerminateProcessRequest do:[:ex|
1959
d05ea54888ee Added tests for `Context >> #unwindAndRestart` and `Context >> resend`
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1664
diff changeset
   302
        pid notNil ifTrue:[ OperatingSystem killProcess: pid ].
1664
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   303
        self writeFile: outputFile to: Stdout labeled: 'TEST TERMINATED'.
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   304
        ex pass.
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   305
    ].
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   306
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   307
    "Created: / 06-01-2017 / 11:25:04 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1966
99c870d21885 Do not load preferences when spawning a VM
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1959
diff changeset
   308
    "Modified: / 02-01-2018 / 16:26:09 / jv"
2082
05e1892aadee More debugging support in `VMSpawningTestCase`es
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1974
diff changeset
   309
    "Modified: / 04-02-2019 / 20:17:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1664
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   310
!
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   311
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   312
writeFile: aFilename to: aStream labeled: aString
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   313
    "
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   314
    Write contents of given `aFilename` to given `aStream` with given label (`aString`).
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   315
    Utility method for spawnSmalltalk:inDirectory: to ease the debugging.
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   316
    "
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   317
    aStream
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   318
            nextPutAll: '== ';
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   319
            nextPutAll: aString;
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   320
            nextPutAll: ' (testcase ';
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   321
            nextPutAll: self printString;
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   322
            nextPutLine:') =='.
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   323
    aFilename isNil ifTrue:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   324
        aStream nextPutLine: 'No file given!!'
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   325
    ] ifFalse:[ aFilename exists ifFalse:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   326
        aStream nextPutAll: 'File does not exist: '; nextPutLine: aFilename pathName
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   327
    ] ifTrue:[
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   328
        aFilename readingFileDo:[:s | 
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   329
            [ s atEnd ] whileFalse:[ aStream nextPutLine:s nextLine.].
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   330
        ].
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   331
    ]].
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   332
ebdc4db610c1 VMSpawningTestCase: Kill the spawned VM on timeout and report its output
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1613
diff changeset
   333
    "Created: / 28-07-2017 / 10:48:53 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1567
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   334
! !
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   335
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   336
!VMSpawningTestCase class methodsFor:'documentation'!
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   337
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   338
version_HG
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   339
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   340
    ^ '$Changeset: <not expanded> $'
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   341
! !
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   342
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   343
e17701a073f9 Added abstract VMSpawningTestCase
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   344
VMSpawningTestCase initialize!