src/TestletTestCaseProxy.st
author vranyj1
Tue, 14 Jun 2011 13:25:53 +0000
branchjk_new_structure
changeset 855 809b1dc41615
parent 854 e165b3da9adb
child 859 56bc5e063b7d
permissions -rw-r--r--
use nameForHDTestReport and selectorForHDTestReport to identify test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     1
"{ Package: 'stx:libjava' }"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     2
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     3
TestCase subclass:#TestletTestCaseProxy
826
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
     4
	instanceVariableNames:'harness'
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     5
	classVariableNames:'TestCases'
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     6
	poolDictionaries:''
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     7
	category:'Languages-Java-JUnit'
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     8
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
     9
853
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    10
TestletTestCaseProxy class instanceVariableNames:'javaClassName shouldFork'
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    11
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    12
"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    13
 The following class instance variables are inherited by this class:
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    14
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    15
	TestCase - lastTestRunResultOrNil lastTestRunsPassedTests lastTestRunsFailedTests lastTestRunsErrorTests
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    16
	TestAsserter - 
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    17
	Object - 
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    18
"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    19
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    20
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    21
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    22
!TestletTestCaseProxy class methodsFor:'initialization'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    23
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    24
initialize
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    25
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    26
    TestCases := Dictionary new.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    27
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    28
    "Created: / 01-03-2011 / 10:43:45 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    29
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    30
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    31
setJavaClassName: aSymbol
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    32
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    33
    javaClassName ifNotNil:
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    34
        [self error: 'Attempting to set java class name twice'].
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    35
    javaClassName := aSymbol.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    36
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    37
    "Created: / 01-03-2011 / 10:43:05 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    38
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    39
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    40
!TestletTestCaseProxy class methodsFor:'accessing'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    41
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    42
javaClass
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    43
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    44
    ^Java at: javaClassName
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    45
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    46
    "Created: / 01-03-2011 / 11:30:29 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    47
    "Modified: / 01-03-2011 / 14:48:30 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    48
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    49
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    50
javaClassName
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    51
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    52
    ^javaClassName
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    53
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    54
    "Created: / 01-03-2011 / 11:30:56 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    55
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    56
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    57
lookupHierarchyRoot
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    58
    ^ TestletTestCaseProxy
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    59
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    60
    "Created: / 01-03-2011 / 11:41:59 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    61
    "Modified: / 01-03-2011 / 14:54:55 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    62
    "Modified: / 29-04-2011 / 10:25:26 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    63
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    64
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    65
selector: aSymbol
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    66
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    67
    ^super selector: aSymbol
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    68
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    69
    "Created: / 01-03-2011 / 11:55:18 / Jan Vrany <jan.vrany@fit.cvut.cz>"
853
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    70
!
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    71
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    72
shouldFork
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    73
    ^ shouldFork ? false
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    74
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    75
    "Modified: / 13-06-2011 / 16:34:35 / Jan Vrany <jan.vrany@fit.cvut.cz>"
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    76
!
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    77
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    78
shouldFork:something
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
    79
    shouldFork := something.
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    80
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    81
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    82
!TestletTestCaseProxy class methodsFor:'private'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    83
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    84
testSelectors
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    85
    "testlet always has only one test method, but maybe for the future.."
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    86
820
beb45cce2856 Mauve test integration works.. and that's the bad news, there are sooo many failures.. so back to the beginning, let's fix natives..
hlopkmar
parents: 761
diff changeset
    87
    ^ #( #'test(Lgnu.testlet.TestHarness;)' ).
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    88
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    89
    "Created: / 01-03-2011 / 10:49:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    90
    "Modified: / 03-03-2011 / 00:34:39 / Marcel Hlopko <hlopik@gmail.com>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    91
    "Modified: / 04-03-2011 / 00:05:51 / Jan Vrany <jan.vrany@fit.cvut.cz>"
