SUnit.js 58 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814
  1. define("amber_core/SUnit", ["amber/boot", "amber_core/Kernel-Objects", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Infrastructure", "amber_core/Kernel-Classes"], function($boot){"use strict";
  2. var $core=$boot.api,nil=$boot.nil,$recv=$boot.asReceiver,$globals=$boot.globals;
  3. $core.addPackage('SUnit');
  4. $core.packages["SUnit"].innerEval = function (expr) { return eval(expr); };
  5. $core.packages["SUnit"].transport = {"type":"amd","amdNamespace":"amber_core"};
  6. $core.addClass('ResultAnnouncement', $globals.Object, ['result'], 'SUnit');
  7. //>>excludeStart("ide", pragmas.excludeIdeData);
  8. $globals.ResultAnnouncement.comment="I get signaled when a `TestCase` has been run.\x0a\x0aMy instances hold the result (instance of `TestResult`) of the test run.";
  9. //>>excludeEnd("ide");
  10. $core.addMethod(
  11. $core.method({
  12. selector: "result",
  13. protocol: 'accessing',
  14. fn: function (){
  15. var self=this;
  16. return self["@result"];
  17. },
  18. //>>excludeStart("ide", pragmas.excludeIdeData);
  19. args: [],
  20. source: "result\x0a\x09^ result",
  21. referencedClasses: [],
  22. //>>excludeEnd("ide");
  23. messageSends: []
  24. }),
  25. $globals.ResultAnnouncement);
  26. $core.addMethod(
  27. $core.method({
  28. selector: "result:",
  29. protocol: 'accessing',
  30. fn: function (aTestResult){
  31. var self=this;
  32. self["@result"]=aTestResult;
  33. return self;
  34. },
  35. //>>excludeStart("ide", pragmas.excludeIdeData);
  36. args: ["aTestResult"],
  37. source: "result: aTestResult\x0a\x09result := aTestResult",
  38. referencedClasses: [],
  39. //>>excludeEnd("ide");
  40. messageSends: []
  41. }),
  42. $globals.ResultAnnouncement);
  43. $core.addClass('TestCase', $globals.Object, ['testSelector', 'asyncTimeout', 'context'], 'SUnit');
  44. //>>excludeStart("ide", pragmas.excludeIdeData);
  45. $globals.TestCase.comment="I am an implementation of the command pattern to run a test.\x0a\x0a## API\x0a\x0aMy instances are created with the class method `#selector:`,\x0apassing the symbol that names the method to be executed when the test case runs.\x0a\x0aWhen you discover a new fixture, subclass `TestCase` and create a `#test...` method for the first test.\x0aAs that method develops and more `#test...` methods are added, you will find yourself refactoring temps\x0ainto instance variables for the objects in the fixture and overriding `#setUp` to initialize these variables.\x0aAs required, override `#tearDown` to nil references, release objects and deallocate.";
  46. //>>excludeEnd("ide");
  47. $core.addMethod(
  48. $core.method({
  49. selector: "assert:",
  50. protocol: 'testing',
  51. fn: function (aBoolean){
  52. var self=this;
  53. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  54. return $core.withContext(function($ctx1) {
  55. //>>excludeEnd("ctx");
  56. self._assert_description_(aBoolean,"Assertion failed");
  57. return self;
  58. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  59. }, function($ctx1) {$ctx1.fill(self,"assert:",{aBoolean:aBoolean},$globals.TestCase)});
  60. //>>excludeEnd("ctx");
  61. },
  62. //>>excludeStart("ide", pragmas.excludeIdeData);
  63. args: ["aBoolean"],
  64. source: "assert: aBoolean\x0a\x09self assert: aBoolean description: 'Assertion failed'",
  65. referencedClasses: [],
  66. //>>excludeEnd("ide");
  67. messageSends: ["assert:description:"]
  68. }),
  69. $globals.TestCase);
  70. $core.addMethod(
  71. $core.method({
  72. selector: "assert:description:",
  73. protocol: 'testing',
  74. fn: function (aBoolean,aString){
  75. var self=this;
  76. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  77. return $core.withContext(function($ctx1) {
  78. //>>excludeEnd("ctx");
  79. if(!$core.assert(aBoolean)){
  80. self._signalFailure_(aString);
  81. };
  82. return self;
  83. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  84. }, function($ctx1) {$ctx1.fill(self,"assert:description:",{aBoolean:aBoolean,aString:aString},$globals.TestCase)});
  85. //>>excludeEnd("ctx");
  86. },
  87. //>>excludeStart("ide", pragmas.excludeIdeData);
  88. args: ["aBoolean", "aString"],
  89. source: "assert: aBoolean description: aString\x0a\x09aBoolean ifFalse: [ self signalFailure: aString ]",
  90. referencedClasses: [],
  91. //>>excludeEnd("ide");
  92. messageSends: ["ifFalse:", "signalFailure:"]
  93. }),
  94. $globals.TestCase);
  95. $core.addMethod(
  96. $core.method({
  97. selector: "assert:equals:",
  98. protocol: 'testing',
  99. fn: function (actual,expected){
  100. var self=this;
  101. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  102. return $core.withContext(function($ctx1) {
  103. //>>excludeEnd("ctx");
  104. var $1,$5,$4,$3,$2;
  105. $1=$recv(actual).__eq(expected);
  106. $5=$recv(expected)._printString();
  107. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  108. $ctx1.sendIdx["printString"]=1;
  109. //>>excludeEnd("ctx");
  110. $4="Expected: ".__comma($5);
  111. $3=$recv($4).__comma(" but was: ");
  112. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  113. $ctx1.sendIdx[","]=2;
  114. //>>excludeEnd("ctx");
  115. $2=$recv($3).__comma($recv(actual)._printString());
  116. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  117. $ctx1.sendIdx[","]=1;
  118. //>>excludeEnd("ctx");
  119. return self._assert_description_($1,$2);
  120. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  121. }, function($ctx1) {$ctx1.fill(self,"assert:equals:",{actual:actual,expected:expected},$globals.TestCase)});
  122. //>>excludeEnd("ctx");
  123. },
  124. //>>excludeStart("ide", pragmas.excludeIdeData);
  125. args: ["actual", "expected"],
  126. source: "assert: actual equals: expected\x0a\x09^ self assert: (actual = expected) description: 'Expected: ', expected printString, ' but was: ', actual printString",
  127. referencedClasses: [],
  128. //>>excludeEnd("ide");
  129. messageSends: ["assert:description:", "=", ",", "printString"]
  130. }),
  131. $globals.TestCase);
  132. $core.addMethod(
  133. $core.method({
  134. selector: "async:",
  135. protocol: 'async',
  136. fn: function (aBlock){
  137. var self=this;
  138. var c;
  139. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  140. return $core.withContext(function($ctx1) {
  141. //>>excludeEnd("ctx");
  142. var $1;
  143. self._errorIfNotAsync_("#async");
  144. c=self["@context"];
  145. return (function(){
  146. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  147. return $core.withContext(function($ctx2) {
  148. //>>excludeEnd("ctx");
  149. $1=self._isAsync();
  150. if($core.assert($1)){
  151. return $recv(c)._execute_(aBlock);
  152. };
  153. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  154. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  155. //>>excludeEnd("ctx");
  156. });
  157. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  158. }, function($ctx1) {$ctx1.fill(self,"async:",{aBlock:aBlock,c:c},$globals.TestCase)});
  159. //>>excludeEnd("ctx");
  160. },
  161. //>>excludeStart("ide", pragmas.excludeIdeData);
  162. args: ["aBlock"],
  163. source: "async: aBlock\x0a\x09| c |\x0a\x09self errorIfNotAsync: '#async'.\x0a\x09c := context.\x0a\x09^ [ self isAsync ifTrue: [ c execute: aBlock ] ]",
  164. referencedClasses: [],
  165. //>>excludeEnd("ide");
  166. messageSends: ["errorIfNotAsync:", "ifTrue:", "isAsync", "execute:"]
  167. }),
  168. $globals.TestCase);
  169. $core.addMethod(
  170. $core.method({
  171. selector: "context:",
  172. protocol: 'accessing',
  173. fn: function (aRunningTestContext){
  174. var self=this;
  175. self["@context"]=aRunningTestContext;
  176. return self;
  177. },
  178. //>>excludeStart("ide", pragmas.excludeIdeData);
  179. args: ["aRunningTestContext"],
  180. source: "context: aRunningTestContext\x0a\x09context := aRunningTestContext",
  181. referencedClasses: [],
  182. //>>excludeEnd("ide");
  183. messageSends: []
  184. }),
  185. $globals.TestCase);
  186. $core.addMethod(
  187. $core.method({
  188. selector: "deny:",
  189. protocol: 'testing',
  190. fn: function (aBoolean){
  191. var self=this;
  192. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  193. return $core.withContext(function($ctx1) {
  194. //>>excludeEnd("ctx");
  195. self._assert_($recv(aBoolean)._not());
  196. return self;
  197. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  198. }, function($ctx1) {$ctx1.fill(self,"deny:",{aBoolean:aBoolean},$globals.TestCase)});
  199. //>>excludeEnd("ctx");
  200. },
  201. //>>excludeStart("ide", pragmas.excludeIdeData);
  202. args: ["aBoolean"],
  203. source: "deny: aBoolean\x0a\x09self assert: aBoolean not",
  204. referencedClasses: [],
  205. //>>excludeEnd("ide");
  206. messageSends: ["assert:", "not"]
  207. }),
  208. $globals.TestCase);
  209. $core.addMethod(
  210. $core.method({
  211. selector: "errorIfNotAsync:",
  212. protocol: 'error handling',
  213. fn: function (aString){
  214. var self=this;
  215. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  216. return $core.withContext(function($ctx1) {
  217. //>>excludeEnd("ctx");
  218. var $1;
  219. $1=self._isAsync();
  220. if(!$core.assert($1)){
  221. self._error_($recv(aString).__comma(" used without prior #timeout:"));
  222. };
  223. return self;
  224. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  225. }, function($ctx1) {$ctx1.fill(self,"errorIfNotAsync:",{aString:aString},$globals.TestCase)});
  226. //>>excludeEnd("ctx");
  227. },
  228. //>>excludeStart("ide", pragmas.excludeIdeData);
  229. args: ["aString"],
  230. source: "errorIfNotAsync: aString\x0a\x09self isAsync ifFalse: [\x0a\x09\x09self error: aString, ' used without prior #timeout:' ]",
  231. referencedClasses: [],
  232. //>>excludeEnd("ide");
  233. messageSends: ["ifFalse:", "isAsync", "error:", ","]
  234. }),
  235. $globals.TestCase);
  236. $core.addMethod(
  237. $core.method({
  238. selector: "finished",
  239. protocol: 'async',
  240. fn: function (){
  241. var self=this;
  242. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  243. return $core.withContext(function($ctx1) {
  244. //>>excludeEnd("ctx");
  245. self._errorIfNotAsync_("#finished");
  246. self["@asyncTimeout"]=nil;
  247. return self;
  248. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  249. }, function($ctx1) {$ctx1.fill(self,"finished",{},$globals.TestCase)});
  250. //>>excludeEnd("ctx");
  251. },
  252. //>>excludeStart("ide", pragmas.excludeIdeData);
  253. args: [],
  254. source: "finished\x0a\x09self errorIfNotAsync: '#finished'.\x0a\x09asyncTimeout := nil",
  255. referencedClasses: [],
  256. //>>excludeEnd("ide");
  257. messageSends: ["errorIfNotAsync:"]
  258. }),
  259. $globals.TestCase);
  260. $core.addMethod(
  261. $core.method({
  262. selector: "isAsync",
  263. protocol: 'testing',
  264. fn: function (){
  265. var self=this;
  266. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  267. return $core.withContext(function($ctx1) {
  268. //>>excludeEnd("ctx");
  269. return $recv(self["@asyncTimeout"])._notNil();
  270. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  271. }, function($ctx1) {$ctx1.fill(self,"isAsync",{},$globals.TestCase)});
  272. //>>excludeEnd("ctx");
  273. },
  274. //>>excludeStart("ide", pragmas.excludeIdeData);
  275. args: [],
  276. source: "isAsync\x0a\x09^ asyncTimeout notNil",
  277. referencedClasses: [],
  278. //>>excludeEnd("ide");
  279. messageSends: ["notNil"]
  280. }),
  281. $globals.TestCase);
  282. $core.addMethod(
  283. $core.method({
  284. selector: "performTest",
  285. protocol: 'running',
  286. fn: function (){
  287. var self=this;
  288. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  289. return $core.withContext(function($ctx1) {
  290. //>>excludeEnd("ctx");
  291. self["@asyncTimeout"]=nil;
  292. self._perform_(self._selector());
  293. return self;
  294. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  295. }, function($ctx1) {$ctx1.fill(self,"performTest",{},$globals.TestCase)});
  296. //>>excludeEnd("ctx");
  297. },
  298. //>>excludeStart("ide", pragmas.excludeIdeData);
  299. args: [],
  300. source: "performTest\x0a\x09asyncTimeout := nil.\x0a\x09self perform: self selector",
  301. referencedClasses: [],
  302. //>>excludeEnd("ide");
  303. messageSends: ["perform:", "selector"]
  304. }),
  305. $globals.TestCase);
  306. $core.addMethod(
  307. $core.method({
  308. selector: "runCase",
  309. protocol: 'running',
  310. fn: function (){
  311. var self=this;
  312. function $TestContext(){return $globals.TestContext||(typeof TestContext=="undefined"?nil:TestContext)}
  313. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  314. return $core.withContext(function($ctx1) {
  315. //>>excludeEnd("ctx");
  316. $recv($recv($TestContext())._testCase_(self))._start();
  317. return self;
  318. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  319. }, function($ctx1) {$ctx1.fill(self,"runCase",{},$globals.TestCase)});
  320. //>>excludeEnd("ctx");
  321. },
  322. //>>excludeStart("ide", pragmas.excludeIdeData);
  323. args: [],
  324. source: "runCase\x0a\x09\x22Runs a test case in isolated context, leaking all errors.\x22\x0a\x0a\x09(TestContext testCase: self) start",
  325. referencedClasses: ["TestContext"],
  326. //>>excludeEnd("ide");
  327. messageSends: ["start", "testCase:"]
  328. }),
  329. $globals.TestCase);
  330. $core.addMethod(
  331. $core.method({
  332. selector: "selector",
  333. protocol: 'accessing',
  334. fn: function (){
  335. var self=this;
  336. return self["@testSelector"];
  337. },
  338. //>>excludeStart("ide", pragmas.excludeIdeData);
  339. args: [],
  340. source: "selector\x0a\x09^ testSelector",
  341. referencedClasses: [],
  342. //>>excludeEnd("ide");
  343. messageSends: []
  344. }),
  345. $globals.TestCase);
  346. $core.addMethod(
  347. $core.method({
  348. selector: "setTestSelector:",
  349. protocol: 'accessing',
  350. fn: function (aSelector){
  351. var self=this;
  352. self["@testSelector"]=aSelector;
  353. return self;
  354. },
  355. //>>excludeStart("ide", pragmas.excludeIdeData);
  356. args: ["aSelector"],
  357. source: "setTestSelector: aSelector\x0a\x09testSelector := aSelector",
  358. referencedClasses: [],
  359. //>>excludeEnd("ide");
  360. messageSends: []
  361. }),
  362. $globals.TestCase);
  363. $core.addMethod(
  364. $core.method({
  365. selector: "setUp",
  366. protocol: 'running',
  367. fn: function (){
  368. var self=this;
  369. return self;
  370. },
  371. //>>excludeStart("ide", pragmas.excludeIdeData);
  372. args: [],
  373. source: "setUp",
  374. referencedClasses: [],
  375. //>>excludeEnd("ide");
  376. messageSends: []
  377. }),
  378. $globals.TestCase);
  379. $core.addMethod(
  380. $core.method({
  381. selector: "should:",
  382. protocol: 'testing',
  383. fn: function (aBlock){
  384. var self=this;
  385. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  386. return $core.withContext(function($ctx1) {
  387. //>>excludeEnd("ctx");
  388. self._assert_($recv(aBlock)._value());
  389. return self;
  390. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  391. }, function($ctx1) {$ctx1.fill(self,"should:",{aBlock:aBlock},$globals.TestCase)});
  392. //>>excludeEnd("ctx");
  393. },
  394. //>>excludeStart("ide", pragmas.excludeIdeData);
  395. args: ["aBlock"],
  396. source: "should: aBlock\x0a\x09self assert: aBlock value",
  397. referencedClasses: [],
  398. //>>excludeEnd("ide");
  399. messageSends: ["assert:", "value"]
  400. }),
  401. $globals.TestCase);
  402. $core.addMethod(
  403. $core.method({
  404. selector: "should:raise:",
  405. protocol: 'testing',
  406. fn: function (aBlock,anExceptionClass){
  407. var self=this;
  408. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  409. return $core.withContext(function($ctx1) {
  410. //>>excludeEnd("ctx");
  411. self._assert_($recv((function(){
  412. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  413. return $core.withContext(function($ctx2) {
  414. //>>excludeEnd("ctx");
  415. $recv(aBlock)._value();
  416. return false;
  417. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  418. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  419. //>>excludeEnd("ctx");
  420. }))._on_do_(anExceptionClass,(function(ex){
  421. return true;
  422. })));
  423. return self;
  424. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  425. }, function($ctx1) {$ctx1.fill(self,"should:raise:",{aBlock:aBlock,anExceptionClass:anExceptionClass},$globals.TestCase)});
  426. //>>excludeEnd("ctx");
  427. },
  428. //>>excludeStart("ide", pragmas.excludeIdeData);
  429. args: ["aBlock", "anExceptionClass"],
  430. source: "should: aBlock raise: anExceptionClass\x0a\x09self assert: ([ aBlock value. false ]\x0a\x09\x09on: anExceptionClass\x0a\x09\x09do: [ :ex | true ])",
  431. referencedClasses: [],
  432. //>>excludeEnd("ide");
  433. messageSends: ["assert:", "on:do:", "value"]
  434. }),
  435. $globals.TestCase);
  436. $core.addMethod(
  437. $core.method({
  438. selector: "shouldnt:raise:",
  439. protocol: 'testing',
  440. fn: function (aBlock,anExceptionClass){
  441. var self=this;
  442. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  443. return $core.withContext(function($ctx1) {
  444. //>>excludeEnd("ctx");
  445. self._assert_($recv((function(){
  446. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  447. return $core.withContext(function($ctx2) {
  448. //>>excludeEnd("ctx");
  449. $recv(aBlock)._value();
  450. return true;
  451. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  452. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  453. //>>excludeEnd("ctx");
  454. }))._on_do_(anExceptionClass,(function(ex){
  455. return false;
  456. })));
  457. return self;
  458. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  459. }, function($ctx1) {$ctx1.fill(self,"shouldnt:raise:",{aBlock:aBlock,anExceptionClass:anExceptionClass},$globals.TestCase)});
  460. //>>excludeEnd("ctx");
  461. },
  462. //>>excludeStart("ide", pragmas.excludeIdeData);
  463. args: ["aBlock", "anExceptionClass"],
  464. source: "shouldnt: aBlock raise: anExceptionClass\x0a\x09self assert: ([ aBlock value. true ]\x0a\x09\x09on: anExceptionClass\x0a\x09\x09do: [ :ex | false ])",
  465. referencedClasses: [],
  466. //>>excludeEnd("ide");
  467. messageSends: ["assert:", "on:do:", "value"]
  468. }),
  469. $globals.TestCase);
  470. $core.addMethod(
  471. $core.method({
  472. selector: "signalFailure:",
  473. protocol: 'private',
  474. fn: function (aString){
  475. var self=this;
  476. function $TestFailure(){return $globals.TestFailure||(typeof TestFailure=="undefined"?nil:TestFailure)}
  477. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  478. return $core.withContext(function($ctx1) {
  479. //>>excludeEnd("ctx");
  480. var $1;
  481. $1=$recv($TestFailure())._new();
  482. $recv($1)._messageText_(aString);
  483. $recv($1)._signal();
  484. return self;
  485. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  486. }, function($ctx1) {$ctx1.fill(self,"signalFailure:",{aString:aString},$globals.TestCase)});
  487. //>>excludeEnd("ctx");
  488. },
  489. //>>excludeStart("ide", pragmas.excludeIdeData);
  490. args: ["aString"],
  491. source: "signalFailure: aString\x0a\x09TestFailure new\x0a\x09\x09messageText: aString;\x0a\x09\x09signal",
  492. referencedClasses: ["TestFailure"],
  493. //>>excludeEnd("ide");
  494. messageSends: ["messageText:", "new", "signal"]
  495. }),
  496. $globals.TestCase);
  497. $core.addMethod(
  498. $core.method({
  499. selector: "tearDown",
  500. protocol: 'running',
  501. fn: function (){
  502. var self=this;
  503. return self;
  504. },
  505. //>>excludeStart("ide", pragmas.excludeIdeData);
  506. args: [],
  507. source: "tearDown",
  508. referencedClasses: [],
  509. //>>excludeEnd("ide");
  510. messageSends: []
  511. }),
  512. $globals.TestCase);
  513. $core.addMethod(
  514. $core.method({
  515. selector: "timeout:",
  516. protocol: 'async',
  517. fn: function (aNumber){
  518. var self=this;
  519. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  520. return $core.withContext(function($ctx1) {
  521. //>>excludeEnd("ctx");
  522. var $1,$receiver;
  523. $1=self["@asyncTimeout"];
  524. if(($receiver = $1) == null || $receiver.isNil){
  525. $1;
  526. } else {
  527. $recv(self["@asyncTimeout"])._clearTimeout();
  528. };
  529. self["@asyncTimeout"]=(0);
  530. self["@asyncTimeout"]=$recv(self._async_((function(){
  531. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  532. return $core.withContext(function($ctx2) {
  533. //>>excludeEnd("ctx");
  534. return self._assert_description_(false,"SUnit grace time exhausted");
  535. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  536. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
  537. //>>excludeEnd("ctx");
  538. })))._valueWithTimeout_(aNumber);
  539. return self;
  540. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  541. }, function($ctx1) {$ctx1.fill(self,"timeout:",{aNumber:aNumber},$globals.TestCase)});
  542. //>>excludeEnd("ctx");
  543. },
  544. //>>excludeStart("ide", pragmas.excludeIdeData);
  545. args: ["aNumber"],
  546. source: "timeout: aNumber\x0a\x09\x22Set a grace time timeout in milliseconds to run the test asynchronously\x22\x0a\x09\x0a\x09asyncTimeout ifNotNil: [ asyncTimeout clearTimeout ].\x0a\x09\x0a\x09\x22to allow #async: message send without throwing an error\x22\x0a\x09asyncTimeout := 0.\x0a\x09\x0a\x09asyncTimeout := (self async: [\x0a\x09\x09self assert: false description: 'SUnit grace time exhausted' ])\x0a\x09\x09\x09valueWithTimeout: aNumber",
  547. referencedClasses: [],
  548. //>>excludeEnd("ide");
  549. messageSends: ["ifNotNil:", "clearTimeout", "valueWithTimeout:", "async:", "assert:description:"]
  550. }),
  551. $globals.TestCase);
  552. $core.addMethod(
  553. $core.method({
  554. selector: "allTestSelectors",
  555. protocol: 'accessing',
  556. fn: function (){
  557. var self=this;
  558. var selectors;
  559. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  560. return $core.withContext(function($ctx1) {
  561. //>>excludeEnd("ctx");
  562. var $1;
  563. selectors=self._testSelectors();
  564. $1=self._shouldInheritSelectors();
  565. if($core.assert($1)){
  566. $recv(selectors)._addAll_($recv(self._superclass())._allTestSelectors());
  567. };
  568. return selectors;
  569. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  570. }, function($ctx1) {$ctx1.fill(self,"allTestSelectors",{selectors:selectors},$globals.TestCase.klass)});
  571. //>>excludeEnd("ctx");
  572. },
  573. //>>excludeStart("ide", pragmas.excludeIdeData);
  574. args: [],
  575. source: "allTestSelectors\x0a\x09| selectors |\x0a\x09selectors := self testSelectors.\x0a\x09self shouldInheritSelectors ifTrue: [\x0a\x09\x09selectors addAll: self superclass allTestSelectors ].\x0a\x09^ selectors",
  576. referencedClasses: [],
  577. //>>excludeEnd("ide");
  578. messageSends: ["testSelectors", "ifTrue:", "shouldInheritSelectors", "addAll:", "allTestSelectors", "superclass"]
  579. }),
  580. $globals.TestCase.klass);
  581. $core.addMethod(
  582. $core.method({
  583. selector: "buildSuite",
  584. protocol: 'accessing',
  585. fn: function (){
  586. var self=this;
  587. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  588. return $core.withContext(function($ctx1) {
  589. //>>excludeEnd("ctx");
  590. return $recv(self._allTestSelectors())._collect_((function(each){
  591. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  592. return $core.withContext(function($ctx2) {
  593. //>>excludeEnd("ctx");
  594. return self._selector_(each);
  595. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  596. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  597. //>>excludeEnd("ctx");
  598. }));
  599. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  600. }, function($ctx1) {$ctx1.fill(self,"buildSuite",{},$globals.TestCase.klass)});
  601. //>>excludeEnd("ctx");
  602. },
  603. //>>excludeStart("ide", pragmas.excludeIdeData);
  604. args: [],
  605. source: "buildSuite\x0a\x09^ self allTestSelectors collect: [ :each | self selector: each ]",
  606. referencedClasses: [],
  607. //>>excludeEnd("ide");
  608. messageSends: ["collect:", "allTestSelectors", "selector:"]
  609. }),
  610. $globals.TestCase.klass);
  611. $core.addMethod(
  612. $core.method({
  613. selector: "classTag",
  614. protocol: 'accessing',
  615. fn: function (){
  616. var self=this;
  617. return "test";
  618. },
  619. //>>excludeStart("ide", pragmas.excludeIdeData);
  620. args: [],
  621. source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'test'",
  622. referencedClasses: [],
  623. //>>excludeEnd("ide");
  624. messageSends: []
  625. }),
  626. $globals.TestCase.klass);
  627. $core.addMethod(
  628. $core.method({
  629. selector: "isAbstract",
  630. protocol: 'testing',
  631. fn: function (){
  632. var self=this;
  633. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  634. return $core.withContext(function($ctx1) {
  635. //>>excludeEnd("ctx");
  636. return $recv(self._name()).__eq("TestCase");
  637. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  638. }, function($ctx1) {$ctx1.fill(self,"isAbstract",{},$globals.TestCase.klass)});
  639. //>>excludeEnd("ctx");
  640. },
  641. //>>excludeStart("ide", pragmas.excludeIdeData);
  642. args: [],
  643. source: "isAbstract\x0a\x09^ self name = 'TestCase'",
  644. referencedClasses: [],
  645. //>>excludeEnd("ide");
  646. messageSends: ["=", "name"]
  647. }),
  648. $globals.TestCase.klass);
  649. $core.addMethod(
  650. $core.method({
  651. selector: "lookupHierarchyRoot",
  652. protocol: 'accessing',
  653. fn: function (){
  654. var self=this;
  655. function $TestCase(){return $globals.TestCase||(typeof TestCase=="undefined"?nil:TestCase)}
  656. return $TestCase();
  657. },
  658. //>>excludeStart("ide", pragmas.excludeIdeData);
  659. args: [],
  660. source: "lookupHierarchyRoot\x0a\x09^ TestCase",
  661. referencedClasses: ["TestCase"],
  662. //>>excludeEnd("ide");
  663. messageSends: []
  664. }),
  665. $globals.TestCase.klass);
  666. $core.addMethod(
  667. $core.method({
  668. selector: "selector:",
  669. protocol: 'accessing',
  670. fn: function (aSelector){
  671. var self=this;
  672. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  673. return $core.withContext(function($ctx1) {
  674. //>>excludeEnd("ctx");
  675. var $1;
  676. $1=self._new();
  677. $recv($1)._setTestSelector_(aSelector);
  678. return $recv($1)._yourself();
  679. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  680. }, function($ctx1) {$ctx1.fill(self,"selector:",{aSelector:aSelector},$globals.TestCase.klass)});
  681. //>>excludeEnd("ctx");
  682. },
  683. //>>excludeStart("ide", pragmas.excludeIdeData);
  684. args: ["aSelector"],
  685. source: "selector: aSelector\x0a\x09^ self new\x0a\x09\x09setTestSelector: aSelector;\x0a\x09\x09yourself",
  686. referencedClasses: [],
  687. //>>excludeEnd("ide");
  688. messageSends: ["setTestSelector:", "new", "yourself"]
  689. }),
  690. $globals.TestCase.klass);
  691. $core.addMethod(
  692. $core.method({
  693. selector: "shouldInheritSelectors",
  694. protocol: 'testing',
  695. fn: function (){
  696. var self=this;
  697. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  698. return $core.withContext(function($ctx1) {
  699. //>>excludeEnd("ctx");
  700. return self.__tild_eq(self._lookupHierarchyRoot());
  701. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  702. }, function($ctx1) {$ctx1.fill(self,"shouldInheritSelectors",{},$globals.TestCase.klass)});
  703. //>>excludeEnd("ctx");
  704. },
  705. //>>excludeStart("ide", pragmas.excludeIdeData);
  706. args: [],
  707. source: "shouldInheritSelectors\x0a\x09^ self ~= self lookupHierarchyRoot",
  708. referencedClasses: [],
  709. //>>excludeEnd("ide");
  710. messageSends: ["~=", "lookupHierarchyRoot"]
  711. }),
  712. $globals.TestCase.klass);
  713. $core.addMethod(
  714. $core.method({
  715. selector: "testSelectors",
  716. protocol: 'accessing',
  717. fn: function (){
  718. var self=this;
  719. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  720. return $core.withContext(function($ctx1) {
  721. //>>excludeEnd("ctx");
  722. return $recv($recv(self._methodDictionary())._keys())._select_((function(each){
  723. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  724. return $core.withContext(function($ctx2) {
  725. //>>excludeEnd("ctx");
  726. return $recv(each)._match_("^test");
  727. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  728. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  729. //>>excludeEnd("ctx");
  730. }));
  731. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  732. }, function($ctx1) {$ctx1.fill(self,"testSelectors",{},$globals.TestCase.klass)});
  733. //>>excludeEnd("ctx");
  734. },
  735. //>>excludeStart("ide", pragmas.excludeIdeData);
  736. args: [],
  737. source: "testSelectors\x0a\x09^ self methodDictionary keys select: [ :each | each match: '^test' ]",
  738. referencedClasses: [],
  739. //>>excludeEnd("ide");
  740. messageSends: ["select:", "keys", "methodDictionary", "match:"]
  741. }),
  742. $globals.TestCase.klass);
  743. $core.addClass('TestContext', $globals.Object, ['testCase'], 'SUnit');
  744. //>>excludeStart("ide", pragmas.excludeIdeData);
  745. $globals.TestContext.comment="I govern running a particular test case.\x0a\x0aMy main added value is `#execute:` method which runs a block as a part of test case (restores context, nilling it afterwards, cleaning/calling `#tearDown` as appropriate for sync/async scenario).";
  746. //>>excludeEnd("ide");
  747. $core.addMethod(
  748. $core.method({
  749. selector: "execute:",
  750. protocol: 'running',
  751. fn: function (aBlock){
  752. var self=this;
  753. var failed;
  754. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  755. return $core.withContext(function($ctx1) {
  756. //>>excludeEnd("ctx");
  757. var $1,$2;
  758. $recv(self["@testCase"])._context_(self);
  759. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  760. $ctx1.sendIdx["context:"]=1;
  761. //>>excludeEnd("ctx");
  762. $recv((function(){
  763. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  764. return $core.withContext(function($ctx2) {
  765. //>>excludeEnd("ctx");
  766. failed=true;
  767. failed;
  768. $recv(aBlock)._value();
  769. failed=false;
  770. return failed;
  771. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  772. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  773. //>>excludeEnd("ctx");
  774. }))._ensure_((function(){
  775. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  776. return $core.withContext(function($ctx2) {
  777. //>>excludeEnd("ctx");
  778. $recv(self["@testCase"])._context_(nil);
  779. $1=$recv(failed)._and_((function(){
  780. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  781. return $core.withContext(function($ctx3) {
  782. //>>excludeEnd("ctx");
  783. return $recv(self["@testCase"])._isAsync();
  784. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  785. $ctx3.sendIdx["isAsync"]=1;
  786. //>>excludeEnd("ctx");
  787. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  788. }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
  789. //>>excludeEnd("ctx");
  790. }));
  791. if($core.assert($1)){
  792. $recv(self["@testCase"])._finished();
  793. };
  794. $2=$recv(self["@testCase"])._isAsync();
  795. if(!$core.assert($2)){
  796. return $recv(self["@testCase"])._tearDown();
  797. };
  798. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  799. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
  800. //>>excludeEnd("ctx");
  801. }));
  802. return self;
  803. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  804. }, function($ctx1) {$ctx1.fill(self,"execute:",{aBlock:aBlock,failed:failed},$globals.TestContext)});
  805. //>>excludeEnd("ctx");
  806. },
  807. //>>excludeStart("ide", pragmas.excludeIdeData);
  808. args: ["aBlock"],
  809. source: "execute: aBlock\x0a\x09| failed |\x0a\x09\x0a\x09testCase context: self.\x0a\x09[\x0a\x09\x09failed := true.\x0a\x09\x09aBlock value.\x0a\x09\x09failed := false\x0a\x09]\x0a\x09\x09ensure: [\x0a\x09\x09\x09testCase context: nil.\x0a\x09\x09\x09\x0a\x09\x09\x09(failed and: [ testCase isAsync ]) ifTrue: [\x0a\x09\x09\x09\x09testCase finished ].\x0a\x09\x09\x09testCase isAsync ifFalse: [\x0a\x09\x09\x09\x09testCase tearDown ] ]",
  810. referencedClasses: [],
  811. //>>excludeEnd("ide");
  812. messageSends: ["context:", "ensure:", "value", "ifTrue:", "and:", "isAsync", "finished", "ifFalse:", "tearDown"]
  813. }),
  814. $globals.TestContext);
  815. $core.addMethod(
  816. $core.method({
  817. selector: "start",
  818. protocol: 'running',
  819. fn: function (){
  820. var self=this;
  821. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  822. return $core.withContext(function($ctx1) {
  823. //>>excludeEnd("ctx");
  824. self._execute_((function(){
  825. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  826. return $core.withContext(function($ctx2) {
  827. //>>excludeEnd("ctx");
  828. $recv(self["@testCase"])._setUp();
  829. return $recv(self["@testCase"])._performTest();
  830. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  831. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  832. //>>excludeEnd("ctx");
  833. }));
  834. return self;
  835. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  836. }, function($ctx1) {$ctx1.fill(self,"start",{},$globals.TestContext)});
  837. //>>excludeEnd("ctx");
  838. },
  839. //>>excludeStart("ide", pragmas.excludeIdeData);
  840. args: [],
  841. source: "start\x0a\x09self execute: [\x0a\x09\x09testCase setUp.\x0a\x09\x09testCase performTest ]",
  842. referencedClasses: [],
  843. //>>excludeEnd("ide");
  844. messageSends: ["execute:", "setUp", "performTest"]
  845. }),
  846. $globals.TestContext);
  847. $core.addMethod(
  848. $core.method({
  849. selector: "testCase:",
  850. protocol: 'accessing',
  851. fn: function (aTestCase){
  852. var self=this;
  853. self["@testCase"]=aTestCase;
  854. return self;
  855. },
  856. //>>excludeStart("ide", pragmas.excludeIdeData);
  857. args: ["aTestCase"],
  858. source: "testCase: aTestCase\x0a\x09testCase := aTestCase",
  859. referencedClasses: [],
  860. //>>excludeEnd("ide");
  861. messageSends: []
  862. }),
  863. $globals.TestContext);
  864. $core.addMethod(
  865. $core.method({
  866. selector: "testCase:",
  867. protocol: 'instance creation',
  868. fn: function (aTestCase){
  869. var self=this;
  870. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  871. return $core.withContext(function($ctx1) {
  872. //>>excludeEnd("ctx");
  873. var $1;
  874. $1=self._new();
  875. $recv($1)._testCase_(aTestCase);
  876. return $recv($1)._yourself();
  877. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  878. }, function($ctx1) {$ctx1.fill(self,"testCase:",{aTestCase:aTestCase},$globals.TestContext.klass)});
  879. //>>excludeEnd("ctx");
  880. },
  881. //>>excludeStart("ide", pragmas.excludeIdeData);
  882. args: ["aTestCase"],
  883. source: "testCase: aTestCase\x0a\x09^ self new\x0a\x09\x09testCase: aTestCase;\x0a\x09\x09yourself",
  884. referencedClasses: [],
  885. //>>excludeEnd("ide");
  886. messageSends: ["testCase:", "new", "yourself"]
  887. }),
  888. $globals.TestContext.klass);
  889. $core.addClass('ReportingTestContext', $globals.TestContext, ['finished', 'result'], 'SUnit');
  890. //>>excludeStart("ide", pragmas.excludeIdeData);
  891. $globals.ReportingTestContext.comment="I add `TestResult` reporting to `TestContext`.\x0a\x0aErrors are caught and save into a `TestResult`,\x0aWhen test case is finished (which can be later for async tests), a callback block is executed; this is used by a `TestSuiteRunner`.";
  892. //>>excludeEnd("ide");
  893. $core.addMethod(
  894. $core.method({
  895. selector: "execute:",
  896. protocol: 'running',
  897. fn: function (aBlock){
  898. var self=this;
  899. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  900. return $core.withContext(function($ctx1) {
  901. //>>excludeEnd("ctx");
  902. var $1;
  903. $recv((function(){
  904. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  905. return $core.withContext(function($ctx2) {
  906. //>>excludeEnd("ctx");
  907. return self._withErrorReporting_((function(){
  908. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  909. return $core.withContext(function($ctx3) {
  910. //>>excludeEnd("ctx");
  911. return (
  912. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  913. $ctx3.supercall = true,
  914. //>>excludeEnd("ctx");
  915. ($globals.ReportingTestContext.superclass||$boot.dnu).fn.prototype._execute_.apply($recv(self), [aBlock]));
  916. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  917. $ctx3.supercall = false;
  918. //>>excludeEnd("ctx");;
  919. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  920. }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
  921. //>>excludeEnd("ctx");
  922. }));
  923. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  924. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  925. //>>excludeEnd("ctx");
  926. }))._ensure_((function(){
  927. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  928. return $core.withContext(function($ctx2) {
  929. //>>excludeEnd("ctx");
  930. $1=$recv(self["@testCase"])._isAsync();
  931. if(!$core.assert($1)){
  932. $recv(self["@result"])._increaseRuns();
  933. return $recv(self["@finished"])._value();
  934. };
  935. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  936. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
  937. //>>excludeEnd("ctx");
  938. }));
  939. return self;
  940. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  941. }, function($ctx1) {$ctx1.fill(self,"execute:",{aBlock:aBlock},$globals.ReportingTestContext)});
  942. //>>excludeEnd("ctx");
  943. },
  944. //>>excludeStart("ide", pragmas.excludeIdeData);
  945. args: ["aBlock"],
  946. source: "execute: aBlock\x0a\x09[\x0a\x09\x09self withErrorReporting: [ super execute: aBlock ]\x0a\x09]\x0a\x09\x09ensure: [\x0a\x09\x09\x09testCase isAsync ifFalse: [\x0a\x09\x09\x09\x09result increaseRuns. finished value ] ]",
  947. referencedClasses: [],
  948. //>>excludeEnd("ide");
  949. messageSends: ["ensure:", "withErrorReporting:", "execute:", "ifFalse:", "isAsync", "increaseRuns", "value"]
  950. }),
  951. $globals.ReportingTestContext);
  952. $core.addMethod(
  953. $core.method({
  954. selector: "finished:",
  955. protocol: 'accessing',
  956. fn: function (aBlock){
  957. var self=this;
  958. self["@finished"]=aBlock;
  959. return self;
  960. },
  961. //>>excludeStart("ide", pragmas.excludeIdeData);
  962. args: ["aBlock"],
  963. source: "finished: aBlock\x0a\x09finished := aBlock",
  964. referencedClasses: [],
  965. //>>excludeEnd("ide");
  966. messageSends: []
  967. }),
  968. $globals.ReportingTestContext);
  969. $core.addMethod(
  970. $core.method({
  971. selector: "result:",
  972. protocol: 'accessing',
  973. fn: function (aTestResult){
  974. var self=this;
  975. self["@result"]=aTestResult;
  976. return self;
  977. },
  978. //>>excludeStart("ide", pragmas.excludeIdeData);
  979. args: ["aTestResult"],
  980. source: "result: aTestResult\x0a\x09result := aTestResult",
  981. referencedClasses: [],
  982. //>>excludeEnd("ide");
  983. messageSends: []
  984. }),
  985. $globals.ReportingTestContext);
  986. $core.addMethod(
  987. $core.method({
  988. selector: "withErrorReporting:",
  989. protocol: 'private',
  990. fn: function (aBlock){
  991. var self=this;
  992. function $TestFailure(){return $globals.TestFailure||(typeof TestFailure=="undefined"?nil:TestFailure)}
  993. function $Error(){return $globals.Error||(typeof Error=="undefined"?nil:Error)}
  994. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  995. return $core.withContext(function($ctx1) {
  996. //>>excludeEnd("ctx");
  997. $recv((function(){
  998. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  999. return $core.withContext(function($ctx2) {
  1000. //>>excludeEnd("ctx");
  1001. return $recv(aBlock)._on_do_($TestFailure(),(function(ex){
  1002. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1003. return $core.withContext(function($ctx3) {
  1004. //>>excludeEnd("ctx");
  1005. return $recv(self["@result"])._addFailure_(self["@testCase"]);
  1006. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1007. }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,2)});
  1008. //>>excludeEnd("ctx");
  1009. }));
  1010. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1011. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1012. //>>excludeEnd("ctx");
  1013. }))._on_do_($Error(),(function(ex){
  1014. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1015. return $core.withContext(function($ctx2) {
  1016. //>>excludeEnd("ctx");
  1017. return $recv(self["@result"])._addError_(self["@testCase"]);
  1018. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1019. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,3)});
  1020. //>>excludeEnd("ctx");
  1021. }));
  1022. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1023. $ctx1.sendIdx["on:do:"]=1;
  1024. //>>excludeEnd("ctx");
  1025. return self;
  1026. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1027. }, function($ctx1) {$ctx1.fill(self,"withErrorReporting:",{aBlock:aBlock},$globals.ReportingTestContext)});
  1028. //>>excludeEnd("ctx");
  1029. },
  1030. //>>excludeStart("ide", pragmas.excludeIdeData);
  1031. args: ["aBlock"],
  1032. source: "withErrorReporting: aBlock\x0a\x09[ aBlock\x0a\x09\x09on: TestFailure\x0a\x09\x09do: [ :ex | result addFailure: testCase ]\x0a\x09]\x0a\x09\x09on: Error\x0a\x09\x09do: [ :ex | result addError: testCase ]",
  1033. referencedClasses: ["TestFailure", "Error"],
  1034. //>>excludeEnd("ide");
  1035. messageSends: ["on:do:", "addFailure:", "addError:"]
  1036. }),
  1037. $globals.ReportingTestContext);
  1038. $core.addMethod(
  1039. $core.method({
  1040. selector: "testCase:result:finished:",
  1041. protocol: 'instance creation',
  1042. fn: function (aTestCase,aTestResult,aBlock){
  1043. var self=this;
  1044. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1045. return $core.withContext(function($ctx1) {
  1046. //>>excludeEnd("ctx");
  1047. var $1;
  1048. $1=(
  1049. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1050. $ctx1.supercall = true,
  1051. //>>excludeEnd("ctx");
  1052. ($globals.ReportingTestContext.klass.superclass||$boot.dnu).fn.prototype._testCase_.apply($recv(self), [aTestCase]));
  1053. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1054. $ctx1.supercall = false;
  1055. //>>excludeEnd("ctx");;
  1056. $recv($1)._result_(aTestResult);
  1057. $recv($1)._finished_(aBlock);
  1058. return $recv($1)._yourself();
  1059. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1060. }, function($ctx1) {$ctx1.fill(self,"testCase:result:finished:",{aTestCase:aTestCase,aTestResult:aTestResult,aBlock:aBlock},$globals.ReportingTestContext.klass)});
  1061. //>>excludeEnd("ctx");
  1062. },
  1063. //>>excludeStart("ide", pragmas.excludeIdeData);
  1064. args: ["aTestCase", "aTestResult", "aBlock"],
  1065. source: "testCase: aTestCase result: aTestResult finished: aBlock\x0a\x09^ (super testCase: aTestCase)\x0a\x09\x09result: aTestResult;\x0a\x09\x09finished: aBlock;\x0a\x09\x09yourself",
  1066. referencedClasses: [],
  1067. //>>excludeEnd("ide");
  1068. messageSends: ["result:", "testCase:", "finished:", "yourself"]
  1069. }),
  1070. $globals.ReportingTestContext.klass);
  1071. $core.addClass('TestFailure', $globals.Error, [], 'SUnit');
  1072. //>>excludeStart("ide", pragmas.excludeIdeData);
  1073. $globals.TestFailure.comment="I am raised when the boolean parameter of an #`assert:` or `#deny:` call is the opposite of what the assertion claims.\x0a\x0aThe test framework distinguishes between failures and errors.\x0aA failure is an event whose possibiity is explicitly anticipated and checked for in an assertion,\x0awhereas an error is an unanticipated problem like a division by 0 or an index out of bounds.";
  1074. //>>excludeEnd("ide");
  1075. $core.addClass('TestResult', $globals.Object, ['timestamp', 'runs', 'errors', 'failures', 'total'], 'SUnit');
  1076. //>>excludeStart("ide", pragmas.excludeIdeData);
  1077. $globals.TestResult.comment="I implement the collecting parameter pattern for running a bunch of tests.\x0a\x0aMy instances hold tests that have run, sorted into the result categories of passed, failures and errors.\x0a\x0a`TestResult` is an interesting object to subclass or substitute. `#runCase:` is the external protocol you need to reproduce";
  1078. //>>excludeEnd("ide");
  1079. $core.addMethod(
  1080. $core.method({
  1081. selector: "addError:",
  1082. protocol: 'accessing',
  1083. fn: function (anError){
  1084. var self=this;
  1085. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1086. return $core.withContext(function($ctx1) {
  1087. //>>excludeEnd("ctx");
  1088. $recv(self._errors())._add_(anError);
  1089. return self;
  1090. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1091. }, function($ctx1) {$ctx1.fill(self,"addError:",{anError:anError},$globals.TestResult)});
  1092. //>>excludeEnd("ctx");
  1093. },
  1094. //>>excludeStart("ide", pragmas.excludeIdeData);
  1095. args: ["anError"],
  1096. source: "addError: anError\x0a\x09self errors add: anError",
  1097. referencedClasses: [],
  1098. //>>excludeEnd("ide");
  1099. messageSends: ["add:", "errors"]
  1100. }),
  1101. $globals.TestResult);
  1102. $core.addMethod(
  1103. $core.method({
  1104. selector: "addFailure:",
  1105. protocol: 'accessing',
  1106. fn: function (aFailure){
  1107. var self=this;
  1108. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1109. return $core.withContext(function($ctx1) {
  1110. //>>excludeEnd("ctx");
  1111. $recv(self._failures())._add_(aFailure);
  1112. return self;
  1113. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1114. }, function($ctx1) {$ctx1.fill(self,"addFailure:",{aFailure:aFailure},$globals.TestResult)});
  1115. //>>excludeEnd("ctx");
  1116. },
  1117. //>>excludeStart("ide", pragmas.excludeIdeData);
  1118. args: ["aFailure"],
  1119. source: "addFailure: aFailure\x0a\x09self failures add: aFailure",
  1120. referencedClasses: [],
  1121. //>>excludeEnd("ide");
  1122. messageSends: ["add:", "failures"]
  1123. }),
  1124. $globals.TestResult);
  1125. $core.addMethod(
  1126. $core.method({
  1127. selector: "errors",
  1128. protocol: 'accessing',
  1129. fn: function (){
  1130. var self=this;
  1131. return self["@errors"];
  1132. },
  1133. //>>excludeStart("ide", pragmas.excludeIdeData);
  1134. args: [],
  1135. source: "errors\x0a\x09^ errors",
  1136. referencedClasses: [],
  1137. //>>excludeEnd("ide");
  1138. messageSends: []
  1139. }),
  1140. $globals.TestResult);
  1141. $core.addMethod(
  1142. $core.method({
  1143. selector: "failures",
  1144. protocol: 'accessing',
  1145. fn: function (){
  1146. var self=this;
  1147. return self["@failures"];
  1148. },
  1149. //>>excludeStart("ide", pragmas.excludeIdeData);
  1150. args: [],
  1151. source: "failures\x0a\x09^ failures",
  1152. referencedClasses: [],
  1153. //>>excludeEnd("ide");
  1154. messageSends: []
  1155. }),
  1156. $globals.TestResult);
  1157. $core.addMethod(
  1158. $core.method({
  1159. selector: "increaseRuns",
  1160. protocol: 'accessing',
  1161. fn: function (){
  1162. var self=this;
  1163. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1164. return $core.withContext(function($ctx1) {
  1165. //>>excludeEnd("ctx");
  1166. self["@runs"]=$recv(self["@runs"]).__plus((1));
  1167. return self;
  1168. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1169. }, function($ctx1) {$ctx1.fill(self,"increaseRuns",{},$globals.TestResult)});
  1170. //>>excludeEnd("ctx");
  1171. },
  1172. //>>excludeStart("ide", pragmas.excludeIdeData);
  1173. args: [],
  1174. source: "increaseRuns\x0a\x09runs := runs + 1",
  1175. referencedClasses: [],
  1176. //>>excludeEnd("ide");
  1177. messageSends: ["+"]
  1178. }),
  1179. $globals.TestResult);
  1180. $core.addMethod(
  1181. $core.method({
  1182. selector: "initialize",
  1183. protocol: 'initialization',
  1184. fn: function (){
  1185. var self=this;
  1186. function $Date(){return $globals.Date||(typeof Date=="undefined"?nil:Date)}
  1187. function $Array(){return $globals.Array||(typeof Array=="undefined"?nil:Array)}
  1188. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1189. return $core.withContext(function($ctx1) {
  1190. //>>excludeEnd("ctx");
  1191. (
  1192. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1193. $ctx1.supercall = true,
  1194. //>>excludeEnd("ctx");
  1195. ($globals.TestResult.superclass||$boot.dnu).fn.prototype._initialize.apply($recv(self), []));
  1196. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1197. $ctx1.supercall = false;
  1198. //>>excludeEnd("ctx");;
  1199. self["@timestamp"]=$recv($Date())._now();
  1200. self["@runs"]=(0);
  1201. self["@errors"]=$recv($Array())._new();
  1202. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1203. $ctx1.sendIdx["new"]=1;
  1204. //>>excludeEnd("ctx");
  1205. self["@failures"]=$recv($Array())._new();
  1206. self["@total"]=(0);
  1207. return self;
  1208. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1209. }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestResult)});
  1210. //>>excludeEnd("ctx");
  1211. },
  1212. //>>excludeStart("ide", pragmas.excludeIdeData);
  1213. args: [],
  1214. source: "initialize\x0a\x09super initialize.\x0a\x09timestamp := Date now.\x0a\x09runs := 0.\x0a\x09errors := Array new.\x0a\x09failures := Array new.\x0a\x09total := 0",
  1215. referencedClasses: ["Date", "Array"],
  1216. //>>excludeEnd("ide");
  1217. messageSends: ["initialize", "now", "new"]
  1218. }),
  1219. $globals.TestResult);
  1220. $core.addMethod(
  1221. $core.method({
  1222. selector: "nextRunDo:",
  1223. protocol: 'running',
  1224. fn: function (aBlock){
  1225. var self=this;
  1226. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1227. return $core.withContext(function($ctx1) {
  1228. //>>excludeEnd("ctx");
  1229. var $2,$1;
  1230. $2=self._runs();
  1231. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1232. $ctx1.sendIdx["runs"]=1;
  1233. //>>excludeEnd("ctx");
  1234. $1=$recv($2).__eq_eq(self._total());
  1235. if(!$core.assert($1)){
  1236. return $recv(aBlock)._value_($recv(self._runs()).__plus((1)));
  1237. };
  1238. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1239. }, function($ctx1) {$ctx1.fill(self,"nextRunDo:",{aBlock:aBlock},$globals.TestResult)});
  1240. //>>excludeEnd("ctx");
  1241. },
  1242. //>>excludeStart("ide", pragmas.excludeIdeData);
  1243. args: ["aBlock"],
  1244. source: "nextRunDo: aBlock\x0a\x09\x22Runs aBlock with index of next run or does nothing if no more runs\x22\x0a\x09^ self runs == self total\x0a\x09\x09ifFalse: [ aBlock value: self runs + 1 ]",
  1245. referencedClasses: [],
  1246. //>>excludeEnd("ide");
  1247. messageSends: ["ifFalse:", "==", "runs", "total", "value:", "+"]
  1248. }),
  1249. $globals.TestResult);
  1250. $core.addMethod(
  1251. $core.method({
  1252. selector: "runCase:",
  1253. protocol: 'running',
  1254. fn: function (aTestCase){
  1255. var self=this;
  1256. function $TestFailure(){return $globals.TestFailure||(typeof TestFailure=="undefined"?nil:TestFailure)}
  1257. function $Error(){return $globals.Error||(typeof Error=="undefined"?nil:Error)}
  1258. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1259. return $core.withContext(function($ctx1) {
  1260. //>>excludeEnd("ctx");
  1261. $recv((function(){
  1262. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1263. return $core.withContext(function($ctx2) {
  1264. //>>excludeEnd("ctx");
  1265. return $recv((function(){
  1266. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1267. return $core.withContext(function($ctx3) {
  1268. //>>excludeEnd("ctx");
  1269. self._increaseRuns();
  1270. return $recv(aTestCase)._runCase();
  1271. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1272. }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
  1273. //>>excludeEnd("ctx");
  1274. }))._on_do_($TestFailure(),(function(ex){
  1275. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1276. return $core.withContext(function($ctx3) {
  1277. //>>excludeEnd("ctx");
  1278. return self._addFailure_(aTestCase);
  1279. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1280. }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,3)});
  1281. //>>excludeEnd("ctx");
  1282. }));
  1283. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1284. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1285. //>>excludeEnd("ctx");
  1286. }))._on_do_($Error(),(function(ex){
  1287. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1288. return $core.withContext(function($ctx2) {
  1289. //>>excludeEnd("ctx");
  1290. return self._addError_(aTestCase);
  1291. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1292. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,4)});
  1293. //>>excludeEnd("ctx");
  1294. }));
  1295. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1296. $ctx1.sendIdx["on:do:"]=1;
  1297. //>>excludeEnd("ctx");
  1298. return self;
  1299. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1300. }, function($ctx1) {$ctx1.fill(self,"runCase:",{aTestCase:aTestCase},$globals.TestResult)});
  1301. //>>excludeEnd("ctx");
  1302. },
  1303. //>>excludeStart("ide", pragmas.excludeIdeData);
  1304. args: ["aTestCase"],
  1305. source: "runCase: aTestCase\x0a\x09[ [ self increaseRuns.\x0a\x09\x09aTestCase runCase ]\x0a\x09on: TestFailure do: [ :ex | self addFailure: aTestCase ]]\x0a\x09on: Error do: [ :ex | self addError: aTestCase ]",
  1306. referencedClasses: ["TestFailure", "Error"],
  1307. //>>excludeEnd("ide");
  1308. messageSends: ["on:do:", "increaseRuns", "runCase", "addFailure:", "addError:"]
  1309. }),
  1310. $globals.TestResult);
  1311. $core.addMethod(
  1312. $core.method({
  1313. selector: "runs",
  1314. protocol: 'accessing',
  1315. fn: function (){
  1316. var self=this;
  1317. return self["@runs"];
  1318. },
  1319. //>>excludeStart("ide", pragmas.excludeIdeData);
  1320. args: [],
  1321. source: "runs\x0a\x09^ runs",
  1322. referencedClasses: [],
  1323. //>>excludeEnd("ide");
  1324. messageSends: []
  1325. }),
  1326. $globals.TestResult);
  1327. $core.addMethod(
  1328. $core.method({
  1329. selector: "status",
  1330. protocol: 'accessing',
  1331. fn: function (){
  1332. var self=this;
  1333. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1334. return $core.withContext(function($ctx1) {
  1335. //>>excludeEnd("ctx");
  1336. var $2,$3,$1;
  1337. $2=$recv(self._errors())._isEmpty();
  1338. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1339. $ctx1.sendIdx["isEmpty"]=1;
  1340. //>>excludeEnd("ctx");
  1341. if($core.assert($2)){
  1342. $3=$recv(self._failures())._isEmpty();
  1343. if($core.assert($3)){
  1344. $1="success";
  1345. } else {
  1346. $1="failure";
  1347. };
  1348. } else {
  1349. $1="error";
  1350. };
  1351. return $1;
  1352. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1353. }, function($ctx1) {$ctx1.fill(self,"status",{},$globals.TestResult)});
  1354. //>>excludeEnd("ctx");
  1355. },
  1356. //>>excludeStart("ide", pragmas.excludeIdeData);
  1357. args: [],
  1358. source: "status\x0a\x09^ self errors isEmpty\x0a\x09\x09ifTrue: [\x0a\x09\x09\x09self failures isEmpty\x0a\x09\x09\x09\x09ifTrue: [ 'success' ]\x0a\x09\x09\x09\x09ifFalse: [ 'failure' ]]\x0a\x09\x09ifFalse: [ 'error' ]",
  1359. referencedClasses: [],
  1360. //>>excludeEnd("ide");
  1361. messageSends: ["ifTrue:ifFalse:", "isEmpty", "errors", "failures"]
  1362. }),
  1363. $globals.TestResult);
  1364. $core.addMethod(
  1365. $core.method({
  1366. selector: "timestamp",
  1367. protocol: 'accessing',
  1368. fn: function (){
  1369. var self=this;
  1370. return self["@timestamp"];
  1371. },
  1372. //>>excludeStart("ide", pragmas.excludeIdeData);
  1373. args: [],
  1374. source: "timestamp\x0a\x09^ timestamp",
  1375. referencedClasses: [],
  1376. //>>excludeEnd("ide");
  1377. messageSends: []
  1378. }),
  1379. $globals.TestResult);
  1380. $core.addMethod(
  1381. $core.method({
  1382. selector: "total",
  1383. protocol: 'accessing',
  1384. fn: function (){
  1385. var self=this;
  1386. return self["@total"];
  1387. },
  1388. //>>excludeStart("ide", pragmas.excludeIdeData);
  1389. args: [],
  1390. source: "total\x0a\x09^ total",
  1391. referencedClasses: [],
  1392. //>>excludeEnd("ide");
  1393. messageSends: []
  1394. }),
  1395. $globals.TestResult);
  1396. $core.addMethod(
  1397. $core.method({
  1398. selector: "total:",
  1399. protocol: 'accessing',
  1400. fn: function (aNumber){
  1401. var self=this;
  1402. self["@total"]=aNumber;
  1403. return self;
  1404. },
  1405. //>>excludeStart("ide", pragmas.excludeIdeData);
  1406. args: ["aNumber"],
  1407. source: "total: aNumber\x0a\x09total := aNumber",
  1408. referencedClasses: [],
  1409. //>>excludeEnd("ide");
  1410. messageSends: []
  1411. }),
  1412. $globals.TestResult);
  1413. $core.addClass('TestSuiteRunner', $globals.Object, ['suite', 'result', 'announcer', 'runNextTest'], 'SUnit');
  1414. //>>excludeStart("ide", pragmas.excludeIdeData);
  1415. $globals.TestSuiteRunner.comment="I am responsible for running a collection (`suite`) of tests.\x0a\x0a## API\x0a\x0aInstances should be created using the class-side `#on:` method, taking a collection of tests to run as parameter.\x0aTo run the test suite, use `#run`.";
  1416. //>>excludeEnd("ide");
  1417. $core.addMethod(
  1418. $core.method({
  1419. selector: "announcer",
  1420. protocol: 'accessing',
  1421. fn: function (){
  1422. var self=this;
  1423. return self["@announcer"];
  1424. },
  1425. //>>excludeStart("ide", pragmas.excludeIdeData);
  1426. args: [],
  1427. source: "announcer\x0a\x09^ announcer",
  1428. referencedClasses: [],
  1429. //>>excludeEnd("ide");
  1430. messageSends: []
  1431. }),
  1432. $globals.TestSuiteRunner);
  1433. $core.addMethod(
  1434. $core.method({
  1435. selector: "contextOf:",
  1436. protocol: 'private',
  1437. fn: function (anInteger){
  1438. var self=this;
  1439. function $ReportingTestContext(){return $globals.ReportingTestContext||(typeof ReportingTestContext=="undefined"?nil:ReportingTestContext)}
  1440. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1441. return $core.withContext(function($ctx1) {
  1442. //>>excludeEnd("ctx");
  1443. return $recv($ReportingTestContext())._testCase_result_finished_($recv(self["@suite"])._at_(anInteger),self["@result"],(function(){
  1444. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1445. return $core.withContext(function($ctx2) {
  1446. //>>excludeEnd("ctx");
  1447. return self._resume();
  1448. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1449. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1450. //>>excludeEnd("ctx");
  1451. }));
  1452. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1453. }, function($ctx1) {$ctx1.fill(self,"contextOf:",{anInteger:anInteger},$globals.TestSuiteRunner)});
  1454. //>>excludeEnd("ctx");
  1455. },
  1456. //>>excludeStart("ide", pragmas.excludeIdeData);
  1457. args: ["anInteger"],
  1458. source: "contextOf: anInteger\x0a\x09^ ReportingTestContext testCase: (suite at: anInteger) result: result finished: [ self resume ]",
  1459. referencedClasses: ["ReportingTestContext"],
  1460. //>>excludeEnd("ide");
  1461. messageSends: ["testCase:result:finished:", "at:", "resume"]
  1462. }),
  1463. $globals.TestSuiteRunner);
  1464. $core.addMethod(
  1465. $core.method({
  1466. selector: "initialize",
  1467. protocol: 'initialization',
  1468. fn: function (){
  1469. var self=this;
  1470. function $Announcer(){return $globals.Announcer||(typeof Announcer=="undefined"?nil:Announcer)}
  1471. function $TestResult(){return $globals.TestResult||(typeof TestResult=="undefined"?nil:TestResult)}
  1472. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1473. return $core.withContext(function($ctx1) {
  1474. //>>excludeEnd("ctx");
  1475. var $1;
  1476. (
  1477. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1478. $ctx1.supercall = true,
  1479. //>>excludeEnd("ctx");
  1480. ($globals.TestSuiteRunner.superclass||$boot.dnu).fn.prototype._initialize.apply($recv(self), []));
  1481. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1482. $ctx1.supercall = false;
  1483. //>>excludeEnd("ctx");;
  1484. self["@announcer"]=$recv($Announcer())._new();
  1485. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1486. $ctx1.sendIdx["new"]=1;
  1487. //>>excludeEnd("ctx");
  1488. self["@result"]=$recv($TestResult())._new();
  1489. self["@runNextTest"]=(function(){
  1490. var runs;
  1491. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1492. return $core.withContext(function($ctx2) {
  1493. //>>excludeEnd("ctx");
  1494. runs=$recv(self["@result"])._runs();
  1495. runs;
  1496. $1=$recv(runs).__lt($recv(self["@result"])._total());
  1497. if($core.assert($1)){
  1498. return $recv(self._contextOf_($recv(runs).__plus((1))))._start();
  1499. };
  1500. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1501. }, function($ctx2) {$ctx2.fillBlock({runs:runs},$ctx1,1)});
  1502. //>>excludeEnd("ctx");
  1503. });
  1504. return self;
  1505. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1506. }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestSuiteRunner)});
  1507. //>>excludeEnd("ctx");
  1508. },
  1509. //>>excludeStart("ide", pragmas.excludeIdeData);
  1510. args: [],
  1511. source: "initialize\x0a\x09super initialize.\x0a\x09announcer := Announcer new.\x0a\x09result := TestResult new.\x0a\x09runNextTest := [ | runs | runs := result runs. runs < result total ifTrue: [ (self contextOf: runs + 1) start ] ].",
  1512. referencedClasses: ["Announcer", "TestResult"],
  1513. //>>excludeEnd("ide");
  1514. messageSends: ["initialize", "new", "runs", "ifTrue:", "<", "total", "start", "contextOf:", "+"]
  1515. }),
  1516. $globals.TestSuiteRunner);
  1517. $core.addMethod(
  1518. $core.method({
  1519. selector: "result",
  1520. protocol: 'accessing',
  1521. fn: function (){
  1522. var self=this;
  1523. return self["@result"];
  1524. },
  1525. //>>excludeStart("ide", pragmas.excludeIdeData);
  1526. args: [],
  1527. source: "result\x0a\x09^ result",
  1528. referencedClasses: [],
  1529. //>>excludeEnd("ide");
  1530. messageSends: []
  1531. }),
  1532. $globals.TestSuiteRunner);
  1533. $core.addMethod(
  1534. $core.method({
  1535. selector: "resume",
  1536. protocol: 'actions',
  1537. fn: function (){
  1538. var self=this;
  1539. function $ResultAnnouncement(){return $globals.ResultAnnouncement||(typeof ResultAnnouncement=="undefined"?nil:ResultAnnouncement)}
  1540. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1541. return $core.withContext(function($ctx1) {
  1542. //>>excludeEnd("ctx");
  1543. $recv(self["@runNextTest"])._fork();
  1544. $recv(self["@announcer"])._announce_($recv($recv($ResultAnnouncement())._new())._result_(self["@result"]));
  1545. return self;
  1546. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1547. }, function($ctx1) {$ctx1.fill(self,"resume",{},$globals.TestSuiteRunner)});
  1548. //>>excludeEnd("ctx");
  1549. },
  1550. //>>excludeStart("ide", pragmas.excludeIdeData);
  1551. args: [],
  1552. source: "resume\x0a\x09runNextTest fork.\x0a\x09announcer announce: (ResultAnnouncement new result: result)",
  1553. referencedClasses: ["ResultAnnouncement"],
  1554. //>>excludeEnd("ide");
  1555. messageSends: ["fork", "announce:", "result:", "new"]
  1556. }),
  1557. $globals.TestSuiteRunner);
  1558. $core.addMethod(
  1559. $core.method({
  1560. selector: "run",
  1561. protocol: 'actions',
  1562. fn: function (){
  1563. var self=this;
  1564. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1565. return $core.withContext(function($ctx1) {
  1566. //>>excludeEnd("ctx");
  1567. $recv(self["@result"])._total_($recv(self["@suite"])._size());
  1568. self._resume();
  1569. return self;
  1570. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1571. }, function($ctx1) {$ctx1.fill(self,"run",{},$globals.TestSuiteRunner)});
  1572. //>>excludeEnd("ctx");
  1573. },
  1574. //>>excludeStart("ide", pragmas.excludeIdeData);
  1575. args: [],
  1576. source: "run\x0a\x09result total: suite size.\x0a\x09self resume",
  1577. referencedClasses: [],
  1578. //>>excludeEnd("ide");
  1579. messageSends: ["total:", "size", "resume"]
  1580. }),
  1581. $globals.TestSuiteRunner);
  1582. $core.addMethod(
  1583. $core.method({
  1584. selector: "suite:",
  1585. protocol: 'accessing',
  1586. fn: function (aCollection){
  1587. var self=this;
  1588. self["@suite"]=aCollection;
  1589. return self;
  1590. },
  1591. //>>excludeStart("ide", pragmas.excludeIdeData);
  1592. args: ["aCollection"],
  1593. source: "suite: aCollection\x0a\x09suite := aCollection",
  1594. referencedClasses: [],
  1595. //>>excludeEnd("ide");
  1596. messageSends: []
  1597. }),
  1598. $globals.TestSuiteRunner);
  1599. $core.addMethod(
  1600. $core.method({
  1601. selector: "new",
  1602. protocol: 'instance creation',
  1603. fn: function (){
  1604. var self=this;
  1605. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1606. return $core.withContext(function($ctx1) {
  1607. //>>excludeEnd("ctx");
  1608. self._shouldNotImplement();
  1609. return self;
  1610. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1611. }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.TestSuiteRunner.klass)});
  1612. //>>excludeEnd("ctx");
  1613. },
  1614. //>>excludeStart("ide", pragmas.excludeIdeData);
  1615. args: [],
  1616. source: "new\x0a\x09self shouldNotImplement",
  1617. referencedClasses: [],
  1618. //>>excludeEnd("ide");
  1619. messageSends: ["shouldNotImplement"]
  1620. }),
  1621. $globals.TestSuiteRunner.klass);
  1622. $core.addMethod(
  1623. $core.method({
  1624. selector: "on:",
  1625. protocol: 'instance creation',
  1626. fn: function (aCollection){
  1627. var self=this;
  1628. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1629. return $core.withContext(function($ctx1) {
  1630. //>>excludeEnd("ctx");
  1631. var $1;
  1632. $1=(
  1633. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1634. $ctx1.supercall = true,
  1635. //>>excludeEnd("ctx");
  1636. ($globals.TestSuiteRunner.klass.superclass||$boot.dnu).fn.prototype._new.apply($recv(self), []));
  1637. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1638. $ctx1.supercall = false;
  1639. //>>excludeEnd("ctx");;
  1640. return $recv($1)._suite_(aCollection);
  1641. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1642. }, function($ctx1) {$ctx1.fill(self,"on:",{aCollection:aCollection},$globals.TestSuiteRunner.klass)});
  1643. //>>excludeEnd("ctx");
  1644. },
  1645. //>>excludeStart("ide", pragmas.excludeIdeData);
  1646. args: ["aCollection"],
  1647. source: "on: aCollection\x0a\x09^ super new suite: aCollection",
  1648. referencedClasses: [],
  1649. //>>excludeEnd("ide");
  1650. messageSends: ["suite:", "new"]
  1651. }),
  1652. $globals.TestSuiteRunner.klass);
  1653. $core.addMethod(
  1654. $core.method({
  1655. selector: "isTestClass",
  1656. protocol: '*SUnit',
  1657. fn: function (){
  1658. var self=this;
  1659. function $TestCase(){return $globals.TestCase||(typeof TestCase=="undefined"?nil:TestCase)}
  1660. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1661. return $core.withContext(function($ctx1) {
  1662. //>>excludeEnd("ctx");
  1663. return $recv(self._includesBehavior_($TestCase()))._and_((function(){
  1664. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1665. return $core.withContext(function($ctx2) {
  1666. //>>excludeEnd("ctx");
  1667. return $recv(self._isAbstract())._not();
  1668. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1669. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1670. //>>excludeEnd("ctx");
  1671. }));
  1672. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1673. }, function($ctx1) {$ctx1.fill(self,"isTestClass",{},$globals.Behavior)});
  1674. //>>excludeEnd("ctx");
  1675. },
  1676. //>>excludeStart("ide", pragmas.excludeIdeData);
  1677. args: [],
  1678. source: "isTestClass\x0a\x09^(self includesBehavior: TestCase) and: [ \x0a\x09\x09\x09self isAbstract not ]",
  1679. referencedClasses: ["TestCase"],
  1680. //>>excludeEnd("ide");
  1681. messageSends: ["and:", "includesBehavior:", "not", "isAbstract"]
  1682. }),
  1683. $globals.Behavior);
  1684. $core.addMethod(
  1685. $core.method({
  1686. selector: "isTestPackage",
  1687. protocol: '*SUnit',
  1688. fn: function (){
  1689. var self=this;
  1690. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1691. return $core.withContext(function($ctx1) {
  1692. //>>excludeEnd("ctx");
  1693. return $recv(self._classes())._anySatisfy_((function(each){
  1694. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1695. return $core.withContext(function($ctx2) {
  1696. //>>excludeEnd("ctx");
  1697. return $recv(each)._isTestClass();
  1698. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1699. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  1700. //>>excludeEnd("ctx");
  1701. }));
  1702. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1703. }, function($ctx1) {$ctx1.fill(self,"isTestPackage",{},$globals.Package)});
  1704. //>>excludeEnd("ctx");
  1705. },
  1706. //>>excludeStart("ide", pragmas.excludeIdeData);
  1707. args: [],
  1708. source: "isTestPackage\x0a\x09^ self classes anySatisfy: [ :each | each isTestClass ]",
  1709. referencedClasses: [],
  1710. //>>excludeEnd("ide");
  1711. messageSends: ["anySatisfy:", "classes", "isTestClass"]
  1712. }),
  1713. $globals.Package);
  1714. });