SUnit.js 57 KB

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