SUnit.js 56 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800
  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. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  313. return $core.withContext(function($ctx1) {
  314. //>>excludeEnd("ctx");
  315. $recv($recv($globals.TestContext)._testCase_(self))._start();
  316. return self;
  317. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  318. }, function($ctx1) {$ctx1.fill(self,"runCase",{},$globals.TestCase)});
  319. //>>excludeEnd("ctx");
  320. },
  321. //>>excludeStart("ide", pragmas.excludeIdeData);
  322. args: [],
  323. source: "runCase\x0a\x09\x22Runs a test case in isolated context, leaking all errors.\x22\x0a\x0a\x09(TestContext testCase: self) start",
  324. referencedClasses: ["TestContext"],
  325. //>>excludeEnd("ide");
  326. messageSends: ["start", "testCase:"]
  327. }),
  328. $globals.TestCase);
  329. $core.addMethod(
  330. $core.method({
  331. selector: "selector",
  332. protocol: 'accessing',
  333. fn: function (){
  334. var self=this;
  335. return self["@testSelector"];
  336. },
  337. //>>excludeStart("ide", pragmas.excludeIdeData);
  338. args: [],
  339. source: "selector\x0a\x09^ testSelector",
  340. referencedClasses: [],
  341. //>>excludeEnd("ide");
  342. messageSends: []
  343. }),
  344. $globals.TestCase);
  345. $core.addMethod(
  346. $core.method({
  347. selector: "setTestSelector:",
  348. protocol: 'accessing',
  349. fn: function (aSelector){
  350. var self=this;
  351. self["@testSelector"]=aSelector;
  352. return self;
  353. },
  354. //>>excludeStart("ide", pragmas.excludeIdeData);
  355. args: ["aSelector"],
  356. source: "setTestSelector: aSelector\x0a\x09testSelector := aSelector",
  357. referencedClasses: [],
  358. //>>excludeEnd("ide");
  359. messageSends: []
  360. }),
  361. $globals.TestCase);
  362. $core.addMethod(
  363. $core.method({
  364. selector: "setUp",
  365. protocol: 'running',
  366. fn: function (){
  367. var self=this;
  368. return self;
  369. },
  370. //>>excludeStart("ide", pragmas.excludeIdeData);
  371. args: [],
  372. source: "setUp",
  373. referencedClasses: [],
  374. //>>excludeEnd("ide");
  375. messageSends: []
  376. }),
  377. $globals.TestCase);
  378. $core.addMethod(
  379. $core.method({
  380. selector: "should:",
  381. protocol: 'testing',
  382. fn: function (aBlock){
  383. var self=this;
  384. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  385. return $core.withContext(function($ctx1) {
  386. //>>excludeEnd("ctx");
  387. self._assert_($recv(aBlock)._value());
  388. return self;
  389. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  390. }, function($ctx1) {$ctx1.fill(self,"should:",{aBlock:aBlock},$globals.TestCase)});
  391. //>>excludeEnd("ctx");
  392. },
  393. //>>excludeStart("ide", pragmas.excludeIdeData);
  394. args: ["aBlock"],
  395. source: "should: aBlock\x0a\x09self assert: aBlock value",
  396. referencedClasses: [],
  397. //>>excludeEnd("ide");
  398. messageSends: ["assert:", "value"]
  399. }),
  400. $globals.TestCase);
  401. $core.addMethod(
  402. $core.method({
  403. selector: "should:raise:",
  404. protocol: 'testing',
  405. fn: function (aBlock,anExceptionClass){
  406. var self=this;
  407. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  408. return $core.withContext(function($ctx1) {
  409. //>>excludeEnd("ctx");
  410. self._assert_($recv((function(){
  411. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  412. return $core.withContext(function($ctx2) {
  413. //>>excludeEnd("ctx");
  414. $recv(aBlock)._value();
  415. return false;
  416. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  417. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  418. //>>excludeEnd("ctx");
  419. }))._on_do_(anExceptionClass,(function(ex){
  420. return true;
  421. })));
  422. return self;
  423. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  424. }, function($ctx1) {$ctx1.fill(self,"should:raise:",{aBlock:aBlock,anExceptionClass:anExceptionClass},$globals.TestCase)});
  425. //>>excludeEnd("ctx");
  426. },
  427. //>>excludeStart("ide", pragmas.excludeIdeData);
  428. args: ["aBlock", "anExceptionClass"],
  429. source: "should: aBlock raise: anExceptionClass\x0a\x09self assert: ([ aBlock value. false ]\x0a\x09\x09on: anExceptionClass\x0a\x09\x09do: [ :ex | true ])",
  430. referencedClasses: [],
  431. //>>excludeEnd("ide");
  432. messageSends: ["assert:", "on:do:", "value"]
  433. }),
  434. $globals.TestCase);
  435. $core.addMethod(
  436. $core.method({
  437. selector: "shouldnt:raise:",
  438. protocol: 'testing',
  439. fn: function (aBlock,anExceptionClass){
  440. var self=this;
  441. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  442. return $core.withContext(function($ctx1) {
  443. //>>excludeEnd("ctx");
  444. self._assert_($recv((function(){
  445. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  446. return $core.withContext(function($ctx2) {
  447. //>>excludeEnd("ctx");
  448. $recv(aBlock)._value();
  449. return true;
  450. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  451. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  452. //>>excludeEnd("ctx");
  453. }))._on_do_(anExceptionClass,(function(ex){
  454. return false;
  455. })));
  456. return self;
  457. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  458. }, function($ctx1) {$ctx1.fill(self,"shouldnt:raise:",{aBlock:aBlock,anExceptionClass:anExceptionClass},$globals.TestCase)});
  459. //>>excludeEnd("ctx");
  460. },
  461. //>>excludeStart("ide", pragmas.excludeIdeData);
  462. args: ["aBlock", "anExceptionClass"],
  463. source: "shouldnt: aBlock raise: anExceptionClass\x0a\x09self assert: ([ aBlock value. true ]\x0a\x09\x09on: anExceptionClass\x0a\x09\x09do: [ :ex | false ])",
  464. referencedClasses: [],
  465. //>>excludeEnd("ide");
  466. messageSends: ["assert:", "on:do:", "value"]
  467. }),
  468. $globals.TestCase);
  469. $core.addMethod(
  470. $core.method({
  471. selector: "signalFailure:",
  472. protocol: 'private',
  473. fn: function (aString){
  474. var self=this;
  475. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  476. return $core.withContext(function($ctx1) {
  477. //>>excludeEnd("ctx");
  478. var $1;
  479. $1=$recv($globals.TestFailure)._new();
  480. $recv($1)._messageText_(aString);
  481. $recv($1)._signal();
  482. return self;
  483. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  484. }, function($ctx1) {$ctx1.fill(self,"signalFailure:",{aString:aString},$globals.TestCase)});
  485. //>>excludeEnd("ctx");
  486. },
  487. //>>excludeStart("ide", pragmas.excludeIdeData);
  488. args: ["aString"],
  489. source: "signalFailure: aString\x0a\x09TestFailure new\x0a\x09\x09messageText: aString;\x0a\x09\x09signal",
  490. referencedClasses: ["TestFailure"],
  491. //>>excludeEnd("ide");
  492. messageSends: ["messageText:", "new", "signal"]
  493. }),
  494. $globals.TestCase);
  495. $core.addMethod(
  496. $core.method({
  497. selector: "tearDown",
  498. protocol: 'running',
  499. fn: function (){
  500. var self=this;
  501. return self;
  502. },
  503. //>>excludeStart("ide", pragmas.excludeIdeData);
  504. args: [],
  505. source: "tearDown",
  506. referencedClasses: [],
  507. //>>excludeEnd("ide");
  508. messageSends: []
  509. }),
  510. $globals.TestCase);
  511. $core.addMethod(
  512. $core.method({
  513. selector: "timeout:",
  514. protocol: 'async',
  515. fn: function (aNumber){
  516. var self=this;
  517. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  518. return $core.withContext(function($ctx1) {
  519. //>>excludeEnd("ctx");
  520. var $1,$receiver;
  521. $1=self["@asyncTimeout"];
  522. if(($receiver = $1) == null || $receiver.isNil){
  523. $1;
  524. } else {
  525. $recv(self["@asyncTimeout"])._clearTimeout();
  526. };
  527. self["@asyncTimeout"]=(0);
  528. self["@asyncTimeout"]=$recv(self._async_((function(){
  529. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  530. return $core.withContext(function($ctx2) {
  531. //>>excludeEnd("ctx");
  532. return self._assert_description_(false,"SUnit grace time exhausted");
  533. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  534. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
  535. //>>excludeEnd("ctx");
  536. })))._valueWithTimeout_(aNumber);
  537. return self;
  538. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  539. }, function($ctx1) {$ctx1.fill(self,"timeout:",{aNumber:aNumber},$globals.TestCase)});
  540. //>>excludeEnd("ctx");
  541. },
  542. //>>excludeStart("ide", pragmas.excludeIdeData);
  543. args: ["aNumber"],
  544. 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",
  545. referencedClasses: [],
  546. //>>excludeEnd("ide");
  547. messageSends: ["ifNotNil:", "clearTimeout", "valueWithTimeout:", "async:", "assert:description:"]
  548. }),
  549. $globals.TestCase);
  550. $core.addMethod(
  551. $core.method({
  552. selector: "allTestSelectors",
  553. protocol: 'accessing',
  554. fn: function (){
  555. var self=this;
  556. var selectors;
  557. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  558. return $core.withContext(function($ctx1) {
  559. //>>excludeEnd("ctx");
  560. var $1;
  561. selectors=self._testSelectors();
  562. $1=self._shouldInheritSelectors();
  563. if($core.assert($1)){
  564. $recv(selectors)._addAll_($recv(self._superclass())._allTestSelectors());
  565. };
  566. return selectors;
  567. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  568. }, function($ctx1) {$ctx1.fill(self,"allTestSelectors",{selectors:selectors},$globals.TestCase.klass)});
  569. //>>excludeEnd("ctx");
  570. },
  571. //>>excludeStart("ide", pragmas.excludeIdeData);
  572. args: [],
  573. source: "allTestSelectors\x0a\x09| selectors |\x0a\x09selectors := self testSelectors.\x0a\x09self shouldInheritSelectors ifTrue: [\x0a\x09\x09selectors addAll: self superclass allTestSelectors ].\x0a\x09^ selectors",
  574. referencedClasses: [],
  575. //>>excludeEnd("ide");
  576. messageSends: ["testSelectors", "ifTrue:", "shouldInheritSelectors", "addAll:", "allTestSelectors", "superclass"]
  577. }),
  578. $globals.TestCase.klass);
  579. $core.addMethod(
  580. $core.method({
  581. selector: "buildSuite",
  582. protocol: 'accessing',
  583. fn: function (){
  584. var self=this;
  585. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  586. return $core.withContext(function($ctx1) {
  587. //>>excludeEnd("ctx");
  588. return $recv(self._allTestSelectors())._collect_((function(each){
  589. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  590. return $core.withContext(function($ctx2) {
  591. //>>excludeEnd("ctx");
  592. return self._selector_(each);
  593. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  594. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  595. //>>excludeEnd("ctx");
  596. }));
  597. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  598. }, function($ctx1) {$ctx1.fill(self,"buildSuite",{},$globals.TestCase.klass)});
  599. //>>excludeEnd("ctx");
  600. },
  601. //>>excludeStart("ide", pragmas.excludeIdeData);
  602. args: [],
  603. source: "buildSuite\x0a\x09^ self allTestSelectors collect: [ :each | self selector: each ]",
  604. referencedClasses: [],
  605. //>>excludeEnd("ide");
  606. messageSends: ["collect:", "allTestSelectors", "selector:"]
  607. }),
  608. $globals.TestCase.klass);
  609. $core.addMethod(
  610. $core.method({
  611. selector: "classTag",
  612. protocol: 'accessing',
  613. fn: function (){
  614. var self=this;
  615. return "test";
  616. },
  617. //>>excludeStart("ide", pragmas.excludeIdeData);
  618. args: [],
  619. 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'",
  620. referencedClasses: [],
  621. //>>excludeEnd("ide");
  622. messageSends: []
  623. }),
  624. $globals.TestCase.klass);
  625. $core.addMethod(
  626. $core.method({
  627. selector: "isAbstract",
  628. protocol: 'testing',
  629. fn: function (){
  630. var self=this;
  631. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  632. return $core.withContext(function($ctx1) {
  633. //>>excludeEnd("ctx");
  634. return $recv(self._name()).__eq("TestCase");
  635. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  636. }, function($ctx1) {$ctx1.fill(self,"isAbstract",{},$globals.TestCase.klass)});
  637. //>>excludeEnd("ctx");
  638. },
  639. //>>excludeStart("ide", pragmas.excludeIdeData);
  640. args: [],
  641. source: "isAbstract\x0a\x09^ self name = 'TestCase'",
  642. referencedClasses: [],
  643. //>>excludeEnd("ide");
  644. messageSends: ["=", "name"]
  645. }),
  646. $globals.TestCase.klass);
  647. $core.addMethod(
  648. $core.method({
  649. selector: "lookupHierarchyRoot",
  650. protocol: 'accessing',
  651. fn: function (){
  652. var self=this;
  653. return $globals.TestCase;
  654. },
  655. //>>excludeStart("ide", pragmas.excludeIdeData);
  656. args: [],
  657. source: "lookupHierarchyRoot\x0a\x09^ TestCase",
  658. referencedClasses: ["TestCase"],
  659. //>>excludeEnd("ide");
  660. messageSends: []
  661. }),
  662. $globals.TestCase.klass);
  663. $core.addMethod(
  664. $core.method({
  665. selector: "selector:",
  666. protocol: 'accessing',
  667. fn: function (aSelector){
  668. var self=this;
  669. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  670. return $core.withContext(function($ctx1) {
  671. //>>excludeEnd("ctx");
  672. var $1;
  673. $1=self._new();
  674. $recv($1)._setTestSelector_(aSelector);
  675. return $recv($1)._yourself();
  676. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  677. }, function($ctx1) {$ctx1.fill(self,"selector:",{aSelector:aSelector},$globals.TestCase.klass)});
  678. //>>excludeEnd("ctx");
  679. },
  680. //>>excludeStart("ide", pragmas.excludeIdeData);
  681. args: ["aSelector"],
  682. source: "selector: aSelector\x0a\x09^ self new\x0a\x09\x09setTestSelector: aSelector;\x0a\x09\x09yourself",
  683. referencedClasses: [],
  684. //>>excludeEnd("ide");
  685. messageSends: ["setTestSelector:", "new", "yourself"]
  686. }),
  687. $globals.TestCase.klass);
  688. $core.addMethod(
  689. $core.method({
  690. selector: "shouldInheritSelectors",
  691. protocol: 'testing',
  692. fn: function (){
  693. var self=this;
  694. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  695. return $core.withContext(function($ctx1) {
  696. //>>excludeEnd("ctx");
  697. return self.__tild_eq(self._lookupHierarchyRoot());
  698. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  699. }, function($ctx1) {$ctx1.fill(self,"shouldInheritSelectors",{},$globals.TestCase.klass)});
  700. //>>excludeEnd("ctx");
  701. },
  702. //>>excludeStart("ide", pragmas.excludeIdeData);
  703. args: [],
  704. source: "shouldInheritSelectors\x0a\x09^ self ~= self lookupHierarchyRoot",
  705. referencedClasses: [],
  706. //>>excludeEnd("ide");
  707. messageSends: ["~=", "lookupHierarchyRoot"]
  708. }),
  709. $globals.TestCase.klass);
  710. $core.addMethod(
  711. $core.method({
  712. selector: "testSelectors",
  713. protocol: 'accessing',
  714. fn: function (){
  715. var self=this;
  716. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  717. return $core.withContext(function($ctx1) {
  718. //>>excludeEnd("ctx");
  719. return $recv($recv(self._methodDictionary())._keys())._select_((function(each){
  720. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  721. return $core.withContext(function($ctx2) {
  722. //>>excludeEnd("ctx");
  723. return $recv(each)._match_("^test");
  724. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  725. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  726. //>>excludeEnd("ctx");
  727. }));
  728. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  729. }, function($ctx1) {$ctx1.fill(self,"testSelectors",{},$globals.TestCase.klass)});
  730. //>>excludeEnd("ctx");
  731. },
  732. //>>excludeStart("ide", pragmas.excludeIdeData);
  733. args: [],
  734. source: "testSelectors\x0a\x09^ self methodDictionary keys select: [ :each | each match: '^test' ]",
  735. referencedClasses: [],
  736. //>>excludeEnd("ide");
  737. messageSends: ["select:", "keys", "methodDictionary", "match:"]
  738. }),
  739. $globals.TestCase.klass);
  740. $core.addClass('TestContext', $globals.Object, ['testCase'], 'SUnit');
  741. //>>excludeStart("ide", pragmas.excludeIdeData);
  742. $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).";
  743. //>>excludeEnd("ide");
  744. $core.addMethod(
  745. $core.method({
  746. selector: "execute:",
  747. protocol: 'running',
  748. fn: function (aBlock){
  749. var self=this;
  750. var failed;
  751. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  752. return $core.withContext(function($ctx1) {
  753. //>>excludeEnd("ctx");
  754. var $1,$2;
  755. $recv(self["@testCase"])._context_(self);
  756. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  757. $ctx1.sendIdx["context:"]=1;
  758. //>>excludeEnd("ctx");
  759. $recv((function(){
  760. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  761. return $core.withContext(function($ctx2) {
  762. //>>excludeEnd("ctx");
  763. failed=true;
  764. failed;
  765. $recv(aBlock)._value();
  766. failed=false;
  767. return failed;
  768. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  769. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  770. //>>excludeEnd("ctx");
  771. }))._ensure_((function(){
  772. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  773. return $core.withContext(function($ctx2) {
  774. //>>excludeEnd("ctx");
  775. $recv(self["@testCase"])._context_(nil);
  776. $1=$recv(failed)._and_((function(){
  777. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  778. return $core.withContext(function($ctx3) {
  779. //>>excludeEnd("ctx");
  780. return $recv(self["@testCase"])._isAsync();
  781. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  782. $ctx3.sendIdx["isAsync"]=1;
  783. //>>excludeEnd("ctx");
  784. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  785. }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
  786. //>>excludeEnd("ctx");
  787. }));
  788. if($core.assert($1)){
  789. $recv(self["@testCase"])._finished();
  790. };
  791. $2=$recv(self["@testCase"])._isAsync();
  792. if(!$core.assert($2)){
  793. return $recv(self["@testCase"])._tearDown();
  794. };
  795. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  796. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
  797. //>>excludeEnd("ctx");
  798. }));
  799. return self;
  800. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  801. }, function($ctx1) {$ctx1.fill(self,"execute:",{aBlock:aBlock,failed:failed},$globals.TestContext)});
  802. //>>excludeEnd("ctx");
  803. },
  804. //>>excludeStart("ide", pragmas.excludeIdeData);
  805. args: ["aBlock"],
  806. 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 ] ]",
  807. referencedClasses: [],
  808. //>>excludeEnd("ide");
  809. messageSends: ["context:", "ensure:", "value", "ifTrue:", "and:", "isAsync", "finished", "ifFalse:", "tearDown"]
  810. }),
  811. $globals.TestContext);
  812. $core.addMethod(
  813. $core.method({
  814. selector: "start",
  815. protocol: 'running',
  816. fn: function (){
  817. var self=this;
  818. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  819. return $core.withContext(function($ctx1) {
  820. //>>excludeEnd("ctx");
  821. self._execute_((function(){
  822. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  823. return $core.withContext(function($ctx2) {
  824. //>>excludeEnd("ctx");
  825. $recv(self["@testCase"])._setUp();
  826. return $recv(self["@testCase"])._performTest();
  827. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  828. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  829. //>>excludeEnd("ctx");
  830. }));
  831. return self;
  832. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  833. }, function($ctx1) {$ctx1.fill(self,"start",{},$globals.TestContext)});
  834. //>>excludeEnd("ctx");
  835. },
  836. //>>excludeStart("ide", pragmas.excludeIdeData);
  837. args: [],
  838. source: "start\x0a\x09self execute: [\x0a\x09\x09testCase setUp.\x0a\x09\x09testCase performTest ]",
  839. referencedClasses: [],
  840. //>>excludeEnd("ide");
  841. messageSends: ["execute:", "setUp", "performTest"]
  842. }),
  843. $globals.TestContext);
  844. $core.addMethod(
  845. $core.method({
  846. selector: "testCase:",
  847. protocol: 'accessing',
  848. fn: function (aTestCase){
  849. var self=this;
  850. self["@testCase"]=aTestCase;
  851. return self;
  852. },
  853. //>>excludeStart("ide", pragmas.excludeIdeData);
  854. args: ["aTestCase"],
  855. source: "testCase: aTestCase\x0a\x09testCase := aTestCase",
  856. referencedClasses: [],
  857. //>>excludeEnd("ide");
  858. messageSends: []
  859. }),
  860. $globals.TestContext);
  861. $core.addMethod(
  862. $core.method({
  863. selector: "testCase:",
  864. protocol: 'instance creation',
  865. fn: function (aTestCase){
  866. var self=this;
  867. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  868. return $core.withContext(function($ctx1) {
  869. //>>excludeEnd("ctx");
  870. var $1;
  871. $1=self._new();
  872. $recv($1)._testCase_(aTestCase);
  873. return $recv($1)._yourself();
  874. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  875. }, function($ctx1) {$ctx1.fill(self,"testCase:",{aTestCase:aTestCase},$globals.TestContext.klass)});
  876. //>>excludeEnd("ctx");
  877. },
  878. //>>excludeStart("ide", pragmas.excludeIdeData);
  879. args: ["aTestCase"],
  880. source: "testCase: aTestCase\x0a\x09^ self new\x0a\x09\x09testCase: aTestCase;\x0a\x09\x09yourself",
  881. referencedClasses: [],
  882. //>>excludeEnd("ide");
  883. messageSends: ["testCase:", "new", "yourself"]
  884. }),
  885. $globals.TestContext.klass);
  886. $core.addClass('ReportingTestContext', $globals.TestContext, ['finished', 'result'], 'SUnit');
  887. //>>excludeStart("ide", pragmas.excludeIdeData);
  888. $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`.";
  889. //>>excludeEnd("ide");
  890. $core.addMethod(
  891. $core.method({
  892. selector: "execute:",
  893. protocol: 'running',
  894. fn: function (aBlock){
  895. var self=this;
  896. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  897. return $core.withContext(function($ctx1) {
  898. //>>excludeEnd("ctx");
  899. var $1;
  900. $recv((function(){
  901. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  902. return $core.withContext(function($ctx2) {
  903. //>>excludeEnd("ctx");
  904. return self._withErrorReporting_((function(){
  905. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  906. return $core.withContext(function($ctx3) {
  907. //>>excludeEnd("ctx");
  908. return (
  909. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  910. $ctx3.supercall = true,
  911. //>>excludeEnd("ctx");
  912. ($globals.ReportingTestContext.superclass||$boot.nilAsClass).fn.prototype._execute_.apply($recv(self), [aBlock]));
  913. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  914. $ctx3.supercall = false;
  915. //>>excludeEnd("ctx");;
  916. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  917. }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
  918. //>>excludeEnd("ctx");
  919. }));
  920. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  921. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  922. //>>excludeEnd("ctx");
  923. }))._ensure_((function(){
  924. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  925. return $core.withContext(function($ctx2) {
  926. //>>excludeEnd("ctx");
  927. $1=$recv(self["@testCase"])._isAsync();
  928. if(!$core.assert($1)){
  929. $recv(self["@result"])._increaseRuns();
  930. return $recv(self["@finished"])._value();
  931. };
  932. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  933. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
  934. //>>excludeEnd("ctx");
  935. }));
  936. return self;
  937. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  938. }, function($ctx1) {$ctx1.fill(self,"execute:",{aBlock:aBlock},$globals.ReportingTestContext)});
  939. //>>excludeEnd("ctx");
  940. },
  941. //>>excludeStart("ide", pragmas.excludeIdeData);
  942. args: ["aBlock"],
  943. 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 ] ]",
  944. referencedClasses: [],
  945. //>>excludeEnd("ide");
  946. messageSends: ["ensure:", "withErrorReporting:", "execute:", "ifFalse:", "isAsync", "increaseRuns", "value"]
  947. }),
  948. $globals.ReportingTestContext);
  949. $core.addMethod(
  950. $core.method({
  951. selector: "finished:",
  952. protocol: 'accessing',
  953. fn: function (aBlock){
  954. var self=this;
  955. self["@finished"]=aBlock;
  956. return self;
  957. },
  958. //>>excludeStart("ide", pragmas.excludeIdeData);
  959. args: ["aBlock"],
  960. source: "finished: aBlock\x0a\x09finished := aBlock",
  961. referencedClasses: [],
  962. //>>excludeEnd("ide");
  963. messageSends: []
  964. }),
  965. $globals.ReportingTestContext);
  966. $core.addMethod(
  967. $core.method({
  968. selector: "result:",
  969. protocol: 'accessing',
  970. fn: function (aTestResult){
  971. var self=this;
  972. self["@result"]=aTestResult;
  973. return self;
  974. },
  975. //>>excludeStart("ide", pragmas.excludeIdeData);
  976. args: ["aTestResult"],
  977. source: "result: aTestResult\x0a\x09result := aTestResult",
  978. referencedClasses: [],
  979. //>>excludeEnd("ide");
  980. messageSends: []
  981. }),
  982. $globals.ReportingTestContext);
  983. $core.addMethod(
  984. $core.method({
  985. selector: "withErrorReporting:",
  986. protocol: 'private',
  987. fn: function (aBlock){
  988. var self=this;
  989. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  990. return $core.withContext(function($ctx1) {
  991. //>>excludeEnd("ctx");
  992. $recv((function(){
  993. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  994. return $core.withContext(function($ctx2) {
  995. //>>excludeEnd("ctx");
  996. return $recv(aBlock)._on_do_($globals.TestFailure,(function(ex){
  997. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  998. return $core.withContext(function($ctx3) {
  999. //>>excludeEnd("ctx");
  1000. return $recv(self["@result"])._addFailure_(self["@testCase"]);
  1001. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1002. }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,2)});
  1003. //>>excludeEnd("ctx");
  1004. }));
  1005. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1006. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1007. //>>excludeEnd("ctx");
  1008. }))._on_do_($globals.Error,(function(ex){
  1009. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1010. return $core.withContext(function($ctx2) {
  1011. //>>excludeEnd("ctx");
  1012. return $recv(self["@result"])._addError_(self["@testCase"]);
  1013. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1014. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,3)});
  1015. //>>excludeEnd("ctx");
  1016. }));
  1017. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1018. $ctx1.sendIdx["on:do:"]=1;
  1019. //>>excludeEnd("ctx");
  1020. return self;
  1021. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1022. }, function($ctx1) {$ctx1.fill(self,"withErrorReporting:",{aBlock:aBlock},$globals.ReportingTestContext)});
  1023. //>>excludeEnd("ctx");
  1024. },
  1025. //>>excludeStart("ide", pragmas.excludeIdeData);
  1026. args: ["aBlock"],
  1027. 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 ]",
  1028. referencedClasses: ["TestFailure", "Error"],
  1029. //>>excludeEnd("ide");
  1030. messageSends: ["on:do:", "addFailure:", "addError:"]
  1031. }),
  1032. $globals.ReportingTestContext);
  1033. $core.addMethod(
  1034. $core.method({
  1035. selector: "testCase:result:finished:",
  1036. protocol: 'instance creation',
  1037. fn: function (aTestCase,aTestResult,aBlock){
  1038. var self=this;
  1039. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1040. return $core.withContext(function($ctx1) {
  1041. //>>excludeEnd("ctx");
  1042. var $1;
  1043. $1=(
  1044. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1045. $ctx1.supercall = true,
  1046. //>>excludeEnd("ctx");
  1047. ($globals.ReportingTestContext.klass.superclass||$boot.nilAsClass).fn.prototype._testCase_.apply($recv(self), [aTestCase]));
  1048. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1049. $ctx1.supercall = false;
  1050. //>>excludeEnd("ctx");;
  1051. $recv($1)._result_(aTestResult);
  1052. $recv($1)._finished_(aBlock);
  1053. return $recv($1)._yourself();
  1054. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1055. }, function($ctx1) {$ctx1.fill(self,"testCase:result:finished:",{aTestCase:aTestCase,aTestResult:aTestResult,aBlock:aBlock},$globals.ReportingTestContext.klass)});
  1056. //>>excludeEnd("ctx");
  1057. },
  1058. //>>excludeStart("ide", pragmas.excludeIdeData);
  1059. args: ["aTestCase", "aTestResult", "aBlock"],
  1060. source: "testCase: aTestCase result: aTestResult finished: aBlock\x0a\x09^ (super testCase: aTestCase)\x0a\x09\x09result: aTestResult;\x0a\x09\x09finished: aBlock;\x0a\x09\x09yourself",
  1061. referencedClasses: [],
  1062. //>>excludeEnd("ide");
  1063. messageSends: ["result:", "testCase:", "finished:", "yourself"]
  1064. }),
  1065. $globals.ReportingTestContext.klass);
  1066. $core.addClass('TestFailure', $globals.Error, [], 'SUnit');
  1067. //>>excludeStart("ide", pragmas.excludeIdeData);
  1068. $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.";
  1069. //>>excludeEnd("ide");
  1070. $core.addClass('TestResult', $globals.Object, ['timestamp', 'runs', 'errors', 'failures', 'total'], 'SUnit');
  1071. //>>excludeStart("ide", pragmas.excludeIdeData);
  1072. $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";
  1073. //>>excludeEnd("ide");
  1074. $core.addMethod(
  1075. $core.method({
  1076. selector: "addError:",
  1077. protocol: 'accessing',
  1078. fn: function (anError){
  1079. var self=this;
  1080. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1081. return $core.withContext(function($ctx1) {
  1082. //>>excludeEnd("ctx");
  1083. $recv(self._errors())._add_(anError);
  1084. return self;
  1085. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1086. }, function($ctx1) {$ctx1.fill(self,"addError:",{anError:anError},$globals.TestResult)});
  1087. //>>excludeEnd("ctx");
  1088. },
  1089. //>>excludeStart("ide", pragmas.excludeIdeData);
  1090. args: ["anError"],
  1091. source: "addError: anError\x0a\x09self errors add: anError",
  1092. referencedClasses: [],
  1093. //>>excludeEnd("ide");
  1094. messageSends: ["add:", "errors"]
  1095. }),
  1096. $globals.TestResult);
  1097. $core.addMethod(
  1098. $core.method({
  1099. selector: "addFailure:",
  1100. protocol: 'accessing',
  1101. fn: function (aFailure){
  1102. var self=this;
  1103. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1104. return $core.withContext(function($ctx1) {
  1105. //>>excludeEnd("ctx");
  1106. $recv(self._failures())._add_(aFailure);
  1107. return self;
  1108. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1109. }, function($ctx1) {$ctx1.fill(self,"addFailure:",{aFailure:aFailure},$globals.TestResult)});
  1110. //>>excludeEnd("ctx");
  1111. },
  1112. //>>excludeStart("ide", pragmas.excludeIdeData);
  1113. args: ["aFailure"],
  1114. source: "addFailure: aFailure\x0a\x09self failures add: aFailure",
  1115. referencedClasses: [],
  1116. //>>excludeEnd("ide");
  1117. messageSends: ["add:", "failures"]
  1118. }),
  1119. $globals.TestResult);
  1120. $core.addMethod(
  1121. $core.method({
  1122. selector: "errors",
  1123. protocol: 'accessing',
  1124. fn: function (){
  1125. var self=this;
  1126. return self["@errors"];
  1127. },
  1128. //>>excludeStart("ide", pragmas.excludeIdeData);
  1129. args: [],
  1130. source: "errors\x0a\x09^ errors",
  1131. referencedClasses: [],
  1132. //>>excludeEnd("ide");
  1133. messageSends: []
  1134. }),
  1135. $globals.TestResult);
  1136. $core.addMethod(
  1137. $core.method({
  1138. selector: "failures",
  1139. protocol: 'accessing',
  1140. fn: function (){
  1141. var self=this;
  1142. return self["@failures"];
  1143. },
  1144. //>>excludeStart("ide", pragmas.excludeIdeData);
  1145. args: [],
  1146. source: "failures\x0a\x09^ failures",
  1147. referencedClasses: [],
  1148. //>>excludeEnd("ide");
  1149. messageSends: []
  1150. }),
  1151. $globals.TestResult);
  1152. $core.addMethod(
  1153. $core.method({
  1154. selector: "increaseRuns",
  1155. protocol: 'accessing',
  1156. fn: function (){
  1157. var self=this;
  1158. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1159. return $core.withContext(function($ctx1) {
  1160. //>>excludeEnd("ctx");
  1161. self["@runs"]=$recv(self["@runs"]).__plus((1));
  1162. return self;
  1163. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1164. }, function($ctx1) {$ctx1.fill(self,"increaseRuns",{},$globals.TestResult)});
  1165. //>>excludeEnd("ctx");
  1166. },
  1167. //>>excludeStart("ide", pragmas.excludeIdeData);
  1168. args: [],
  1169. source: "increaseRuns\x0a\x09runs := runs + 1",
  1170. referencedClasses: [],
  1171. //>>excludeEnd("ide");
  1172. messageSends: ["+"]
  1173. }),
  1174. $globals.TestResult);
  1175. $core.addMethod(
  1176. $core.method({
  1177. selector: "initialize",
  1178. protocol: 'initialization',
  1179. fn: function (){
  1180. var self=this;
  1181. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1182. return $core.withContext(function($ctx1) {
  1183. //>>excludeEnd("ctx");
  1184. (
  1185. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1186. $ctx1.supercall = true,
  1187. //>>excludeEnd("ctx");
  1188. ($globals.TestResult.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
  1189. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1190. $ctx1.supercall = false;
  1191. //>>excludeEnd("ctx");;
  1192. self["@timestamp"]=$recv($globals.Date)._now();
  1193. self["@runs"]=(0);
  1194. self["@errors"]=$recv($globals.Array)._new();
  1195. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1196. $ctx1.sendIdx["new"]=1;
  1197. //>>excludeEnd("ctx");
  1198. self["@failures"]=$recv($globals.Array)._new();
  1199. self["@total"]=(0);
  1200. return self;
  1201. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1202. }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestResult)});
  1203. //>>excludeEnd("ctx");
  1204. },
  1205. //>>excludeStart("ide", pragmas.excludeIdeData);
  1206. args: [],
  1207. source: "initialize\x0a\x09super initialize.\x0a\x09timestamp := Date now.\x0a\x09runs := 0.\x0a\x09errors := Array new.\x0a\x09failures := Array new.\x0a\x09total := 0",
  1208. referencedClasses: ["Date", "Array"],
  1209. //>>excludeEnd("ide");
  1210. messageSends: ["initialize", "now", "new"]
  1211. }),
  1212. $globals.TestResult);
  1213. $core.addMethod(
  1214. $core.method({
  1215. selector: "nextRunDo:",
  1216. protocol: 'running',
  1217. fn: function (aBlock){
  1218. var self=this;
  1219. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1220. return $core.withContext(function($ctx1) {
  1221. //>>excludeEnd("ctx");
  1222. var $2,$1;
  1223. $2=self._runs();
  1224. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1225. $ctx1.sendIdx["runs"]=1;
  1226. //>>excludeEnd("ctx");
  1227. $1=$recv($2).__eq_eq(self._total());
  1228. if(!$core.assert($1)){
  1229. return $recv(aBlock)._value_($recv(self._runs()).__plus((1)));
  1230. };
  1231. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1232. }, function($ctx1) {$ctx1.fill(self,"nextRunDo:",{aBlock:aBlock},$globals.TestResult)});
  1233. //>>excludeEnd("ctx");
  1234. },
  1235. //>>excludeStart("ide", pragmas.excludeIdeData);
  1236. args: ["aBlock"],
  1237. 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 ]",
  1238. referencedClasses: [],
  1239. //>>excludeEnd("ide");
  1240. messageSends: ["ifFalse:", "==", "runs", "total", "value:", "+"]
  1241. }),
  1242. $globals.TestResult);
  1243. $core.addMethod(
  1244. $core.method({
  1245. selector: "runCase:",
  1246. protocol: 'running',
  1247. fn: function (aTestCase){
  1248. var self=this;
  1249. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1250. return $core.withContext(function($ctx1) {
  1251. //>>excludeEnd("ctx");
  1252. $recv((function(){
  1253. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1254. return $core.withContext(function($ctx2) {
  1255. //>>excludeEnd("ctx");
  1256. return $recv((function(){
  1257. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1258. return $core.withContext(function($ctx3) {
  1259. //>>excludeEnd("ctx");
  1260. self._increaseRuns();
  1261. return $recv(aTestCase)._runCase();
  1262. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1263. }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
  1264. //>>excludeEnd("ctx");
  1265. }))._on_do_($globals.TestFailure,(function(ex){
  1266. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1267. return $core.withContext(function($ctx3) {
  1268. //>>excludeEnd("ctx");
  1269. return self._addFailure_(aTestCase);
  1270. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1271. }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,3)});
  1272. //>>excludeEnd("ctx");
  1273. }));
  1274. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1275. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1276. //>>excludeEnd("ctx");
  1277. }))._on_do_($globals.Error,(function(ex){
  1278. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1279. return $core.withContext(function($ctx2) {
  1280. //>>excludeEnd("ctx");
  1281. return self._addError_(aTestCase);
  1282. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1283. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,4)});
  1284. //>>excludeEnd("ctx");
  1285. }));
  1286. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1287. $ctx1.sendIdx["on:do:"]=1;
  1288. //>>excludeEnd("ctx");
  1289. return self;
  1290. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1291. }, function($ctx1) {$ctx1.fill(self,"runCase:",{aTestCase:aTestCase},$globals.TestResult)});
  1292. //>>excludeEnd("ctx");
  1293. },
  1294. //>>excludeStart("ide", pragmas.excludeIdeData);
  1295. args: ["aTestCase"],
  1296. 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 ]",
  1297. referencedClasses: ["TestFailure", "Error"],
  1298. //>>excludeEnd("ide");
  1299. messageSends: ["on:do:", "increaseRuns", "runCase", "addFailure:", "addError:"]
  1300. }),
  1301. $globals.TestResult);
  1302. $core.addMethod(
  1303. $core.method({
  1304. selector: "runs",
  1305. protocol: 'accessing',
  1306. fn: function (){
  1307. var self=this;
  1308. return self["@runs"];
  1309. },
  1310. //>>excludeStart("ide", pragmas.excludeIdeData);
  1311. args: [],
  1312. source: "runs\x0a\x09^ runs",
  1313. referencedClasses: [],
  1314. //>>excludeEnd("ide");
  1315. messageSends: []
  1316. }),
  1317. $globals.TestResult);
  1318. $core.addMethod(
  1319. $core.method({
  1320. selector: "status",
  1321. protocol: 'accessing',
  1322. fn: function (){
  1323. var self=this;
  1324. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1325. return $core.withContext(function($ctx1) {
  1326. //>>excludeEnd("ctx");
  1327. var $2,$3,$1;
  1328. $2=$recv(self._errors())._isEmpty();
  1329. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1330. $ctx1.sendIdx["isEmpty"]=1;
  1331. //>>excludeEnd("ctx");
  1332. if($core.assert($2)){
  1333. $3=$recv(self._failures())._isEmpty();
  1334. if($core.assert($3)){
  1335. $1="success";
  1336. } else {
  1337. $1="failure";
  1338. };
  1339. } else {
  1340. $1="error";
  1341. };
  1342. return $1;
  1343. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1344. }, function($ctx1) {$ctx1.fill(self,"status",{},$globals.TestResult)});
  1345. //>>excludeEnd("ctx");
  1346. },
  1347. //>>excludeStart("ide", pragmas.excludeIdeData);
  1348. args: [],
  1349. 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' ]",
  1350. referencedClasses: [],
  1351. //>>excludeEnd("ide");
  1352. messageSends: ["ifTrue:ifFalse:", "isEmpty", "errors", "failures"]
  1353. }),
  1354. $globals.TestResult);
  1355. $core.addMethod(
  1356. $core.method({
  1357. selector: "timestamp",
  1358. protocol: 'accessing',
  1359. fn: function (){
  1360. var self=this;
  1361. return self["@timestamp"];
  1362. },
  1363. //>>excludeStart("ide", pragmas.excludeIdeData);
  1364. args: [],
  1365. source: "timestamp\x0a\x09^ timestamp",
  1366. referencedClasses: [],
  1367. //>>excludeEnd("ide");
  1368. messageSends: []
  1369. }),
  1370. $globals.TestResult);
  1371. $core.addMethod(
  1372. $core.method({
  1373. selector: "total",
  1374. protocol: 'accessing',
  1375. fn: function (){
  1376. var self=this;
  1377. return self["@total"];
  1378. },
  1379. //>>excludeStart("ide", pragmas.excludeIdeData);
  1380. args: [],
  1381. source: "total\x0a\x09^ total",
  1382. referencedClasses: [],
  1383. //>>excludeEnd("ide");
  1384. messageSends: []
  1385. }),
  1386. $globals.TestResult);
  1387. $core.addMethod(
  1388. $core.method({
  1389. selector: "total:",
  1390. protocol: 'accessing',
  1391. fn: function (aNumber){
  1392. var self=this;
  1393. self["@total"]=aNumber;
  1394. return self;
  1395. },
  1396. //>>excludeStart("ide", pragmas.excludeIdeData);
  1397. args: ["aNumber"],
  1398. source: "total: aNumber\x0a\x09total := aNumber",
  1399. referencedClasses: [],
  1400. //>>excludeEnd("ide");
  1401. messageSends: []
  1402. }),
  1403. $globals.TestResult);
  1404. $core.addClass('TestSuiteRunner', $globals.Object, ['suite', 'result', 'announcer', 'runNextTest'], 'SUnit');
  1405. //>>excludeStart("ide", pragmas.excludeIdeData);
  1406. $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`.";
  1407. //>>excludeEnd("ide");
  1408. $core.addMethod(
  1409. $core.method({
  1410. selector: "announcer",
  1411. protocol: 'accessing',
  1412. fn: function (){
  1413. var self=this;
  1414. return self["@announcer"];
  1415. },
  1416. //>>excludeStart("ide", pragmas.excludeIdeData);
  1417. args: [],
  1418. source: "announcer\x0a\x09^ announcer",
  1419. referencedClasses: [],
  1420. //>>excludeEnd("ide");
  1421. messageSends: []
  1422. }),
  1423. $globals.TestSuiteRunner);
  1424. $core.addMethod(
  1425. $core.method({
  1426. selector: "contextOf:",
  1427. protocol: 'private',
  1428. fn: function (anInteger){
  1429. var self=this;
  1430. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1431. return $core.withContext(function($ctx1) {
  1432. //>>excludeEnd("ctx");
  1433. return $recv($globals.ReportingTestContext)._testCase_result_finished_($recv(self["@suite"])._at_(anInteger),self["@result"],(function(){
  1434. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1435. return $core.withContext(function($ctx2) {
  1436. //>>excludeEnd("ctx");
  1437. return self._resume();
  1438. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1439. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1440. //>>excludeEnd("ctx");
  1441. }));
  1442. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1443. }, function($ctx1) {$ctx1.fill(self,"contextOf:",{anInteger:anInteger},$globals.TestSuiteRunner)});
  1444. //>>excludeEnd("ctx");
  1445. },
  1446. //>>excludeStart("ide", pragmas.excludeIdeData);
  1447. args: ["anInteger"],
  1448. source: "contextOf: anInteger\x0a\x09^ ReportingTestContext testCase: (suite at: anInteger) result: result finished: [ self resume ]",
  1449. referencedClasses: ["ReportingTestContext"],
  1450. //>>excludeEnd("ide");
  1451. messageSends: ["testCase:result:finished:", "at:", "resume"]
  1452. }),
  1453. $globals.TestSuiteRunner);
  1454. $core.addMethod(
  1455. $core.method({
  1456. selector: "initialize",
  1457. protocol: 'initialization',
  1458. fn: function (){
  1459. var self=this;
  1460. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1461. return $core.withContext(function($ctx1) {
  1462. //>>excludeEnd("ctx");
  1463. var $1;
  1464. (
  1465. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1466. $ctx1.supercall = true,
  1467. //>>excludeEnd("ctx");
  1468. ($globals.TestSuiteRunner.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
  1469. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1470. $ctx1.supercall = false;
  1471. //>>excludeEnd("ctx");;
  1472. self["@announcer"]=$recv($globals.Announcer)._new();
  1473. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1474. $ctx1.sendIdx["new"]=1;
  1475. //>>excludeEnd("ctx");
  1476. self["@result"]=$recv($globals.TestResult)._new();
  1477. self["@runNextTest"]=(function(){
  1478. var runs;
  1479. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1480. return $core.withContext(function($ctx2) {
  1481. //>>excludeEnd("ctx");
  1482. runs=$recv(self["@result"])._runs();
  1483. runs;
  1484. $1=$recv(runs).__lt($recv(self["@result"])._total());
  1485. if($core.assert($1)){
  1486. return $recv(self._contextOf_($recv(runs).__plus((1))))._start();
  1487. };
  1488. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1489. }, function($ctx2) {$ctx2.fillBlock({runs:runs},$ctx1,1)});
  1490. //>>excludeEnd("ctx");
  1491. });
  1492. return self;
  1493. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1494. }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestSuiteRunner)});
  1495. //>>excludeEnd("ctx");
  1496. },
  1497. //>>excludeStart("ide", pragmas.excludeIdeData);
  1498. args: [],
  1499. 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 ] ].",
  1500. referencedClasses: ["Announcer", "TestResult"],
  1501. //>>excludeEnd("ide");
  1502. messageSends: ["initialize", "new", "runs", "ifTrue:", "<", "total", "start", "contextOf:", "+"]
  1503. }),
  1504. $globals.TestSuiteRunner);
  1505. $core.addMethod(
  1506. $core.method({
  1507. selector: "result",
  1508. protocol: 'accessing',
  1509. fn: function (){
  1510. var self=this;
  1511. return self["@result"];
  1512. },
  1513. //>>excludeStart("ide", pragmas.excludeIdeData);
  1514. args: [],
  1515. source: "result\x0a\x09^ result",
  1516. referencedClasses: [],
  1517. //>>excludeEnd("ide");
  1518. messageSends: []
  1519. }),
  1520. $globals.TestSuiteRunner);
  1521. $core.addMethod(
  1522. $core.method({
  1523. selector: "resume",
  1524. protocol: 'actions',
  1525. fn: function (){
  1526. var self=this;
  1527. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1528. return $core.withContext(function($ctx1) {
  1529. //>>excludeEnd("ctx");
  1530. $recv(self["@runNextTest"])._fork();
  1531. $recv(self["@announcer"])._announce_($recv($recv($globals.ResultAnnouncement)._new())._result_(self["@result"]));
  1532. return self;
  1533. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1534. }, function($ctx1) {$ctx1.fill(self,"resume",{},$globals.TestSuiteRunner)});
  1535. //>>excludeEnd("ctx");
  1536. },
  1537. //>>excludeStart("ide", pragmas.excludeIdeData);
  1538. args: [],
  1539. source: "resume\x0a\x09runNextTest fork.\x0a\x09announcer announce: (ResultAnnouncement new result: result)",
  1540. referencedClasses: ["ResultAnnouncement"],
  1541. //>>excludeEnd("ide");
  1542. messageSends: ["fork", "announce:", "result:", "new"]
  1543. }),
  1544. $globals.TestSuiteRunner);
  1545. $core.addMethod(
  1546. $core.method({
  1547. selector: "run",
  1548. protocol: 'actions',
  1549. fn: function (){
  1550. var self=this;
  1551. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1552. return $core.withContext(function($ctx1) {
  1553. //>>excludeEnd("ctx");
  1554. $recv(self["@result"])._total_($recv(self["@suite"])._size());
  1555. self._resume();
  1556. return self;
  1557. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1558. }, function($ctx1) {$ctx1.fill(self,"run",{},$globals.TestSuiteRunner)});
  1559. //>>excludeEnd("ctx");
  1560. },
  1561. //>>excludeStart("ide", pragmas.excludeIdeData);
  1562. args: [],
  1563. source: "run\x0a\x09result total: suite size.\x0a\x09self resume",
  1564. referencedClasses: [],
  1565. //>>excludeEnd("ide");
  1566. messageSends: ["total:", "size", "resume"]
  1567. }),
  1568. $globals.TestSuiteRunner);
  1569. $core.addMethod(
  1570. $core.method({
  1571. selector: "suite:",
  1572. protocol: 'accessing',
  1573. fn: function (aCollection){
  1574. var self=this;
  1575. self["@suite"]=aCollection;
  1576. return self;
  1577. },
  1578. //>>excludeStart("ide", pragmas.excludeIdeData);
  1579. args: ["aCollection"],
  1580. source: "suite: aCollection\x0a\x09suite := aCollection",
  1581. referencedClasses: [],
  1582. //>>excludeEnd("ide");
  1583. messageSends: []
  1584. }),
  1585. $globals.TestSuiteRunner);
  1586. $core.addMethod(
  1587. $core.method({
  1588. selector: "new",
  1589. protocol: 'instance creation',
  1590. fn: function (){
  1591. var self=this;
  1592. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1593. return $core.withContext(function($ctx1) {
  1594. //>>excludeEnd("ctx");
  1595. self._shouldNotImplement();
  1596. return self;
  1597. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1598. }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.TestSuiteRunner.klass)});
  1599. //>>excludeEnd("ctx");
  1600. },
  1601. //>>excludeStart("ide", pragmas.excludeIdeData);
  1602. args: [],
  1603. source: "new\x0a\x09self shouldNotImplement",
  1604. referencedClasses: [],
  1605. //>>excludeEnd("ide");
  1606. messageSends: ["shouldNotImplement"]
  1607. }),
  1608. $globals.TestSuiteRunner.klass);
  1609. $core.addMethod(
  1610. $core.method({
  1611. selector: "on:",
  1612. protocol: 'instance creation',
  1613. fn: function (aCollection){
  1614. var self=this;
  1615. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1616. return $core.withContext(function($ctx1) {
  1617. //>>excludeEnd("ctx");
  1618. var $1;
  1619. $1=(
  1620. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1621. $ctx1.supercall = true,
  1622. //>>excludeEnd("ctx");
  1623. ($globals.TestSuiteRunner.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
  1624. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1625. $ctx1.supercall = false;
  1626. //>>excludeEnd("ctx");;
  1627. return $recv($1)._suite_(aCollection);
  1628. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1629. }, function($ctx1) {$ctx1.fill(self,"on:",{aCollection:aCollection},$globals.TestSuiteRunner.klass)});
  1630. //>>excludeEnd("ctx");
  1631. },
  1632. //>>excludeStart("ide", pragmas.excludeIdeData);
  1633. args: ["aCollection"],
  1634. source: "on: aCollection\x0a\x09^ super new suite: aCollection",
  1635. referencedClasses: [],
  1636. //>>excludeEnd("ide");
  1637. messageSends: ["suite:", "new"]
  1638. }),
  1639. $globals.TestSuiteRunner.klass);
  1640. $core.addMethod(
  1641. $core.method({
  1642. selector: "isTestClass",
  1643. protocol: '*SUnit',
  1644. fn: function (){
  1645. var self=this;
  1646. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1647. return $core.withContext(function($ctx1) {
  1648. //>>excludeEnd("ctx");
  1649. return $recv(self._includesBehavior_($globals.TestCase))._and_((function(){
  1650. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1651. return $core.withContext(function($ctx2) {
  1652. //>>excludeEnd("ctx");
  1653. return $recv(self._isAbstract())._not();
  1654. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1655. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1656. //>>excludeEnd("ctx");
  1657. }));
  1658. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1659. }, function($ctx1) {$ctx1.fill(self,"isTestClass",{},$globals.Behavior)});
  1660. //>>excludeEnd("ctx");
  1661. },
  1662. //>>excludeStart("ide", pragmas.excludeIdeData);
  1663. args: [],
  1664. source: "isTestClass\x0a\x09^(self includesBehavior: TestCase) and: [ \x0a\x09\x09\x09self isAbstract not ]",
  1665. referencedClasses: ["TestCase"],
  1666. //>>excludeEnd("ide");
  1667. messageSends: ["and:", "includesBehavior:", "not", "isAbstract"]
  1668. }),
  1669. $globals.Behavior);
  1670. $core.addMethod(
  1671. $core.method({
  1672. selector: "isTestPackage",
  1673. protocol: '*SUnit',
  1674. fn: function (){
  1675. var self=this;
  1676. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1677. return $core.withContext(function($ctx1) {
  1678. //>>excludeEnd("ctx");
  1679. return $recv(self._classes())._anySatisfy_((function(each){
  1680. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1681. return $core.withContext(function($ctx2) {
  1682. //>>excludeEnd("ctx");
  1683. return $recv(each)._isTestClass();
  1684. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1685. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  1686. //>>excludeEnd("ctx");
  1687. }));
  1688. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1689. }, function($ctx1) {$ctx1.fill(self,"isTestPackage",{},$globals.Package)});
  1690. //>>excludeEnd("ctx");
  1691. },
  1692. //>>excludeStart("ide", pragmas.excludeIdeData);
  1693. args: [],
  1694. source: "isTestPackage\x0a\x09^ self classes anySatisfy: [ :each | each isTestClass ]",
  1695. referencedClasses: [],
  1696. //>>excludeEnd("ide");
  1697. messageSends: ["anySatisfy:", "classes", "isTestClass"]
  1698. }),
  1699. $globals.Package);
  1700. });