RegressionTests__ExceptionTest.st
author Claus Gittinger <cg@exept.de>
Wed, 24 Aug 2011 14:04:01 +0200
changeset 634 ae51f7778dad
parent 349 8aeec57e44db
child 641 0c1a14671aee
permissions -rw-r--r--
added: #test7_error_in_unwind #test8_error_in_unwind2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
241
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     1
"{ Package: 'exept:regression' }"
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     2
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     3
"{ NameSpace: RegressionTests }"
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     4
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     5
TestCase subclass:#ExceptionTest
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     6
	instanceVariableNames:''
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     7
	classVariableNames:''
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     8
	poolDictionaries:''
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
     9
	category:'tests-Regression'
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    10
!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    11
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    12
!ExceptionTest class methodsFor:'documentation'!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    13
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    14
documentation
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    15
"
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    16
    documentation to be added.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    17
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    18
    [author:]
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    19
        Stefan Vogel (stefan@zwerg)
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    20
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    21
    [instance variables:]
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    22
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    23
    [class variables:]
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    24
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    25
    [see also:]
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    26
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    27
"
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    28
! !
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    29
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    30
!ExceptionTest methodsFor:'initialize / release'!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    31
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    32
setUp
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    33
    "common setup - invoked before testing."
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    34
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    35
    super setUp
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    36
!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    37
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    38
tearDown
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    39
    "common cleanup - invoked after testing."
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    40
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    41
    super tearDown
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    42
! !
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    43
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    44
!ExceptionTest methodsFor:'tests'!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    45
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    46
test1
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    47
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    48
    |result zero|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    49
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    50
    result := OrderedCollection new.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    51
    zero := 0.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    52