820
beb45cce2856 Mauve test integration works.. and that's the bad news, there are sooo many failures.. so back to the beginning, let's fix natives..
hlopkmar
parents: 761
diff changeset
    92
    "Modified: / 29-05-2011 / 22:54:06 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    93
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    94
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    95
!TestletTestCaseProxy class methodsFor:'queries'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
    96
854
e165b3da9adb Fixes for running tests in separate processes (required since VM often crash)
vranyj1
parents: 853
diff changeset
    97
isTestlet
e165b3da9adb Fixes for running tests in separate processes (required since VM often crash)
vranyj1
parents: 853
diff changeset
    98
	^ true
e165b3da9adb Fixes for running tests in separate processes (required since VM often crash)
vranyj1
parents: 853
diff changeset
    99
e165b3da9adb Fixes for running tests in separate processes (required since VM often crash)
vranyj1
parents: 853
diff changeset
   100
!
e165b3da9adb Fixes for running tests in separate processes (required since VM often crash)
vranyj1
parents: 853
diff changeset
   101
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   102
isAbstract
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   103
    ^ self == TestletTestCaseProxy
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   104
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   105
    "Created: / 28-02-2011 / 22:32:46 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   106
    "Modified: / 01-03-2011 / 14:54:58 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   107
    "Modified: / 29-04-2011 / 10:21:51 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   108
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   109
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   110
!TestletTestCaseProxy class methodsFor:'subclass creation'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   111
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   112
for: javaClass 
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   113
    "Answers a new (anonymous) testcase proxy for
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   114
     given javaClass"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   115
    
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   116
    | meta  cls  name |
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   117
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   118
    self assert: javaClass isJavaClass description: 'Not a java class'.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   119
    self assert: javaClass isTestletLike
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   120
        description: 'Not a testcase-like class'.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   121
    name := javaClass name.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   122
    TestCases at: name ifPresent: [:c | ^ c ].
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   123
    meta := Metaclass new.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   124
    meta setSuperclass: TestletTestCaseProxy class.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   125
    meta instSize: TestletTestCaseProxy class instSize.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   126
    cls := meta new.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   127
    cls setSuperclass: TestletTestCaseProxy.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   128
    cls flags: TestletTestCaseProxy flags.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   129
    cls instSize: TestletTestCaseProxy instSize.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   130
    cls setJavaClassName: name.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   131
    cls 
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   132
        setName: ('TestletTestCase for: (Java classForName: ' , name storeString 
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   133
                , ')') asSymbol.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   134
    cls setCategory: javaClass category.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   135
    TestCases at: name put: cls.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   136
    ^ cls
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   137
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   138
    "Created: / 01-03-2011 / 10:30:17 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   139
    "Modified: / 03-03-2011 / 00:20:49 / Marcel Hlopko <hlopik@gmail.com>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   140
    "Modified: / 01-04-2011 / 16:02:45 / Jan Vrany <jan.vrany@fit.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   141
    "Modified: / 29-04-2011 / 10:21:39 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   142
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   143
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   144
!TestletTestCaseProxy methodsFor:'accessing'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   145
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   146
javaClass
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   147
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   148
    | javaClass |
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   149
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   150
    self 
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   151
        assert: (javaClass := self class javaClass) isJavaClass
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   152
        description: 'java class does not exists'.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   153
    ^javaClass
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   154
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   155
    "Created: / 01-03-2011 / 14:48:17 / Jan Vrany <jan.vrany@fit.cvut.cz>"
