RegressionTests__ParserTests.st
author Claus Gittinger <cg@exept.de>
Tue, 09 Jul 2019 18:53:03 +0200
changeset 2327 bf482d49aeaf
parent 2238 fdf23514ffb7
child 2571 32ec13cd1757
permissions -rw-r--r--
#QUALITY by exept class: RegressionTests::StringTests added: #test82c_expanding
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
     1
"{ Encoding: utf8 }"
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
     2
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     3
"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     4
 COPYRIGHT (c) 2006 by eXept Software AG
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     5
	      All Rights Reserved
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     6
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     7
 This software is furnished under a license and may be used
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    12
 hereby transferred.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    13
"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    14
"{ Package: 'stx:goodies/regression' }"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    15
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    16
"{ NameSpace: RegressionTests }"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    17
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    18
TestCase subclass:#ParserTests
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    19
	instanceVariableNames:'mockClass'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    20
	classVariableNames:''
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    21
	poolDictionaries:''
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    22
	category:'tests-Regression-Compilers'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    23
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    24
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    25
!ParserTests class methodsFor:'documentation'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    26
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    27
copyright
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    28
"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    29
 COPYRIGHT (c) 2006 by eXept Software AG
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    30
	      All Rights Reserved
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    31
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    32
 This software is furnished under a license and may be used
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    33
 only in accordance with the terms of that license and with the
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    35
 be provided or otherwise made available to, or used by, any
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    36
 other person.  No title to or ownership of the software is
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    37
 hereby transferred.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    38
"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    39
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    40
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    41
!ParserTests methodsFor:'accessing'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    42
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    43
mockClass
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    44
    ^ mockClass
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    45
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    46
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    47
mockClass:something
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    48
    mockClass := something.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    49
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    50
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    51
parserClass
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    52
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    53
    ^Parser
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    54
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    55
    "Created: / 01-07-2010 / 11:53:34 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    56
    "Modified: / 01-07-2010 / 17:38:42 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    57
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    58
2185
210ba8fc2b76 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 1796
diff changeset
    59
