SUnit.js 56 KB

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