349
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    53
    [ 0 // zero ] 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    54
        on:ZeroDivide 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    55
        do:[:ex|
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    56
            self assert:(ex signal == ZeroDivide).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    57
            self assert:(ex originator == 0).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    58
            result add:#Error 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
    59
        ].
241
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    60
    self assert:(result size == 1).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    61
    self assert:(result first == #Error).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    62
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    63
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    64
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    65
     self run:#test1
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    66
     self new test1
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    67
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    68
!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    69
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    70
test10
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    71
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    72
    |result zero|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    73
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    74
    result := OrderedCollection new.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    75
    zero := 0.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    76
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    77
    [
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    78
        [
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    79
            Warning handle:[:ex | result add:#Warning ] do:[ 2 // zero ].
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    80
        ] on:ZeroDivide do:[:ex |
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    81
            result add:#Error.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    82
            ex reject.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    83
            [
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    84
                self warn:ex description.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    85
            ] on:Warning do:[:ex| result add:#Warning2]
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    86
        ]
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    87
    ] on:ZeroDivide do:[:ex |
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    88
        result add:#Error2
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    89
    ].
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    90
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    91
    self assert:(result size == 2).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    92
    self assert:(result first == #Error).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    93
    self assert:(result second == #Error2)
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    94
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    95
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    96
     self run:#test10
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    97
     self new test10
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    98
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    99
!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   100
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   101
test2
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   102
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   103
    |result zero|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   104
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   105
    result := OrderedCollection new.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   106
    zero := 0.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   107
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   108
    self should:[
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   109
        [ 0 // zero ] on:ZeroDivide do:[:ex|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   110
            result add:#Error.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   111
            0 // zero
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   112
        ].
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   113
    ] raise:ZeroDivide.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   114
    self assert:(result size == 1).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   115
    self assert:(result first == #Error).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   116
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   117
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   118
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   119
     self run:#test2
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   120
     self new test2
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   121
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   122
!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   123
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   124
test3
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   125
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   126
    |result zero|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   127
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   128
    result := OrderedCollection new.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   129
    zero := 0.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   130
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   131
    self should:[
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   132
        [ 0 // zero ] on:ZeroDivide do:[:ex|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   133
            result add:#Error.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   134
            [ 0 // zero ] on:ZeroDivide do:[:ex|
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   135
                result add:#Error1.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   136
                ex reject.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   137
            ].
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   138
        ].
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   139
    ] raise:ZeroDivide.
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   140
    self assert:(result size == 2).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   141
    self assert:(result first == #Error).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   142
    self assert:(result second == #Error1).
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   143
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   144
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   145
    "
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   146
     self run:#test3
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   147
     self new test3
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   148
    "
349
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   149
!
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   150
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   151
test4_on_do
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   152
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   153
    |exceptionHappened zero|
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   154
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   155
    zero := 0.
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   156
    exceptionHappened := false.
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   157
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   158
    [0 // zero] 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   159
        on:ZeroDivide 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   160
        do:[:ex|
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   161
            exceptionHappened := true
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   162
        ].
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   163
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   164
    self assert:(exceptionHappened).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   165
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   166
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   167
    "
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   168
     self run:#test4_on_do
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   169
     self new test4_on_do
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   170
    "
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   171
!
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   172
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   173
test5_on_do_ensure
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   174
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   175
    |exceptionHappened ensureCalled zero|
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   176
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   177
    zero := 0.
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   178
    exceptionHappened := ensureCalled := false.
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   179
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   180
    [0 // zero] 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   181
        on:ZeroDivide 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   182
        do:[:ex| exceptionHappened := true]
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   183
        ensure:[ ensureCalled := true ].
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   184
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   185
    self assert:(exceptionHappened).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   186
    self assert:(ensureCalled).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   187
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   188
    "
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   189
     self run:#test5_on_do_ensure
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   190
     self new test5_on_do_ensure
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   191
    "
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   192
!
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   193
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   194
test6_on_do_ensure
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   195
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   196
    |exceptionHappened ensureCalled zero|
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   197
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   198
    zero := 0.
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   199
    exceptionHappened := ensureCalled := false.
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   200
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   201
    [zero // 1] 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   202
        on:ZeroDivide 
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   203
        do:[:ex| exceptionHappened := true]
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   204
        ensure:[ ensureCalled := true ].
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   205
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   206
    self assert:(exceptionHappened not).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   207
    self assert:(ensureCalled).
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   208
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   209
    "
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   210
     self run:#test6_on_do_ensure
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   211
     self new test6_on_do_ensure
8aeec57e44db *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 241
diff changeset
   212
    "
634
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   213
!
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   214
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   215
test7_error_in_unwind
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   216
    "think about this - not sure, how to react on an error happening in the unwind..."
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   217
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   218
    |zero trace|
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   219
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   220
    zero := 0.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   221
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   222
    trace := OrderedCollection new.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   223
    Error handle:[:ex |
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   224
        trace add:5.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   225
    ] do:[
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   226
        [
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   227
            trace add:1.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   228
            1 // zero.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   229
            trace add:2.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   230
        ] ensure:[
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   231
            trace add:3.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   232
            1 // zero.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   233
            trace add:4.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   234
        ].
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   235
    ].
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   236
    self assert:(trace asArray = #(1 5 3)).
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   237
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   238
    "
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   239
     self run:#test7_error_in_unwind
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   240
     self new test7_error_in_unwind
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   241
    "
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   242
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   243
    "Created: / 24-08-2011 / 13:55:27 / cg"
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   244
!
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   245
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   246
test8_error_in_unwind2
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   247
    "no matter what happens in test7 - this one should work !!"
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   248
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   249
    |zero trace|
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   250
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   251
    zero := 0.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   252
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   253
    trace := OrderedCollection new.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   254
    Error handle:[:ex |
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   255
        trace add:6.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   256
    ] do:[
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   257
        Error handle:[:ex |
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   258
            trace add:5.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   259
        ] do:[
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   260
            [
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   261
                trace add:1.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   262
                1 // zero.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   263
                trace add:2.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   264
            ] ensure:[
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   265
                trace add:3.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   266
                1 // zero.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   267
                trace add:4.
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   268
            ].
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   269
        ].
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   270
    ].
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   271
    self assert:(trace asArray = #(1 5 3 6)).
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   272
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   273
    "
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   274
     self run:#test8_error_in_unwind2
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   275
     self new test8_error_in_unwind2
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   276
    "
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   277
Claus Gittinger <cg@exept.de>
parents: 349
diff changeset
   278
    "Created: / 24-08-2011 / 14:02:01 / cg"
241
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   279
! !
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   280
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   281
!ExceptionTest class methodsFor:'documentation'!
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   282
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   283
version
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   284
    ^ '$Header$'
5b8a5dd10628 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   285
! !