!ParserTests methodsFor:'initialize / release'!
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    60
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    61
setUp
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    62
    "prepares the testing environment which consists of mock class instance
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    63
     for sample annotated methods"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    64
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    65
    |testClass|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    66
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    67
    Class withoutUpdatingChangesDo:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    68
        testClass := self class 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    69
                    subclass:'AnnotationTestedClass'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    70
                    classInstanceVariableNames:''
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    71
                    instanceVariableNames:''
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    72
                    classVariableNames:''
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    73
                    poolDictionaries:''.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    74
    ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    75
    self mockClass:testClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    76
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    77
    "Created: / 29-11-2009 / 20:52:00 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    78
    "Modified: / 29-11-2009 / 22:09:27 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    79
    "Modified: / 12-07-2010 / 09:33:21 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    80
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    81
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    82
tearDown
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    83
    "release allocated resources for testing environment"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    84
    self mockClass: nil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    85
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    86
    "Created: / 29-11-2009 / 20:52:13 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    87
    "Modified: / 29-11-2009 / 22:09:33 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    88
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    89
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    90
!ParserTests methodsFor:'smoke test'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    91
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    92
testParseAllMethods
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    93
    Smalltalk allClassesDo:[:cls |
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    94
        Transcript showCR:cls.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    95
        cls instAndClassMethodsDo:[:mthd |
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    96
            Parser parseMethod:mthd source in:mthd mclass
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    97
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    98
    ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
    99
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   100
    "Created: / 28-06-2011 / 22:23:43 / cg"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   101
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   102
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   103
!ParserTests methodsFor:'tests - annotations'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   104
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   105
testAnnotationWithArrayLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   106
    "Positive testing the structure of unknown annotation definition: the annotation with #(<array>) literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   107
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   108
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   109
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   110
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   111
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   112
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   113
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   114
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   115
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   116
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   117
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   118
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   119
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   120
                        parseMethod:'annotationWithArrayLiteralExample <annotation: #(1 2 3 4)> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   121
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   122
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   123
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   124
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   125
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   126
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   127
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   128
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   129
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   130
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   131
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   132
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   133
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   134
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   135
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   136
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   137
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   138
    self assert:(arguments at:1) = #( 1 2 3 4 ).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   139
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   140
    "Created: / 12-01-2010 / 13:43:19 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   141
    "Modified: / 23-05-2019 / 09:28:41 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   142
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   143
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   144
testAnnotationWithByteArrayLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   145
    "Positive testing the structure of unknown annotation definition: the annotation with #[<byte array>] literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   146
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   147
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   148
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   149
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   150
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   151
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   152
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   153
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   154
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   155
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   156
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   157
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   158
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   159
                        parseMethod:'annotationWithByteArrayLiteralExample <annotation: #[64 128 192]> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   160
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   161
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   162
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   163
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   164
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   165
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   166
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   167
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   168
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   169
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   170
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   171
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   172
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   173
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   174
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   175
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   176
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   177
    self assert:(arguments at:1) = #[ 64 128 192 ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   178
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   179
    "Created: / 12-01-2010 / 13:35:36 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   180
    "Modified: / 23-05-2019 / 09:28:45 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   181
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   182
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   183
testAnnotationWithCharacterLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   184
    "Positive testing the structure of unknown annotation definition: the annotation with character literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   185
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   186
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   187
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   188
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   189
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   190
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   191
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   192
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   193
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   194
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   195
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   196
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   197
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   198
                        parseMethod:'annotationWithCharacterLiteralExample <annotation: $A> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   199
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   200
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   201
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   202
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   203
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   204
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   205
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   206
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   207
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   208
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   209
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   210
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   211
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   212
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   213
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   214
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   215
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   216
    self assert:(arguments at:1) = $A.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   217
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   218
    "Created: / 12-01-2010 / 13:20:37 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   219
    "Modified: / 23-05-2019 / 09:28:48 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   220
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   221
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   222
testAnnotationWithFalseLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   223
    "Positive testing the structure of unknown annotation definition: the annotation with false literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   224
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   225
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   226
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   227
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   228
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   229
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   230
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   231
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   232
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   233
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   234
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   235
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   236
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   237
                        parseMethod:'annotationWithFalseLiteralExample <annotation: false> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   238
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   239
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   240
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   241
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   242
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   243
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   244
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   245
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   246
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   247
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   248
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   249
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   250
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   251
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   252
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   253
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   254
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   255
    self assert:(arguments at:1) = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   256
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   257
    "Created: / 12-01-2010 / 13:13:26 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   258
    "Modified: / 23-05-2019 / 09:28:50 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   259
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   260
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   261
testAnnotationWithInvalidArgument
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   262
    "Negative testing the structure of unknown annotation definition: the annotation with the non-literal argument; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   263
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   264
    |parserState parseErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   265
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   266
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   267
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   268
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   269
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   270
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   271
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   272
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   273
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   274
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   275
                        parseMethod:'annotationWithInvalidArgumentExample <annotation: annotation:> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   276
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   277
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   278
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   279
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   280
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   281
    self assert:parserState hasError = true.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   282
    self assert:parseErrorOccured = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   283
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   284
    "Created: / 12-01-2010 / 13:48:48 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   285
    "Modified: / 23-05-2019 / 09:28:53 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   286
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   287
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   288
testAnnotationWithInvalidContentFollowed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   289
    "Negative testing the structure of unknown annotation definition: the annotation with valid argument followed by invalid content; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   290
    "Test Note: based on the previous parser behaviour this type of situation is not considered as serious,
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   291
     it's considered as ignorable, informing requester and proceeding execution"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   292
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   293
    |parserState annotation arguments ignorableErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   294
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   295
    ignorableErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   296
     " create method for annotation testing purpose " " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   297
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   298
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   299
            ignorableErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   300
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   301
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   302
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   303
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   304
                        parseMethod:'annotationWithInvalidContentFollowedExample <annotation: #argument #argument> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   305
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   306
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   307
     " ignorable error should occured "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   308
    self assert:ignorableErrorOccured = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   309
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   310
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   311
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   312
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   313
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   314
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   315
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   316
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   317
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   318
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   319
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   320
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   321
    self assert:(arguments at:1) = #argument.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   322
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   323
    "Created: / 12-01-2010 / 13:52:16 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   324
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   325
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   326
testAnnotationWithKeywordLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   327
    "Positive testing the structure of unknown annotation definition: the annotation with #<keyword> literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   328
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   329
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   330
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   331
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   332
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   333
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   334
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   335
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   336
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   337
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   338
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   339
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   340
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   341
                        parseMethod:'annotationWithKeywordLiteralExample <annotation: #equals:> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   342
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   343
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   344
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   345
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   346
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   347
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   348
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   349
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   350
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   351
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   352
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   353
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   354
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   355
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   356
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   357
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   358
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   359
    self assert:(arguments at:1) = #equals:.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   360
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   361
    "Created: / 12-01-2010 / 13:30:47 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   362
    "Modified: / 23-05-2019 / 09:28:56 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   363
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   364
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   365
testAnnotationWithMultiKeywordLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   366
    "Positive testing the structure of unknown annotation definition: the annotation with #<multikeyword> literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   367
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   368
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   369
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   370
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   371
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   372
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   373
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   374
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   375
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   376
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   377
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   378
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   379
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   380
                        parseMethod:'annotationWithMultiKeywordLiteralExample <annotation: #equals:from:> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   381
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   382
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   383
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   384
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   385
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   386
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   387
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   388
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   389
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   390
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   391
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   392
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   393
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   394
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   395
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   396
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   397
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   398
    self assert:(arguments at:1) = #equals:from:.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   399
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   400
    "Created: / 12-01-2010 / 13:31:41 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   401
    "Modified: / 23-05-2019 / 09:28:58 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   402
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   403
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   404
testAnnotationWithNegativeNumberLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   405
    "Positive testing the structure of unknown annotation definition: the annotation with negative_number literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   406
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   407
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   408
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   409
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   410
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   411
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   412
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   413
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   414
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   415
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   416
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   417
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   418
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   419
                        parseMethod:'annotationWithNegativeNumberLiteralExample <annotation: -123> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   420
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   421
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   422
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   423
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   424
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   425
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   426
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   427
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   428
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   429
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   430
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   431
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   432
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   433
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   434
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   435
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   436
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   437
    self assert:(arguments at:1) = -123.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   438
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   439
    "Created: / 12-01-2010 / 13:18:46 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   440
    "Modified: / 23-05-2019 / 09:29:01 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   441
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   442
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   443
testAnnotationWithNilLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   444
    "Positive testing the structure of unknown annotation definition: the annotation with nil literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   445
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   446
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   447
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   448
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   449
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   450
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   451
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   452
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   453
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   454
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   455
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   456
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   457
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   458
                        parseMethod:'annotationWithFalseLiteralExample <annotation: nil> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   459
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   460
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   461
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   462
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   463
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   464
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   465
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   466
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   467
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   468
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   469
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   470
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   471
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   472
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   473
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   474
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   475
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   476
    self assert:(arguments at:1) isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   477
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   478
    "Created: / 12-01-2010 / 13:13:59 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   479
    "Modified: / 23-05-2019 / 09:29:04 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   480
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   481
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   482
testAnnotationWithNumberLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   483
    "Positive testing the structure of unknown annotation definition: the annotation with number literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   484
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   485
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   486
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   487
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   488
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   489
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   490
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   491
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   492
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   493
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   494
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   495
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   496
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   497
                        parseMethod:'annotationWithNumberLiteralExample <annotation: 123> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   498
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   499
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   500
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   501
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   502
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   503
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   504
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   505
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   506
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   507
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   508
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   509
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   510
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   511
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   512
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   513
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   514
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   515
    self assert:(arguments at:1) = 123.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   516
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   517
    "Created: / 12-01-2010 / 13:18:15 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   518
    "Modified: / 23-05-2019 / 09:29:06 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   519
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   520
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   521
testAnnotationWithStringLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   522
    "Positive testing the structure of unknown annotation definition: the annotation with string literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   523
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   524
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   525
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   526
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   527
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   528
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   529
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   530
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   531
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   532
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   533
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   534
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   535
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   536
                        parseMethod:'annotationWithCharacterLiteralExample <annotation: ''Hello world!!''> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   537
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   538
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   539
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   540
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   541
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   542
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   543
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   544
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   545
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   546
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   547
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   548
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   549
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   550
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   551
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   552
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   553
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   554
    self assert:(arguments at:1) = 'Hello world!!'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   555
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   556
    "Created: / 12-01-2010 / 13:21:43 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   557
    "Modified: / 23-05-2019 / 09:29:09 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   558
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   559
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   560
testAnnotationWithSymbolLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   561
    "Positive testing the structure of unknown annotation definition: the annotation with #<characters> | #<name> literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   562
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   563
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   564
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   565
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   566
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   567
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   568
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   569
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   570
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   571
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   572
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   573
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   574
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   575
                        parseMethod:'annotationWithSymbolLiteralExample <annotation: #symbol> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   576
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   577
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   578
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   579
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   580
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   581
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   582
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   583
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   584
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   585
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   586
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   587
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   588
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   589
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   590
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   591
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   592
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   593
    self assert:(arguments at:1) = #symbol.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   594
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   595
    "Created: / 12-01-2010 / 13:26:54 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   596
    "Modified: / 23-05-2019 / 09:29:12 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   597
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   598
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   599
testAnnotationWithSymbolLiteral2
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   600
    "Positive testing the structure of unknown annotation definition: the annotation with #<characters> | #<name> literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   601
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   602
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   603
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   604
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   605
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   606
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   607
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   608
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   609
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   610
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   611
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   612
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   613
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   614
                        parseMethod:'annotationWithSymbolLiteralExample <annotation: symbol> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   615
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   616
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   617
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   618
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   619
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   620
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   621
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   622
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   623
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   624
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   625
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   626
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   627
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   628
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   629
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   630
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   631
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   632
    self assert:(arguments at:1) = #symbol.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   633
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   634
    "Created: / 11-07-2010 / 23:00:24 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   635
    "Modified: / 23-05-2019 / 09:29:14 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   636
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   637
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   638
testAnnotationWithTrueLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   639
    "Positive testing the structure of unknown annotation definition: the annotation with true literal; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   640
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   641
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   642
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   643
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   644
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   645
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   646
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   647
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   648
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   649
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   650
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   651
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   652
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   653
                        parseMethod:'annotationWithTrueLiteralExample <annotation: true> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   654
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   655
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   656
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   657
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   658
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   659
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   660
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   661
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   662
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   663
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   664
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   665
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   666
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   667
    self assert:(annotation at:1) = 'annotation:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   668
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   669
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   670
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   671
    self assert:(arguments at:1) = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   672
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   673
    "Created: / 12-01-2010 / 13:11:22 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   674
    "Modified: / 23-05-2019 / 09:29:17 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   675
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   676
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   677
testCompoundAnnotationLiteral
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   678
    "Positive testing the structure of unknown annotation definition: the annotation is compound of more keywords defining the annotation type; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   679
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   680
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   681
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   682
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   683
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   684
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   685
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   686
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   687
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   688
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   689
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   690
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   691
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   692
                        parseMethod:'compoundAnnotationLiteralExample <annotation: true alt: false> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   693
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   694
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   695
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   696
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   697
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   698
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   699
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   700
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   701
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   702
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   703
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   704
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   705
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   706
    self assert:(annotation at:1) = 'annotation:alt:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   707
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   708
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   709
    self assert:arguments size = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   710
    self assert:(arguments at:1) = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   711
    self assert:(arguments at:2) = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   712
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   713
    "Created: / 12-01-2010 / 13:47:00 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   714
    "Modified: / 23-05-2019 / 09:29:19 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   715
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   716
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   717
testDislocationAfterMethodBody
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   718
    "Negative testing the location of annotation definition: the annotation is situated after MethodSequenceNode; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   719
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   720
    |parserState parseErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   721
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   722
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   723
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   724
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   725
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   726
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   727
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   728
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   729
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   730
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   731
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   732
                        parseMethod:'dislocationInMethodHeaderExample |x| x:=1. ^x. <annotation: #argument>'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   733
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   734
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   735
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   736
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   737
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   738
    self assert:parserState hasError = true.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   739
    self assert:parseErrorOccured = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   740
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   741
    "Created: / 12-01-2010 / 12:42:03 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   742
    "Modified: / 23-05-2019 / 09:29:23 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   743
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   744
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   745
testDislocationInMethodBody
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   746
    "Negative testing the location of annotation definition: the annotation is situated in MethodSequenceNode; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   747
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   748
    |parserState parseErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   749
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   750
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   751
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   752
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   753
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   754
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   755
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   756
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   757
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   758
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   759
                        parseMethod:'dislocationInMethodHeaderExample |x| <annotation: #argument> x:=1. ^x.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   760
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   761
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   762
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   763
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   764
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   765
    self assert:parserState hasError = true.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   766
    self assert:parseErrorOccured = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   767
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   768
    "Created: / 12-01-2010 / 12:31:24 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   769
    "Modified: / 23-05-2019 / 09:29:25 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   770
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   771
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   772
testDislocationInMethodHeader
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   773
    "Negative testing the location of annotation definition: the annotation is situated before <name>|BinaryMethodName|KeywordMethodName; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   774
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   775
    |parserState parseErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   776
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   777
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   778
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   779
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   780
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   781
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   782
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   783
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   784
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   785
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   786
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   787
                        parseMethod:'<annotation: #argument> dislocationInMethodHeaderExample ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   788
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   789
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   790
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   791
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   792
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   793
    self assert:parserState hasError = true.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   794
    self assert:parseErrorOccured = true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   795
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   796
    "Created: / 12-01-2010 / 12:29:46 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   797
    "Modified: / 23-05-2019 / 09:29:28 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   798
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   799
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   800
testEmptyAnnotation
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   801
    "Positive testing the structure of unknown annotation definition: the empty annotation; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   802
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   803
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   804
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   805
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   806
    " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   807
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   808
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   809
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   810
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   811
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   812
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   813
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   814
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   815
                        parseMethod:'emptyAnnotationExample <annotation> |x| x:=1. ^x. '
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   816
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   817
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   818
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   819
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   820
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   821
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   822
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   823
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   824
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   825
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   826
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   827
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   828
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   829
    self assert:(annotation at:1) = 'annotation'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   830
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   831
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   832
    self assert:arguments size = 0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   833
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   834
    "Created: / 12-01-2010 / 13:08:15 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   835
    "Modified: / 23-05-2019 / 09:29:30 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   836
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   837
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   838
testMultipleAnnotationsInMethod
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   839
    "Positive testing the multiple annotation definition and theirs order: the annotations are situated in defined location; see grammar"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   840
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   841
    |parserState parseErrorOccured annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   842
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   843
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   844
    parseErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   845
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   846
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   847
            parseErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   848
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   849
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   850
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   851
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   852
                        parseMethod:'multipleAnnotationsInMethodExample <annotation1: #argument> <annotation2: #argument> |x| x:=1. ^x.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   853
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   854
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   855
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   856
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   857
    self deny:parserState = #Error.
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   858
    self assert:parserState hasError = false.
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   859
    self assert:parseErrorOccured = false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   860
     " find the annotations record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   861
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   862
    self assert:(parserState annotations size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   863
     " check the first annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   864
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   865
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   866
    self assert:(annotation at:1) = 'annotation1:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   867
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   868
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   869
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   870
    self assert:(arguments at:1) = #argument.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   871
     " check the second annotation defined"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   872
    annotation := parserState annotations at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   873
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   874
    self assert:(annotation at:1) = 'annotation2:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   875
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   876
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   877
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   878
    self assert:(arguments at:1) = #argument.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   879
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   880
    "Created: / 12-01-2010 / 12:47:57 / pp <Pavel.Pospichal@gmail.com>"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
   881
    "Modified: / 23-05-2019 / 09:29:33 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   882
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   883
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   884
!ParserTests methodsFor:'tests - context'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   885
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   886
testContextWithInvalidArgument
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   887
    "Negative testing the context annotation structure for the no-literal argument"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   888
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   889
    |parserState|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   890
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   891
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   892
    self should:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   893
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   894
                        parseMethod:'contextWithNoArgumentsExample <context: context:> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   895
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   896
        ] raise:ParseError.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   897
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   898
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   899
"/    self assert:parserState notNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   900
"/    self assert:parserState == #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   901
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   902
    "Created: / 11-01-2010 / 22:50:54 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   903
    "Modified: / 01-07-2010 / 16:30:50 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   904
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   905
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   906
testContextWithInvalidContentFollowed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   907
    "Negative testing the context annotation structure 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   908
     with valid argument followed by invalid content (following literal): <context: #return #return>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   909
    "Test Note: based on the previous parser behaviour this type of situation is not considered as serious,
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   910
     it's considered as ignorable, informing requester and proceeding execution"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   911
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   912
    |parserState annotation arguments ignorableErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   913
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   914
    ignorableErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   915
     " create method for annotation testing purpose " " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   916
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   917
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   918
            ignorableErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   919
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   920
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   921
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   922
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   923
                        parseMethod:'contextWithInvalidContentFollowedExample <context: #return #return> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   924
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   925
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   926
     " ignorable error should occured "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   927
    self should:ignorableErrorOccured.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   928
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   929
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   930
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   931
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   932
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   933
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   934
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   935
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   936
    self assert:(annotation at:1) = 'context:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   937
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   938
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   939
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   940
    self assert:(arguments at:1) = #return.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   941
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   942
    "Created: / 09-01-2010 / 13:14:26 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   943
    "Modified: / 11-01-2010 / 23:15:15 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   944
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   945
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   946
testContextWithNoArguments
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   947
    "Negative testing the context annotation structure for the no argument annotation structure <context>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   948
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   949
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   950
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   951
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   952
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   953
                parseMethod:'contextWithNoArgumentsExample <context> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   954
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   955
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   956
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   957
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   958
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   959
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   960
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   961
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   962
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   963
    self assert:(annotation at:1) = 'context'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   964
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   965
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   966
    self assert:arguments size = 0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   967
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
   968
    "Created: / 09-01-2010 / 12:41:53 / Pavel Pospíchal <Pavel.Pospichal@gmail.com>"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   969
    "Modified: / 11-01-2010 / 23:15:24 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   970
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   971
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   972
testStxContext
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   973
    "Testing the context annotation structure used in St/X virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   974
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   975
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   976
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   977
    " create method for annotation testing purpose : GenericException>>raiseRequest"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   978
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   979
                parseMethod:'stxContextExample <context: #return> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   980
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   981
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   982
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   983
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   984
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   985
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   986
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   987
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   988
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   989
    self assert:(annotation at:1) = 'context:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   990
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   991
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   992
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   993
    self assert:(arguments at:1) = #return.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   994
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   995
    "Created: / 29-11-2009 / 09:37:38 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   996
    "Modified: / 11-01-2010 / 22:33:21 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   997
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   998
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
   999
!ParserTests methodsFor:'tests - exception'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1000
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1001
testExceptionWithInvalidArgument
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1002
    "Negative testing the exception annotation structure for the no-literal argument"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1003
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1004
    |parserState|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1005
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1006
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1007
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1008
                parseMethod:'exceptionWithInvalidArgumentExample <exception: exception:> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1009
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1010
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1011
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1012
    self assert:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1013
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1014
    "Created: / 11-01-2010 / 22:57:43 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1015
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1016
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1017
testExceptionWithInvalidContentFollowed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1018
    "Negative testing the exception annotation structure 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1019
     with valid argument followed by invalid content (following literal): <exception: #handle #handle>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1020
    "Test Note: based on the previous parser behaviour this type of situation is not considered as serious,
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1021
     it's considered as ignorable, informing requester and proceeding execution"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1022
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1023
    |parserState annotation arguments ignorableErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1024
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1025
    ignorableErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1026
     " create method for annotation testing purpose " " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1027
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1028
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1029
            ignorableErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1030
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1031
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1032
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1033
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1034
                        parseMethod:'exceptionWithInvalidContentFollowedExample <exception: #handle #handle> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1035
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1036
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1037
     " ignorable error should occured "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1038
    self should:ignorableErrorOccured.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1039
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1040
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1041
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1042
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1043
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1044
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1045
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1046
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1047
    self assert:(annotation at:1) = 'exception:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1048
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1049
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1050
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1051
    self assert:(arguments at:1) = #handle.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1052
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1053
    "Created: / 11-01-2010 / 23:02:28 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1054
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1055
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1056
testExceptionWithNoArguments
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1057
    "Negative testing the exception annotation structure for the no argument annotation structure <exception>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1058
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1059
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1060
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1061
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1062
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1063
                parseMethod:'exceptionWithNoArgumentsExample <exception> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1064
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1065
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1066
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1067
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1068
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1069
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1070
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1071
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1072
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1073
    self assert:(annotation at:1) = 'exception'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1074
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1075
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1076
    self assert:arguments size = 0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1077
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1078
    "Created: / 11-01-2010 / 23:06:31 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1079
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1080
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1081
testSt80HandleException
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1082
    "Testing the exception annotation structure used in St-80 virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1083
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1084
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1085
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1086
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1087
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1088
                parseMethod:'st80HandleExceptionExample <exception: #handle> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1089
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1090
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1091
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1092
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1093
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1094
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1095
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1096
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1097
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1098
    self assert:(annotation at:1) = 'exception:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1099
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1100
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1101
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1102
    self assert:(arguments at:1) = #handle.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1103
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1104
    "Created: / 29-11-2009 / 09:36:20 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1105
    "Modified: / 07-12-2009 / 01:38:31 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1106
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1107
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1108
testSt80RaiseException
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1109
    "Testing the exception annotation structure used in St-80 virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1110
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1111
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1112
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1113
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1114
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1115
                parseMethod:'st80RaiseExceptionExample <exception: #raise> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1116
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1117
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1118
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1119
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1120
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1121
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1122
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1123
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1124
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1125
    self assert:(annotation at:1) = 'exception:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1126
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1127
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1128
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1129
    self assert:(arguments at:1) = #raise.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1130
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1131
    "Created: / 29-11-2009 / 22:36:00 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1132
    "Modified: / 12-12-2009 / 21:39:21 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1133
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1134
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1135
testSt80UnwindException
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1136
    "Testing the exception annotation structure used in St-80 virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1137
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1138
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1139
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1140
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1141
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1142
                parseMethod:'st80UnwindExceptionExample <exception: #unwind> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1143
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1144
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1145
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1146
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1147
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1148
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1149
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1150
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1151
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1152
    self assert:(annotation at:1) = 'exception:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1153
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1154
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1155
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1156
    self assert:(arguments at:1) = #unwind.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1157
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1158
    "Created: / 29-11-2009 / 22:36:49 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1159
    "Modified: / 12-12-2009 / 21:39:35 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1160
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1161
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1162
!ParserTests methodsFor:'tests - external function'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1163
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1164
testDolphinExternalFunctionByStdcall
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1165
    "Testing the external function annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1166
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1167
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1168
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1169
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1170
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1171
                parseMethod:'dolphinExternalFunctionByStdcallExample <stdcall: ''hresult CloseThemeData handle''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1172
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1173
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1174
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1175
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1176
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1177
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1178
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1179
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1180
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1181
    self assert:(annotation at:1) = 'stdcall:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1182
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1183
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1184
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1185
    self assert:(arguments at:1) = 'hresult CloseThemeData handle'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1186
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1187
    "Created: / 29-11-2009 / 09:50:11 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1188
    "Modified: / 12-01-2010 / 11:56:15 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1189
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1190
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1191
testSqueakExternalFunctionByApicall
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1192
    "Testing the external function annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1193
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1194
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1195
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1196
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1197
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1198
                parseMethod:'squeakExternalFunctionByApicallExample <apicall: ''long GetCurrentProcessId (void)'' module: ''kernel32.dll''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1199
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1200
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1201
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1202
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1203
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1204
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1205
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1206
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1207
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1208
    self assert:(annotation at:1) = 'apicall:module:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1209
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1210
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1211
    self assert:arguments size = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1212
    self assert:(arguments at:1) = 'long GetCurrentProcessId (void)'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1213
    self assert:(arguments at:2) = 'kernel32.dll'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1214
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1215
    "Created: / 29-11-2009 / 09:49:04 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1216
    "Modified: / 11-01-2010 / 23:29:51 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1217
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1218
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1219
testSqueakExternalFunctionByCdecl
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1220
    "Testing the external function annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1221
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1222
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1223
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1224
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1225
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1226
                parseMethod:'squeakExternalFunctionByCdeclExample <cdecl: ''long fstat (long MacStat* )'' module: ''libc.dylib''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1227
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1228
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1229
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1230
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1231
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1232
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1233
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1234
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1235
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1236
    self assert:(annotation at:1) = 'cdecl:module:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1237
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1238
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1239
    self assert:arguments size = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1240
    self assert:(arguments at:1) = 'long fstat (long MacStat* )'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1241
    self assert:(arguments at:2) = 'libc.dylib'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1242
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1243
    "Created: / 29-11-2009 / 09:49:36 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1244
    "Modified: / 11-01-2010 / 23:18:04 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1245
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1246
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1247
testStVExternalFunctionByApi
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1248
    "Testing the external function annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1249
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1250
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1251
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1252
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1253
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1254
                parseMethod:'stVExternalFunctionByApiExample <api: ''_func _int32 void''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1255
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1256
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1257
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1258
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1259
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1260
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1261
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1262
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1263
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1264
    self assert:(annotation at:1) = 'api:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1265
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1266
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1267
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1268
    self assert:(arguments at:1) = '_func _int32 void'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1269
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1270
    "Created: / 29-11-2009 / 09:47:49 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1271
    "Modified: / 12-12-2009 / 22:08:06 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1272
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1273
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1274
testStVExternalFunctionByOle
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1275
    "Testing the external function annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1276
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1277
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1278
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1279
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1280
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1281
                parseMethod:'stVExternalFunctionByOleExample <ole: ''return varchar2 varchar2''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1282
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1283
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1284
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1285
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1286
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1287
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1288
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1289
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1290
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1291
    self assert:(annotation at:1) = 'ole:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1292
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1293
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1294
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1295
    self assert:(arguments at:1) = 'return varchar2 varchar2'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1296
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1297
    "Created: / 29-11-2009 / 09:48:25 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1298
    "Modified: / 10-12-2009 / 11:18:29 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1299
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1300
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1301
testVwExternalFunctionByC
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1302
    "Testing the external function annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1303
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1304
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1305
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1306
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1307
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1308
                parseMethod:'vwExternalFunctionByCExample <c: ''void func(int x)''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1309
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1310
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1311
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1312
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1313
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1314
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1315
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1316
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1317
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1318
    self assert:(annotation at:1) = 'c:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1319
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1320
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1321
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1322
    self assert:(arguments at:1) = 'void func(int x)'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1323
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1324
    "Created: / 29-11-2009 / 09:46:31 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1325
    "Modified: / 12-12-2009 / 22:08:24 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1326
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1327
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1328
!ParserTests methodsFor:'tests - external functions STX'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1329
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1330
testSTX_ffiCall_01_cdecl
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1331
    |s p|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1332
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1333
    s := '<cdecl: char* ''ffiPrintString'' (char *)>'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1334
    p := Parser new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1335
    p source:s.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1336
    p nextToken.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1337
    p parsePrimitiveOrResourceSpecOrEmpty.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1338
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1339
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1340
testSTX_ffiCall_02_api
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1341
    |s p|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1342
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1343
    s := '<api: char* ''ffiPrintString'' (char *)>'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1344
    p := Parser new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1345
    p source:s.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1346
    p nextToken.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1347
    p parsePrimitiveOrResourceSpecOrEmpty.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1348
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1349
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1350
testSTX_ffiCall_03_c
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1351
    |s p|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1352
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1353
    s := '<C: char* >'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1354
    p := Parser new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1355
    p source:s.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1356
    p nextToken.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1357
    p parsePrimitiveOrResourceSpecOrEmpty.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1358
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1359
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1360
testSTX_ffiCall_04_undefinedClasses
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1361
    |b1 b2|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1362
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1363
    self should:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1364
        b1 := Parser evaluate:'[ NotYetLoadedClass ]'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1365
    ] raise:ParseError.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1366
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1367
    self assert:(b1 == nil).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1368
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1369
    self should:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1370
        b2 := Parser evaluate:'[ NonExistingNameSpace::NotYetLoadedClass ]'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1371
    ] raise:ParseError.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1372
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1373
    self assert:(b2 == nil).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1374
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1375
    "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1376
     self run:#test4
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1377
     self new test4
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1378
    "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1379
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1380
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1381
!ParserTests methodsFor:'tests - primitive'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1382
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1383
testNewSTXPrimitive
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1384
    "Testing the primitive annotation structure used in St/X virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1385
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1386
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1387
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1388
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1389
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1390
                parseMethod:'newSTXPrimitiveExample <primitive> ^self'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1391
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1392
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1393
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1394
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1395
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1396
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1397
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1398
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1399
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1400
    self assert:(annotation at:1) = 'primitive'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1401
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1402
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1403
    self assert:arguments size = 0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1404
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1405
    "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1406
     The primitive specifies method as logic which needs special handling
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1407
     before setting up a stack frame for the method to make it run. The example structure
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1408
     of primitive annotation is following:
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1409
        <primitive>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1410
    "Created: / 29-11-2009 / 09:34:36 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1411
    "Modified: / 06-12-2009 / 21:46:35 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1412
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1413
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1414
testPrimitiveWithInvalidArgument
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1415
    "Negative testing the context annotation structure for the no-literal argument"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1416
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1417
    |parserState|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1418
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1419
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1420
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1421
                parseMethod:'primitiveWithInvalidArgumentExample <primitive: primitive:> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1422
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1423
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1424
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1425
    self assert:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1426
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1427
    "Created: / 12-01-2010 / 08:40:28 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1428
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1429
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1430
testPrimitiveWithInvalidContentFollowed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1431
    "Negative testing the primitive annotation structure 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1432
     with valid argument followed by invalid content (following literal): <context: #return #return>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1433
    "Test Note: based on the previous parser behaviour this type of situation is not considered as serious,
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1434
     it's considered as ignorable, informing requester and proceeding execution"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1435
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1436
    |parserState annotation arguments ignorableErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1437
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1438
    ignorableErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1439
     " create method for annotation testing purpose " " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1440
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1441
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1442
            ignorableErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1443
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1444
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1445
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1446
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1447
                        parseMethod:'primitiveWithInvalidContentFollowedExample <primitive: ''test'' ''test''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1448
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1449
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1450
     " ignorable error should occured "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1451
    self should:ignorableErrorOccured.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1452
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1453
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1454
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1455
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1456
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1457
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1458
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1459
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1460
    self assert:(annotation at:1) = 'primitive:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1461
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1462
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1463
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1464
    self assert:(arguments at:1) = 'test'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1465
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1466
    "Created: / 12-01-2010 / 08:42:01 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1467
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1468
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1469
testSqueakPrimitive
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1470
    "Testing the named primitive annotation structure used in Squeak virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1471
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1472
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1473
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1474
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1475
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1476
                parseMethod:'squeakPrimitiveExample <primitive: ''test''> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1477
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1478
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1479
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1480
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1481
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1482
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1483
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1484
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1485
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1486
    self assert:(annotation at:1) = 'primitive:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1487
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1488
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1489
    self assert:arguments = 'test'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1490
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1491
    "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1492
     The named primitive specifies identifier value used to look up logic which is processed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1493
     before setting up a stack frame for the method to make it run. The example structure
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1494
     of named primitive annotation is following:
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1495
        <primitive: test>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1496
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1497
    "Created: / 29-11-2009 / 09:34:05 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1498
    "Modified: / 07-12-2009 / 01:29:29 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1499
    "Modified: / 04-09-2014 / 12:36:13 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1500
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1501
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1502
testSt80Primitive
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1503
    "Testing the numbered primitive annotation structure used in ST-80 virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1504
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1505
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1506
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1507
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1508
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1509
                parseMethod:'st80PrimitiveExample <primitive: 1> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1510
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1511
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1512
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1513
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1514
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1515
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1516
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1517
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1518
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1519
    self assert:(annotation at:1) = 'primitive:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1520
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1521
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1522
    self assert:arguments = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1523
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1524
    "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1525
     The numbered primitive specifies index value used to look up logic which is processed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1526
     before setting up a stack frame for the method to make it run. The example structure
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1527
     of numbered primitive annotation is following:
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1528
        <primitive: 1>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1529
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1530
    "Created: / 29-11-2009 / 09:33:18 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1531
    "Modified: / 07-12-2009 / 01:20:27 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1532
    "Modified: / 04-09-2014 / 12:36:37 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1533
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1534
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1535
testVAgePrimitive
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1536
    "Testing the named primitive annotation structure used in Visual Age virtual machine"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1537
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1538
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1539
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1540
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1541
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1542
                parseMethod:'vAgePrimitiveExample <primitive: #test> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1543
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1544
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1545
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1546
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1547
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1548
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1549
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1550
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1551
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1552
    self assert:(annotation at:1) = 'primitive:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1553
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1554
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1555
    self assert:arguments  = #test.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1556
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1557
    "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1558
     The named primitive specifies identifier value used to look up logic which is processed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1559
     before setting up a stack frame for the method to make it run. The example structure
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1560
     of named primitive annotation is following:
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1561
        <primitive: test>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1562
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1563
    "Created: / 29-11-2009 / 09:34:59 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1564
    "Modified: / 12-12-2009 / 22:09:48 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1565
    "Modified: / 04-09-2014 / 12:37:22 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1566
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1567
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1568
!ParserTests methodsFor:'tests - resource'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1569
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1570
testResourceWithInvalidArgument
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1571
    "Negative testing the context annotation structure for the no-literal argument"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1572
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1573
    |parserState|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1574
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1575
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1576
    self should:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1577
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1578
                        parseMethod:'resourceWithInvalidArgumentExample <resource: resource:> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1579
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1580
        ] raise:ParseError.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1581
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1582
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1583
"/    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1584
"/    self assert:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1585
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1586
    "Created: / 12-01-2010 / 11:28:13 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1587
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1588
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1589
testResourceWithInvalidContentFollowed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1590
    "Negative testing the resource annotation structure 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1591
     with valid argument followed by invalid content (following literal): <resource: #symbol #(array of symbols)>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1592
    "Test Note: based on the previous parser behaviour this type of situation is not considered as serious,
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1593
     it's considered as ignorable, informing requester and proceeding execution"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1594
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1595
    |parserState annotation arguments ignorableErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1596
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1597
    ignorableErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1598
     " create method for annotation testing purpose " " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1599
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1600
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1601
            ignorableErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1602
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1603
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1604
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1605
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1606
                        parseMethod:'resourceWithInvalidContentFollowedExample <resource: #symbol #(1 2 3)> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1607
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1608
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1609
     " ignorable error should occured "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1610
    self should:ignorableErrorOccured.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1611
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1612
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1613
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1614
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1615
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1616
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1617
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1618
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1619
    self assert:(annotation at:1) = 'resource:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1620
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1621
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1622
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1623
    self assert:(arguments at:1) = #symbol.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1624
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1625
    "Created: / 12-01-2010 / 11:33:22 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1626
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1627
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1628
testResourceWithNoArguments
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1629
    "Negative testing the resource annotation structure for the no argument annotation structure <resource>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1630
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1631
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1632
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1633
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1634
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1635
                parseMethod:'resourceWithNoArgumentsExample <resource> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1636
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1637
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1638
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1639
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1640
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1641
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1642
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1643
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1644
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1645
    self assert:(annotation at:1) = 'resource'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1646
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1647
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1648
    self assert:arguments size = 0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1649
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1650
    "Created: / 12-01-2010 / 11:35:21 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1651
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1652
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1653
testSingleResourcePragma
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1654
    "Testing the resource annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1655
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1656
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1657
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1658
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1659
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1660
                parseMethod:'resourcePragmaExample <resource: #skipInDebuggersWalkBack> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1661
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1662
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1663
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1664
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1665
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1666
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1667
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1668
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1669
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1670
    self assert:(annotation at:1) = 'resource:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1671
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1672
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1673
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1674
    self assert:(arguments at:1) = #skipInDebuggersWalkBack.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1675
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1676
    "Created: / 29-11-2009 / 09:40:17 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1677
    "Modified: / 12-12-2009 / 22:10:53 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1678
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1679
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1680
!ParserTests methodsFor:'tests - scanner'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1681
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1682
test_100_scan_EOLcomment1    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1683
    |parser|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1684
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1685
    parser := self parserClass new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1686
    parser saveComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1687
    parser
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1688
                parseMethod:'foo
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1689
"/
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1690
1'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1691
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1692
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1693
    self deny:parser isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1694
    self deny:parser == #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1695
    self assert:parser comments size == 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1696
    self assert:parser comments first commentString isEmpty.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1697
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1698
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1699
test_101_scan_EOLcomment2    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1700
    |parser|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1701
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1702
    parser := self parserClass new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1703
    parser saveComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1704
    parser
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1705
                parseMethod:'foo
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1706
"/a
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1707
1'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1708
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1709
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1710
    self deny:parser isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1711
    self deny:parser == #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1712
    self assert:parser comments size == 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1713
    self assert:parser comments first commentString = 'a'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1714
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1715
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1716
test_102_scan_EOLcomment3    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1717
    |parser|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1718
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1719
    parser := self parserClass new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1720
    parser saveComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1721
    parser
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1722
                parseMethod:'foo
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1723
"/abc
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1724
1'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1725
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1726
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1727
    self deny:parser isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1728
    self deny:parser == #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1729
    self assert:parser comments size == 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1730
    self assert:parser comments first commentString = 'abc'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1731
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1732
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1733
test_110_scan_DelimitedComment1    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1734
    |parser|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1735
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1736
    parser := self parserClass new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1737
    parser parserFlags allowSTXDelimiterComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1738
    parser saveComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1739
    parser
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1740
                parseMethod:'foo
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1741
"<<END
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1742
bla
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1743
bla bla
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1744
END
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1745
1'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1746
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1747
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1748
    self deny:parser isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1749
    self deny:parser == #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1750
    self assert:parser comments size == 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1751
    self assert:parser comments first commentString = '<<END\bla\bla bla\END\' withCRs.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1752
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1753
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1754
test_110_scan_DelimitedComment2    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1755
    |parser|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1756
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1757
    parser := self parserClass new.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1758
    parser parserFlags allowSTXDelimiterComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1759
    parser saveComments:true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1760
    parser
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1761
                parseMethod:'foo
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1762
"<<<< here is the difference"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1763
1'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1764
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1765
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1766
    self deny:parser isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1767
    self deny:parser == #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1768
    self assert:parser comments size == 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1769
    self assert:parser comments first commentString = '<<END\bla\bla bla\END\' withCRs.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1770
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1771
    "Created: / 04-09-2014 / 12:00:55 / Jan Vrany <jan.vrany@fit.cvut.cz>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1772
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1773
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1774
test_120_scan_numbers    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1775
    |s n|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1776
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1777
    n := Scanner scanNumberFrom:(s := ReadStream on:'0').
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1778
    self assert:(n == 0).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1779
    self assert:(s position == 1).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1780
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1781
    n := Scanner scanNumberFrom:(s := ReadStream on:'1234 ').
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1782
    self assert:(n == 1234).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1783
    self assert:(s position == 4).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1784
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1785
    n := Scanner scanNumberFrom:(s := ReadStream on:'1234.0 ').
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1786
    self assert:(n = 1234.0).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1787
    self assert:(s position == 6).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1788
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1789
    n := Scanner scanNumberFrom:(s := ReadStream on:'1234/ ').
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1790
    self assert:(n = 1234).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1791
    self assert:(s position == 4).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1792
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1793
    n := Scanner scanNumberFrom:(s := ReadStream on:'1234/2 ').
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1794
    self assert:(n = (1234/2)).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1795
    self assert:(s position == 6).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1797
    self assert:( Number readSmalltalkSyntaxFrom:'99d' ) = 99.0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1798
    self assert:( Number readSmalltalkSyntaxFrom:'99.00d' ) = 99.0.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1799
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1800
    self assert:( Number readSmalltalkSyntaxFrom:'12345678901234567890' ) = 12345678901234567890.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1801
    self assert:( Number readSmalltalkSyntaxFrom:'16rAAAAFFFFAAAAFFFF' ) = 16rAAAAFFFFAAAAFFFF.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1802
    self assert:( Number readSmalltalkSyntaxFrom:'(1/10)') = (1/10).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1803
    self assert:( Number readSmalltalkSyntaxFrom:'(1/3)' ) = (1/3).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1804
    self assert:( Number readSmalltalkSyntaxFrom:'(-1/3)' ) = (-1/3).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1805
    self assert:( Number readSmalltalkSyntaxFrom:'(1/-3)' ) = (-1/3).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1806
    self assert:( Number readSmalltalkSyntaxFrom:'(-1/-3)' ) = (1/3).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1807
    self assert:( Number readSmalltalkSyntaxFrom:'-(1/3)' ) = (-1/3).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1808
    self assert:( Number readSmalltalkSyntaxFrom:'-(-1/-3)' ) = (-1/3).
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1809
    self assert:( Number readSmalltalkSyntaxFrom:'+00000123.45') = 00000123.45.  
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1810
!
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1811
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1812
test_121_scan_specialStrings    
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1813
    |s tok str|
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1814
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1815
    "/ c-strings in scanner
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1816
    s := Scanner for:' c''\n\t\\\a'' '.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1817
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1818
    self assert:(tok == #String).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1819
    self assert:(s tokenValue = (String         
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1820
                                    with:Character nl 
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1821
                                    with:Character tab 
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1822
                                    with:$\
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1823
                                    with:$a)).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1824
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1825
    "/ c-strings in stc (if compiled)
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1826
    str := c'\n\t\\\a'.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1827
    self assert:(str = (String         
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1828
                                    with:Character nl 
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1829
                                    with:Character tab 
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1830
                                    with:$\
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1831
                                    with:$a)).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1832
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1833
    "/ expanded-string
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1834
    s := Scanner for:' e''one: { 123 } two: { 122+2 }\n'' '.
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1835
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1836
    self assert:(tok == #StringFragment).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1837
    self assert:(s tokenValue = 'one: ').
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1838
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1839
    "/ tok := s nextToken.
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1840
    "/ self assert:(tok == ${).
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1841
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1842
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1843
    self assert:(tok == #Integer).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1844
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1845
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1846
    self assert:(tok == $}).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1847
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1848
    tok := s continueEscapedString.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1849
    self assert:(tok == #StringFragment).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1850
    self assert:(s tokenValue = ' two: ').
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1851
    
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1852
    "/ tok := s nextToken.
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1853
    "/ self assert:(tok == ${).
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1854
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1855
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1856
    self assert:(tok == #Integer).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1857
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1858
    self assert:(tok == #BinaryOperator).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1859
    self assert:(s tokenName = '+').
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1860
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1861
    self assert:(tok == #Integer).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1862
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1863
    tok := s nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1864
    self assert:(tok == $}).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1865
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1866
    tok := s continueEscapedString.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1867
    self assert:(tok == #String).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1868
    self assert:(s tokenValue = Character nl asString).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1869
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1870
    "Created: / 22-05-2019 / 20:10:24 / Claus Gittinger"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1871
    "Modified: / 23-05-2019 / 09:24:07 / Claus Gittinger"
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1872
!
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1873
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1874
test_121b_parse_specialStrings    
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1875
    |p expr|
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1876
2238
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1877
    self 
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1878
        skipIf:true
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1879
        description:'not yet supported by stc'.
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1880
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1881
    "/ expanded-string
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1882
    p := Parser for:' e''one: { 123 } two: { 122+2 }\n'' '.
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1883
    p nextToken.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1884
    expr := p expression.
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1885
    self assert:(expr isMessage).
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1886
    self assert:(expr evaluate = c'one: 123 two: 124\n').
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1887
2238
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1888
    "/ 1 to:10 do:[:i |
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1889
    "/     Transcript showCR: e'{i} factorial is {i factorial}'.
fdf23514ffb7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2236
diff changeset
  1890
    "/ ].
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1891
2235
6b741d3d1881 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2185
diff changeset
  1892
    "Created: / 22-05-2019 / 20:56:40 / Claus Gittinger"
2236
d678c6a536ef #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2235
diff changeset
  1893
    "Modified: / 23-05-2019 / 09:24:57 / Claus Gittinger"
1796
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1894
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1895
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1896
!ParserTests methodsFor:'tests - sysprim'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1897
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1898
testSysPrimitiveWithInvalidArgument
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1899
    "Negative testing the context annotation structure for the no-literal argument"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1900
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1901
    |parserState|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1902
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1903
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1904
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1905
                parseMethod:'sysPrimitiveWithInvalidArgumentExample <sysprim: sysprim:> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1906
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1907
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1908
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1909
    self assert:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1910
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1911
    "Created: / 12-01-2010 / 11:49:19 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1912
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1913
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1914
testSysPrimitiveWithInvalidContentFollowed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1915
    "Negative testing the sysprim annotation structure 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1916
     with valid argument followed by invalid content (following literal):  <sysprim: #none #none>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1917
    "Test Note: based on the previous parser behaviour this type of situation is not considered as serious,
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1918
     it's considered as ignorable, informing requester and proceeding execution"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1919
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1920
    |parserState annotation arguments ignorableErrorOccured|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1921
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1922
    ignorableErrorOccured := false.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1923
     " create method for annotation testing purpose " " the signal is raised by Parser2::ParseError>>raiseRequest but there is no way how to handle its signal"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1924
    self parserClass parseErrorSignal 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1925
        handle:[:ex | 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1926
            ignorableErrorOccured := true.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1927
            ex proceed
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1928
        ]
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1929
        do:[
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1930
            parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1931
                        parseMethod:'sysPrimitiveWithInvalidContentFollowedExample <sysprim: #none #none> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1932
                        in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1933
        ].
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1934
     " ignorable error should occured "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1935
    self should:ignorableErrorOccured.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1936
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1937
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1938
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1939
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1940
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1941
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1942
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1943
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1944
    self assert:(annotation at:1) = 'sysprim:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1945
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1946
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1947
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1948
    self assert:(arguments at:1) = #none.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1949
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1950
    "Created: / 12-01-2010 / 11:51:14 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1951
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1952
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1953
testSysPrimitiveWithNoArguments
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1954
    "Negative testing the exception annotation structure for the no argument annotation structure <sysprim>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1955
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1956
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1957
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1958
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1959
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1960
                parseMethod:'sysPrimitiveWithNoArgumentsExample <sysprim> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1961
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1962
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1963
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1964
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1965
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1966
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1967
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1968
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1969
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1970
    self assert:(annotation at:1) = 'sysprim'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1971
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1972
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1973
    self assert:arguments size = 0
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1974
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1975
    "Created: / 12-01-2010 / 11:52:40 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1976
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1977
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1978
testVAgeSysPrimitive
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1979
    "Testing the sysprim annotation structure"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1980
    
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1981
    |parserState annotation arguments|
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1982
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1983
    " create method for annotation testing purpose "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1984
    parserState := self parserClass 
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1985
                parseMethod:'vAgeSysPrimitiveExample <sysprim: #none> ^self.'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1986
                in:mockClass.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1987
     " check the parser result "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1988
    self deny:parserState = #Error.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1989
    self deny:parserState isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1990
     " find the annotation record in parser state "
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1991
    self deny:parserState annotations isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1992
    self assert:(parserState annotations size) = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1993
    annotation := parserState annotations at:1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1994
    self assert:(annotation size) = 2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1995
    self assert:(annotation at:1) = 'sysprim:'.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1996
    arguments := annotation at:2.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1997
    self deny:arguments isNil.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1998
    self assert:arguments size = 1.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  1999
    self assert:(arguments at:1) = #none.
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2000
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2001
    "Created: / 29-11-2009 / 09:39:11 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2002
    "Modified: / 12-12-2009 / 22:11:28 / pp <Pavel.Pospichal@gmail.com>"
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2003
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2004
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2005
!ParserTests class methodsFor:'documentation'!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2006
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2007
version
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2008
    ^ '$Header$'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2009
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2010
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2011
version_CVS
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2012
    ^ '$Header$'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2013
!
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2014
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2015
version_SVN
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2016
    ^ '$ Id: ParserTests.st 2014 2010-07-12 08:10:01Z vranyj1  $'
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2017
! !
de195a6c7aa8 *** empty log message ***
sr
parents:
diff changeset
  2018