855
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   156
!
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   157
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   158
nameForHDTestReport
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   159
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   160
    ^(self class javaClassName copyReplaceAll:$/ with: $.) copyTo: (self class javaClassName lastIndexOf: $/) - 1.
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   161
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   162
    "Created: / 01-04-2011 / 16:10:34 / Jan Vrany <jan.vrany@fit.cvut.cz>"
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   163
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   164
!
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   165
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   166
selectorForHDTestReport
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   167
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   168
    ^self class javaClassName copyFrom: 
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   169
		(self class javaClassName lastIndexOf: $/) + 1
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   170
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   171
809b1dc41615 use nameForHDTestReport and selectorForHDTestReport to identify test
vranyj1
parents: 854
diff changeset
   172
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   173
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   174
826
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   175
!TestletTestCaseProxy methodsFor:'error handling'!
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   176
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   177
doesNotUnderstand: aMessage
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   178
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   179
    aMessage selector == #'check(Z)V' ifTrue: [
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   180
        aMessage arg1 == 0 ifTrue:
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   181
            [TestResult failure sunitSignalWith: 'Testlet failed']
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   182
    ] ifFalse:[ aMessage selector == #'check(ZLjava/lang/String;)V' ifTrue:[
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   183
        aMessage arg1 == 0 ifTrue:        
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   184
            [TestResult failure sunitSignalWith: (Java as_ST_String: aMessage arguments second)]
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   185
    ]].
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   186
    (harness respondsTo: aMessage selector) ifTrue:
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   187
        [^aMessage sendTo: harness].
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   188
    ^super doesNotUnderstand: aMessage
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   189
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   190
    "Created: / 31-05-2011 / 16:30:48 / Jan Vrany <jan.vrany@fit.cvut.cz>"
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   191
! !
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   192
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   193
!TestletTestCaseProxy methodsFor:'private'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   194
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   195
harnessMock
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   196
    ^ (Java classForName: 'stx.libjava.tests.mocks.TestletHarnessMock') new.
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   197
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   198
    "Modified: / 29-04-2011 / 10:52:53 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   199
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   200
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   201
performTest
826
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   202
    | handlerBlock |
824
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   203
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   204
    handlerBlock := [:ex | TestResult failure sunitSignalWith: ex description].
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   205
826
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   206
    harness := self harnessMock.
820
beb45cce2856 Mauve test integration works.. and that's the bad news, there are sooo many failures.. so back to the beginning, let's fix natives..
hlopkmar
parents: 761
diff changeset
   207
    
824
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   208
    [ JavaVM unimplementedNativeMethodSignal 
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   209
        handle:
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   210
            handlerBlock
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   211
        do: [
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   212
            self javaClass new 
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   213
                perform: 'test(Lgnu/testlet/TestHarness;)V' sunitAsSymbol
826
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   214
                with: self
824
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   215
       ].
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   216
    ] on: JavaError do: [:ex | 
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   217
        TestResult failure sunitSignalWith: ex description
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   218
    ].
26e719a7e88c Few fixes and native methods
vranyj1
parents: 820
diff changeset
   219
826
db53b9c842d7 - TestletTestCaseProxy: debugging support improved.
vranyj1
parents: 824
diff changeset
   220
    "/((harness instVarNamed: 'passed') = 0 ) ifTrue: [ TestResult failure sunitSignalWith: 'Test failed' ].
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   221
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   222
    "Created: / 01-03-2011 / 14:50:32 / Jan Vrany <jan.vrany@fit.cvut.cz>"
820
beb45cce2856 Mauve test integration works.. and that's the bad news, there are sooo many failures.. so back to the beginning, let's fix natives..
hlopkmar
parents: 761
diff changeset
   223
    "Modified: / 29-05-2011 / 23:19:07 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
853
aa9af509e506 TestletTestCaseProxy: added classvar to specify whether run the test in separate process
vranyj1
parents: 826
diff changeset
   224
    "Modified: / 13-06-2011 / 17:03:14 / Jan Vrany <jan.vrany@fit.cvut.cz>"
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   225
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   226
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   227
!TestletTestCaseProxy class methodsFor:'documentation'!
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   228
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   229
version_SVN
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   230
    ^ '$Id$'
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   231
! !
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   232
43e017ec7958 Merged with /branches/jk
vranyj1
parents:
diff changeset
   233
TestletTestCaseProxy initialize!