Axxord-Tests.js 39 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055
  1. define(["amber/boot", "amber_core/SUnit", "axxord/Axxord"], function($boot){"use strict";
  2. if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
  3. if(!("nilAsValue" in $boot))$boot.nilAsValue=$boot.nilAsReceiver;
  4. var $core=$boot.api,nil=$boot.nilAsValue,$nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
  5. if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
  6. $core.addPackage("Axxord-Tests");
  7. $core.packages["Axxord-Tests"].innerEval = function (expr) { return eval(expr); };
  8. $core.packages["Axxord-Tests"].transport = {"type":"amd","amdNamespace":"axxord"};
  9. $core.addClass("AxolatorTest", $globals.TestCase, ["rootModel"], "Axxord-Tests");
  10. $core.addMethod(
  11. $core.method({
  12. selector: "setUp",
  13. protocol: "running",
  14. fn: function (){
  15. var self=this,$self=this;
  16. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  17. return $core.withContext(function($ctx1) {
  18. //>>excludeEnd("ctx");
  19. var $1;
  20. $1=$recv($globals.EavModel)._new();
  21. $recv($1)._getBlock_((function(x){
  22. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  23. return $core.withContext(function($ctx2) {
  24. //>>excludeEnd("ctx");
  25. return $recv(x)._root();
  26. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  27. }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
  28. //>>excludeEnd("ctx");
  29. }));
  30. $self["@rootModel"]=$recv($1)._putBlock_((function(x,y){
  31. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  32. return $core.withContext(function($ctx2) {
  33. //>>excludeEnd("ctx");
  34. return $recv(x)._root_(y);
  35. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  36. }, function($ctx2) {$ctx2.fillBlock({x:x,y:y},$ctx1,2)});
  37. //>>excludeEnd("ctx");
  38. }));
  39. return self;
  40. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  41. }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.AxolatorTest)});
  42. //>>excludeEnd("ctx");
  43. },
  44. //>>excludeStart("ide", pragmas.excludeIdeData);
  45. args: [],
  46. source: "setUp\x0a\x0arootModel := EavModel new\x0a\x09getBlock: [:x | x root];\x0a putBlock: [:x :y | x root: y].",
  47. referencedClasses: ["EavModel"],
  48. //>>excludeEnd("ide");
  49. messageSends: ["getBlock:", "new", "root", "putBlock:", "root:"]
  50. }),
  51. $globals.AxolatorTest);
  52. $core.addMethod(
  53. $core.method({
  54. selector: "testNontrivialModelGetsAppropriateValueForModification",
  55. protocol: "tests",
  56. fn: function (){
  57. var self=this,$self=this;
  58. var isolator,model,result;
  59. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  60. return $core.withContext(function($ctx1) {
  61. //>>excludeEnd("ctx");
  62. var $1,$3,$2;
  63. result=nil;
  64. isolator=$recv($globals.Axolator)._on_($globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (5)]], "baz"],"moo","zoo"]));
  65. $1=$recv($globals.EavModel)._new();
  66. $recv($1)._getBlock_((function(x){
  67. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  68. return $core.withContext(function($ctx2) {
  69. //>>excludeEnd("ctx");
  70. $3=$recv(x)._root();
  71. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  72. $ctx2.sendIdx["root"]=1;
  73. //>>excludeEnd("ctx");
  74. $2=$recv($3)._at_("foo");
  75. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  76. $ctx2.sendIdx["at:"]=2;
  77. //>>excludeEnd("ctx");
  78. return $recv($2)._at_((2));
  79. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  80. $ctx2.sendIdx["at:"]=1;
  81. //>>excludeEnd("ctx");
  82. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  83. }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
  84. //>>excludeEnd("ctx");
  85. }));
  86. model=$recv($1)._putBlock_((function(x,y){
  87. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  88. return $core.withContext(function($ctx2) {
  89. //>>excludeEnd("ctx");
  90. return $recv($recv($recv(x)._root())._at_("foo"))._at_put_((2),y);
  91. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  92. }, function($ctx2) {$ctx2.fillBlock({x:x,y:y},$ctx1,2)});
  93. //>>excludeEnd("ctx");
  94. }));
  95. $recv(isolator)._model_modify_(model,(function(r){
  96. result=r;
  97. return result;
  98. }));
  99. $self._assert_equals_([(1), [(2), (5)]],result);
  100. return self;
  101. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  102. }, function($ctx1) {$ctx1.fill(self,"testNontrivialModelGetsAppropriateValueForModification",{isolator:isolator,model:model,result:result},$globals.AxolatorTest)});
  103. //>>excludeEnd("ctx");
  104. },
  105. //>>excludeStart("ide", pragmas.excludeIdeData);
  106. args: [],
  107. source: "testNontrivialModelGetsAppropriateValueForModification\x0a| isolator model result |\x0aresult := nil.\x0aisolator := Axolator on: #{ 'foo' -> #('bar' #(1 #(2 5)) 'baz'). 'moo' -> 'zoo' }.\x0amodel := EavModel new\x0a\x09getBlock: [ :x | (x root at: 'foo') at: 2 ];\x0a\x09putBlock: [ :x :y | (x root at: 'foo') at: 2 put: y].\x0aisolator model: model modify: [:r|result := r].\x0aself assert: #(1 #(2 5)) equals: result",
  108. referencedClasses: ["Axolator", "EavModel"],
  109. //>>excludeEnd("ide");
  110. messageSends: ["on:", "getBlock:", "new", "at:", "root", "putBlock:", "at:put:", "model:modify:", "assert:equals:"]
  111. }),
  112. $globals.AxolatorTest);
  113. $core.addMethod(
  114. $core.method({
  115. selector: "testNontrivialModelModifiesAppropriateValue",
  116. protocol: "tests",
  117. fn: function (){
  118. var self=this,$self=this;
  119. var isolator,model,result;
  120. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  121. return $core.withContext(function($ctx1) {
  122. //>>excludeEnd("ctx");
  123. var $1,$3,$2;
  124. result=nil;
  125. isolator=$recv($globals.Axolator)._on_($globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (3)]], "baz"],"moo","zoo"]));
  126. $1=$recv($globals.EavModel)._new();
  127. $recv($1)._getBlock_((function(x){
  128. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  129. return $core.withContext(function($ctx2) {
  130. //>>excludeEnd("ctx");
  131. $3=$recv(x)._root();
  132. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  133. $ctx2.sendIdx["root"]=1;
  134. //>>excludeEnd("ctx");
  135. $2=$recv($3)._at_("foo");
  136. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  137. $ctx2.sendIdx["at:"]=2;
  138. //>>excludeEnd("ctx");
  139. return $recv($2)._at_((2));
  140. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  141. $ctx2.sendIdx["at:"]=1;
  142. //>>excludeEnd("ctx");
  143. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  144. }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
  145. //>>excludeEnd("ctx");
  146. }));
  147. model=$recv($1)._putBlock_((function(x,y){
  148. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  149. return $core.withContext(function($ctx2) {
  150. //>>excludeEnd("ctx");
  151. return $recv($recv($recv(x)._root())._at_("foo"))._at_put_((2),y);
  152. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  153. }, function($ctx2) {$ctx2.fillBlock({x:x,y:y},$ctx1,2)});
  154. //>>excludeEnd("ctx");
  155. }));
  156. $recv(isolator)._model_modify_(model,(function(r){
  157. return "new";
  158. }));
  159. $recv(isolator)._model_read_(model,(function(r){
  160. result=r;
  161. return result;
  162. }));
  163. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  164. $ctx1.sendIdx["model:read:"]=1;
  165. //>>excludeEnd("ctx");
  166. $self._assert_equals_("new",result);
  167. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  168. $ctx1.sendIdx["assert:equals:"]=1;
  169. //>>excludeEnd("ctx");
  170. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  171. result=r;
  172. return result;
  173. }));
  174. $self._assert_equals_($globals.HashedCollection._newFromPairs_(["foo",["bar", "new", "baz"],"moo","zoo"]),result);
  175. return self;
  176. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  177. }, function($ctx1) {$ctx1.fill(self,"testNontrivialModelModifiesAppropriateValue",{isolator:isolator,model:model,result:result},$globals.AxolatorTest)});
  178. //>>excludeEnd("ctx");
  179. },
  180. //>>excludeStart("ide", pragmas.excludeIdeData);
  181. args: [],
  182. source: "testNontrivialModelModifiesAppropriateValue\x0a| isolator model result |\x0aresult := nil.\x0aisolator := Axolator on: #{ 'foo' -> #('bar' #(1 #(2 3)) 'baz'). 'moo' -> 'zoo' }.\x0amodel := EavModel new\x0a\x09getBlock: [ :x | (x root at: 'foo') at: 2 ];\x0a\x09putBlock: [ :x :y | (x root at: 'foo') at: 2 put: y].\x0aisolator model: model modify: [:r|#new].\x0aisolator model: model read: [:r|result := r].\x0aself assert: #new equals: result.\x0aisolator model: rootModel read: [:r|result := r].\x0aself assert: #{ 'foo' -> #('bar' #new 'baz'). 'moo' -> 'zoo' } equals: result",
  183. referencedClasses: ["Axolator", "EavModel"],
  184. //>>excludeEnd("ide");
  185. messageSends: ["on:", "getBlock:", "new", "at:", "root", "putBlock:", "at:put:", "model:modify:", "model:read:", "assert:equals:"]
  186. }),
  187. $globals.AxolatorTest);
  188. $core.addMethod(
  189. $core.method({
  190. selector: "testNontrivialModelReturnsAppropriateValue",
  191. protocol: "tests",
  192. fn: function (){
  193. var self=this,$self=this;
  194. var isolator,model,result;
  195. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  196. return $core.withContext(function($ctx1) {
  197. //>>excludeEnd("ctx");
  198. result=nil;
  199. isolator=$recv($globals.Axolator)._on_($globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (3)]], "baz"],"moo","zoo"]));
  200. model=$recv($recv($globals.EavModel)._new())._getBlock_((function(x){
  201. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  202. return $core.withContext(function($ctx2) {
  203. //>>excludeEnd("ctx");
  204. return $recv($recv($recv(x)._root())._at_("foo"))._at_((2));
  205. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  206. $ctx2.sendIdx["at:"]=1;
  207. //>>excludeEnd("ctx");
  208. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  209. }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
  210. //>>excludeEnd("ctx");
  211. }));
  212. $recv(isolator)._model_read_(model,(function(r){
  213. result=r;
  214. return result;
  215. }));
  216. $self._assert_equals_([(1), [(2), (3)]],result);
  217. return self;
  218. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  219. }, function($ctx1) {$ctx1.fill(self,"testNontrivialModelReturnsAppropriateValue",{isolator:isolator,model:model,result:result},$globals.AxolatorTest)});
  220. //>>excludeEnd("ctx");
  221. },
  222. //>>excludeStart("ide", pragmas.excludeIdeData);
  223. args: [],
  224. source: "testNontrivialModelReturnsAppropriateValue\x0a| isolator model result |\x0aresult := nil.\x0aisolator := Axolator on: #{ 'foo' -> #('bar' #(1 #(2 3)) 'baz'). 'moo' -> 'zoo' }.\x0amodel := EavModel new getBlock: [ :x | (x root at: 'foo') at: 2 ].\x0aisolator model: model read: [:r|result := r].\x0aself assert: #(1 #(2 3)) equals: result",
  225. referencedClasses: ["Axolator", "EavModel"],
  226. //>>excludeEnd("ide");
  227. messageSends: ["on:", "getBlock:", "new", "at:", "root", "model:read:", "assert:equals:"]
  228. }),
  229. $globals.AxolatorTest);
  230. $core.addMethod(
  231. $core.method({
  232. selector: "testRootModelExaminesThenModifiesRoot",
  233. protocol: "tests",
  234. fn: function (){
  235. var self=this,$self=this;
  236. var isolator,result;
  237. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  238. return $core.withContext(function($ctx1) {
  239. //>>excludeEnd("ctx");
  240. result=nil;
  241. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  242. $recv(isolator)._model_modify_($self["@rootModel"],(function(r){
  243. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  244. return $core.withContext(function($ctx2) {
  245. //>>excludeEnd("ctx");
  246. return $recv(r)._second();
  247. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  248. }, function($ctx2) {$ctx2.fillBlock({r:r},$ctx1,1)});
  249. //>>excludeEnd("ctx");
  250. }));
  251. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  252. result=r;
  253. return result;
  254. }));
  255. $self._assert_equals_([(2), (3)],result);
  256. return self;
  257. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  258. }, function($ctx1) {$ctx1.fill(self,"testRootModelExaminesThenModifiesRoot",{isolator:isolator,result:result},$globals.AxolatorTest)});
  259. //>>excludeEnd("ctx");
  260. },
  261. //>>excludeStart("ide", pragmas.excludeIdeData);
  262. args: [],
  263. source: "testRootModelExaminesThenModifiesRoot\x0a| isolator result |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0aisolator model: rootModel modify: [:r|r second].\x0aisolator model: rootModel read: [:r|result := r].\x0aself assert: #(2 3) equals: result",
  264. referencedClasses: ["Axolator"],
  265. //>>excludeEnd("ide");
  266. messageSends: ["on:", "model:modify:", "second", "model:read:", "assert:equals:"]
  267. }),
  268. $globals.AxolatorTest);
  269. $core.addMethod(
  270. $core.method({
  271. selector: "testRootModelGetsRootForModification",
  272. protocol: "tests",
  273. fn: function (){
  274. var self=this,$self=this;
  275. var isolator,result;
  276. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  277. return $core.withContext(function($ctx1) {
  278. //>>excludeEnd("ctx");
  279. result=nil;
  280. isolator=$recv($globals.Axolator)._on_([(2), [(1), (0)]]);
  281. $recv(isolator)._model_modify_($self["@rootModel"],(function(r){
  282. result=r;
  283. return result;
  284. }));
  285. $self._assert_equals_([(2), [(1), (0)]],result);
  286. return self;
  287. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  288. }, function($ctx1) {$ctx1.fill(self,"testRootModelGetsRootForModification",{isolator:isolator,result:result},$globals.AxolatorTest)});
  289. //>>excludeEnd("ctx");
  290. },
  291. //>>excludeStart("ide", pragmas.excludeIdeData);
  292. args: [],
  293. source: "testRootModelGetsRootForModification\x0a| isolator result |\x0aresult := nil.\x0aisolator := Axolator on: #(2 #(1 0)).\x0aisolator model: rootModel modify: [:r|result := r].\x0aself assert: #(2 #(1 0)) equals: result",
  294. referencedClasses: ["Axolator"],
  295. //>>excludeEnd("ide");
  296. messageSends: ["on:", "model:modify:", "assert:equals:"]
  297. }),
  298. $globals.AxolatorTest);
  299. $core.addMethod(
  300. $core.method({
  301. selector: "testRootModelModifiesAndDeeplyIsolatesInPlaceModifiedRoot",
  302. protocol: "tests",
  303. fn: function (){
  304. var self=this,$self=this;
  305. var isolator,result,newValue;
  306. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  307. return $core.withContext(function($ctx1) {
  308. //>>excludeEnd("ctx");
  309. result=nil;
  310. newValue=nil;
  311. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  312. $recv(isolator)._model_modify_($self["@rootModel"],(function(r){
  313. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  314. return $core.withContext(function($ctx2) {
  315. //>>excludeEnd("ctx");
  316. newValue=r;
  317. newValue;
  318. $recv(r)._at_put_((1),(4));
  319. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  320. $ctx2.sendIdx["at:put:"]=1;
  321. //>>excludeEnd("ctx");
  322. return r;
  323. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  324. }, function($ctx2) {$ctx2.fillBlock({r:r},$ctx1,1)});
  325. //>>excludeEnd("ctx");
  326. }));
  327. $recv(newValue)._at_put_((2),"bar");
  328. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  329. $ctx1.sendIdx["at:put:"]=2;
  330. //>>excludeEnd("ctx");
  331. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  332. result=r;
  333. return result;
  334. }));
  335. $recv(newValue)._at_put_((2),"baz");
  336. $self._assert_equals_([(4), [(2), (3)]],result);
  337. return self;
  338. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  339. }, function($ctx1) {$ctx1.fill(self,"testRootModelModifiesAndDeeplyIsolatesInPlaceModifiedRoot",{isolator:isolator,result:result,newValue:newValue},$globals.AxolatorTest)});
  340. //>>excludeEnd("ctx");
  341. },
  342. //>>excludeStart("ide", pragmas.excludeIdeData);
  343. args: [],
  344. source: "testRootModelModifiesAndDeeplyIsolatesInPlaceModifiedRoot\x0a| isolator result newValue |\x0aresult := nil. newValue := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0aisolator model: rootModel modify: [:r|newValue := r. r at: 1 put: 4. r].\x0anewValue at: 2 put: 'bar'.\x0aisolator model: rootModel read: [:r|result := r].\x0anewValue at: 2 put: 'baz'.\x0aself assert: #(4 #(2 3)) equals: result",
  345. referencedClasses: ["Axolator"],
  346. //>>excludeEnd("ide");
  347. messageSends: ["on:", "model:modify:", "at:put:", "model:read:", "assert:equals:"]
  348. }),
  349. $globals.AxolatorTest);
  350. $core.addMethod(
  351. $core.method({
  352. selector: "testRootModelModifiesAndDeeplyIsolatesRoot",
  353. protocol: "tests",
  354. fn: function (){
  355. var self=this,$self=this;
  356. var isolator,result,newValue;
  357. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  358. return $core.withContext(function($ctx1) {
  359. //>>excludeEnd("ctx");
  360. var $1;
  361. result=nil;
  362. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  363. newValue=$globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]);
  364. $recv(isolator)._model_modify_($self["@rootModel"],(function(r){
  365. return newValue;
  366. }));
  367. $1=$recv(newValue)._at_("foo");
  368. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  369. $ctx1.sendIdx["at:"]=1;
  370. //>>excludeEnd("ctx");
  371. $recv($1)._at_put_((1),"bar");
  372. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  373. $ctx1.sendIdx["at:put:"]=1;
  374. //>>excludeEnd("ctx");
  375. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  376. result=r;
  377. return result;
  378. }));
  379. $recv($recv(newValue)._at_("foo"))._at_put_((3),"baz");
  380. $self._assert_equals_($globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]),result);
  381. return self;
  382. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  383. }, function($ctx1) {$ctx1.fill(self,"testRootModelModifiesAndDeeplyIsolatesRoot",{isolator:isolator,result:result,newValue:newValue},$globals.AxolatorTest)});
  384. //>>excludeEnd("ctx");
  385. },
  386. //>>excludeStart("ide", pragmas.excludeIdeData);
  387. args: [],
  388. source: "testRootModelModifiesAndDeeplyIsolatesRoot\x0a| isolator result newValue |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0anewValue := #{'foo'->#(4 5 6)}.\x0aisolator model: rootModel modify: [:r|newValue].\x0a(newValue at: 'foo') at: 1 put: 'bar'.\x0aisolator model: rootModel read: [:r|result := r].\x0a(newValue at: 'foo') at: 3 put: 'baz'.\x0aself assert: #{'foo'->#(4 5 6)} equals: result",
  389. referencedClasses: ["Axolator"],
  390. //>>excludeEnd("ide");
  391. messageSends: ["on:", "model:modify:", "at:put:", "at:", "model:read:", "assert:equals:"]
  392. }),
  393. $globals.AxolatorTest);
  394. $core.addMethod(
  395. $core.method({
  396. selector: "testRootModelModifiesAndIsolatesRoot",
  397. protocol: "tests",
  398. fn: function (){
  399. var self=this,$self=this;
  400. var isolator,result,newValue;
  401. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  402. return $core.withContext(function($ctx1) {
  403. //>>excludeEnd("ctx");
  404. result=nil;
  405. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  406. newValue=$globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]);
  407. $recv(isolator)._model_modify_($self["@rootModel"],(function(r){
  408. return newValue;
  409. }));
  410. $recv(newValue)._at_put_("foo","bar");
  411. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  412. $ctx1.sendIdx["at:put:"]=1;
  413. //>>excludeEnd("ctx");
  414. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  415. result=r;
  416. return result;
  417. }));
  418. $recv(newValue)._at_put_("foo","baz");
  419. $self._assert_equals_($globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]),result);
  420. return self;
  421. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  422. }, function($ctx1) {$ctx1.fill(self,"testRootModelModifiesAndIsolatesRoot",{isolator:isolator,result:result,newValue:newValue},$globals.AxolatorTest)});
  423. //>>excludeEnd("ctx");
  424. },
  425. //>>excludeStart("ide", pragmas.excludeIdeData);
  426. args: [],
  427. source: "testRootModelModifiesAndIsolatesRoot\x0a| isolator result newValue |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0anewValue := #{'foo'->#(4 5 6)}.\x0aisolator model: rootModel modify: [:r|newValue].\x0anewValue at: 'foo' put: 'bar'.\x0aisolator model: rootModel read: [:r|result := r].\x0anewValue at: 'foo' put: 'baz'.\x0aself assert: #{'foo'->#(4 5 6)} equals: result",
  428. referencedClasses: ["Axolator"],
  429. //>>excludeEnd("ide");
  430. messageSends: ["on:", "model:modify:", "at:put:", "model:read:", "assert:equals:"]
  431. }),
  432. $globals.AxolatorTest);
  433. $core.addMethod(
  434. $core.method({
  435. selector: "testRootModelModifiesRoot",
  436. protocol: "tests",
  437. fn: function (){
  438. var self=this,$self=this;
  439. var isolator,result;
  440. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  441. return $core.withContext(function($ctx1) {
  442. //>>excludeEnd("ctx");
  443. result=nil;
  444. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  445. $recv(isolator)._model_modify_($self["@rootModel"],(function(r){
  446. return $globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]);
  447. }));
  448. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  449. result=r;
  450. return result;
  451. }));
  452. $self._assert_equals_($globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]),result);
  453. return self;
  454. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  455. }, function($ctx1) {$ctx1.fill(self,"testRootModelModifiesRoot",{isolator:isolator,result:result},$globals.AxolatorTest)});
  456. //>>excludeEnd("ctx");
  457. },
  458. //>>excludeStart("ide", pragmas.excludeIdeData);
  459. args: [],
  460. source: "testRootModelModifiesRoot\x0a| isolator result |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0aisolator model: rootModel modify: [:r|#{'foo'->#(4 5 6)}].\x0aisolator model: rootModel read: [:r|result := r].\x0aself assert: #{'foo'->#(4 5 6)} equals: result",
  461. referencedClasses: ["Axolator"],
  462. //>>excludeEnd("ide");
  463. messageSends: ["on:", "model:modify:", "model:read:", "assert:equals:"]
  464. }),
  465. $globals.AxolatorTest);
  466. $core.addMethod(
  467. $core.method({
  468. selector: "testRootModelReturnsDeeplyIsolatedRoot",
  469. protocol: "tests",
  470. fn: function (){
  471. var self=this,$self=this;
  472. var isolator,result;
  473. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  474. return $core.withContext(function($ctx1) {
  475. //>>excludeEnd("ctx");
  476. result=nil;
  477. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  478. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  479. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  480. return $core.withContext(function($ctx2) {
  481. //>>excludeEnd("ctx");
  482. return $recv($recv(r)._at_((2)))._at_put_((1),(0));
  483. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  484. }, function($ctx2) {$ctx2.fillBlock({r:r},$ctx1,1)});
  485. //>>excludeEnd("ctx");
  486. }));
  487. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  488. $ctx1.sendIdx["model:read:"]=1;
  489. //>>excludeEnd("ctx");
  490. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  491. result=r;
  492. return result;
  493. }));
  494. $self._assert_equals_([(1), [(2), (3)]],result);
  495. return self;
  496. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  497. }, function($ctx1) {$ctx1.fill(self,"testRootModelReturnsDeeplyIsolatedRoot",{isolator:isolator,result:result},$globals.AxolatorTest)});
  498. //>>excludeEnd("ctx");
  499. },
  500. //>>excludeStart("ide", pragmas.excludeIdeData);
  501. args: [],
  502. source: "testRootModelReturnsDeeplyIsolatedRoot\x0a| isolator result |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0aisolator model: rootModel read: [:r|(r at: 2) at: 1 put: 0].\x0aisolator model: rootModel read: [:r|result := r].\x0aself assert: #(1 #(2 3)) equals: result",
  503. referencedClasses: ["Axolator"],
  504. //>>excludeEnd("ide");
  505. messageSends: ["on:", "model:read:", "at:put:", "at:", "assert:equals:"]
  506. }),
  507. $globals.AxolatorTest);
  508. $core.addMethod(
  509. $core.method({
  510. selector: "testRootModelReturnsIsolatedRoot",
  511. protocol: "tests",
  512. fn: function (){
  513. var self=this,$self=this;
  514. var isolator,result;
  515. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  516. return $core.withContext(function($ctx1) {
  517. //>>excludeEnd("ctx");
  518. result=nil;
  519. isolator=$recv($globals.Axolator)._on_([(1), [(2), (4)]]);
  520. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  521. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  522. return $core.withContext(function($ctx2) {
  523. //>>excludeEnd("ctx");
  524. return $recv(r)._at_put_((2),nil);
  525. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  526. }, function($ctx2) {$ctx2.fillBlock({r:r},$ctx1,1)});
  527. //>>excludeEnd("ctx");
  528. }));
  529. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  530. $ctx1.sendIdx["model:read:"]=1;
  531. //>>excludeEnd("ctx");
  532. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  533. result=r;
  534. return result;
  535. }));
  536. $self._assert_equals_([(1), [(2), (4)]],result);
  537. return self;
  538. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  539. }, function($ctx1) {$ctx1.fill(self,"testRootModelReturnsIsolatedRoot",{isolator:isolator,result:result},$globals.AxolatorTest)});
  540. //>>excludeEnd("ctx");
  541. },
  542. //>>excludeStart("ide", pragmas.excludeIdeData);
  543. args: [],
  544. source: "testRootModelReturnsIsolatedRoot\x0a| isolator result |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 4)).\x0aisolator model: rootModel read: [:r|r at: 2 put: nil].\x0aisolator model: rootModel read: [:r|result := r].\x0aself assert: #(1 #(2 4)) equals: result",
  545. referencedClasses: ["Axolator"],
  546. //>>excludeEnd("ide");
  547. messageSends: ["on:", "model:read:", "at:put:", "assert:equals:"]
  548. }),
  549. $globals.AxolatorTest);
  550. $core.addMethod(
  551. $core.method({
  552. selector: "testRootModelReturnsRoot",
  553. protocol: "tests",
  554. fn: function (){
  555. var self=this,$self=this;
  556. var isolator,result;
  557. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  558. return $core.withContext(function($ctx1) {
  559. //>>excludeEnd("ctx");
  560. result=nil;
  561. isolator=$recv($globals.Axolator)._on_([(1), [(2), (3)]]);
  562. $recv(isolator)._model_read_($self["@rootModel"],(function(r){
  563. result=r;
  564. return result;
  565. }));
  566. $self._assert_equals_([(1), [(2), (3)]],result);
  567. return self;
  568. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  569. }, function($ctx1) {$ctx1.fill(self,"testRootModelReturnsRoot",{isolator:isolator,result:result},$globals.AxolatorTest)});
  570. //>>excludeEnd("ctx");
  571. },
  572. //>>excludeStart("ide", pragmas.excludeIdeData);
  573. args: [],
  574. source: "testRootModelReturnsRoot\x0a| isolator result |\x0aresult := nil.\x0aisolator := Axolator on: #(1 #(2 3)).\x0aisolator model: rootModel read: [:r|result := r].\x0aself assert: #(1 #(2 3)) equals: result",
  575. referencedClasses: ["Axolator"],
  576. //>>excludeEnd("ide");
  577. messageSends: ["on:", "model:read:", "assert:equals:"]
  578. }),
  579. $globals.AxolatorTest);
  580. $core.addClass("PlainConsumeTransformTest", $globals.TestCase, [], "Axxord-Tests");
  581. $core.addMethod(
  582. $core.method({
  583. selector: "testModelTransformSentToAxon",
  584. protocol: "tests",
  585. fn: function (){
  586. var self=this,$self=this;
  587. var model,result,axon;
  588. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  589. return $core.withContext(function($ctx1) {
  590. //>>excludeEnd("ctx");
  591. result=nil;
  592. model=$globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (3)]], "baz"],"moo","zoo"]);
  593. axon=$recv($globals.TestSpyAxon)._new();
  594. $recv(axon)._registerIn_(model);
  595. $recv(model)._axes_transform_(["foo", (2)],(function(r){
  596. return "new";
  597. }));
  598. $self._assert_equals_($recv(axon)._changedAspectLog(),[["foo", (2)]]);
  599. return self;
  600. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  601. }, function($ctx1) {$ctx1.fill(self,"testModelTransformSentToAxon",{model:model,result:result,axon:axon},$globals.PlainConsumeTransformTest)});
  602. //>>excludeEnd("ctx");
  603. },
  604. //>>excludeStart("ide", pragmas.excludeIdeData);
  605. args: [],
  606. source: "testModelTransformSentToAxon\x0a| model result axon |\x0aresult := nil.\x0amodel := #{ 'foo' -> #('bar' #(1 #(2 3)) 'baz'). 'moo' -> 'zoo' }.\x0aaxon := TestSpyAxon new.\x0aaxon registerIn: model.\x0amodel axes: #(foo 2) transform: [:r | #new].\x0aself assert: axon changedAspectLog equals: #((foo 2))",
  607. referencedClasses: ["TestSpyAxon"],
  608. //>>excludeEnd("ide");
  609. messageSends: ["new", "registerIn:", "axes:transform:", "assert:equals:", "changedAspectLog"]
  610. }),
  611. $globals.PlainConsumeTransformTest);
  612. $core.addMethod(
  613. $core.method({
  614. selector: "testNontrivialModelGetsAppropriateValueForTransform",
  615. protocol: "tests",
  616. fn: function (){
  617. var self=this,$self=this;
  618. var model,result;
  619. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  620. return $core.withContext(function($ctx1) {
  621. //>>excludeEnd("ctx");
  622. result=nil;
  623. model=$globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (5)]], "baz"],"moo","zoo"]);
  624. $recv(model)._axes_transform_(["foo", (2)],(function(r){
  625. result=r;
  626. return result;
  627. }));
  628. $self._assert_equals_([(1), [(2), (5)]],result);
  629. return self;
  630. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  631. }, function($ctx1) {$ctx1.fill(self,"testNontrivialModelGetsAppropriateValueForTransform",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  632. //>>excludeEnd("ctx");
  633. },
  634. //>>excludeStart("ide", pragmas.excludeIdeData);
  635. args: [],
  636. source: "testNontrivialModelGetsAppropriateValueForTransform\x0a| model result |\x0aresult := nil.\x0amodel := #{ 'foo' -> #('bar' #(1 #(2 5)) 'baz'). 'moo' -> 'zoo' }.\x0amodel axes: #(foo 2) transform: [:r | result := r].\x0aself assert: #(1 #(2 5)) equals: result",
  637. referencedClasses: [],
  638. //>>excludeEnd("ide");
  639. messageSends: ["axes:transform:", "assert:equals:"]
  640. }),
  641. $globals.PlainConsumeTransformTest);
  642. $core.addMethod(
  643. $core.method({
  644. selector: "testNontrivialModelReturnsAppropriateValue",
  645. protocol: "tests",
  646. fn: function (){
  647. var self=this,$self=this;
  648. var model,result;
  649. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  650. return $core.withContext(function($ctx1) {
  651. //>>excludeEnd("ctx");
  652. result=nil;
  653. model=$globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (3)]], "baz"],"moo","zoo"]);
  654. $recv(model)._axes_consume_(["foo", (2)],(function(r){
  655. result=r;
  656. return result;
  657. }));
  658. $self._assert_equals_([(1), [(2), (3)]],result);
  659. return self;
  660. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  661. }, function($ctx1) {$ctx1.fill(self,"testNontrivialModelReturnsAppropriateValue",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  662. //>>excludeEnd("ctx");
  663. },
  664. //>>excludeStart("ide", pragmas.excludeIdeData);
  665. args: [],
  666. source: "testNontrivialModelReturnsAppropriateValue\x0a| model result |\x0aresult := nil.\x0amodel := #{ 'foo' -> #('bar' #(1 #(2 3)) 'baz'). 'moo' -> 'zoo' }.\x0amodel axes: #(foo 2) consume: [:r | result := r].\x0aself assert: #(1 #(2 3)) equals: result",
  667. referencedClasses: [],
  668. //>>excludeEnd("ide");
  669. messageSends: ["axes:consume:", "assert:equals:"]
  670. }),
  671. $globals.PlainConsumeTransformTest);
  672. $core.addMethod(
  673. $core.method({
  674. selector: "testNontrivialModelTransformsAppropriateValue",
  675. protocol: "tests",
  676. fn: function (){
  677. var self=this,$self=this;
  678. var model,result;
  679. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  680. return $core.withContext(function($ctx1) {
  681. //>>excludeEnd("ctx");
  682. result=nil;
  683. model=$globals.HashedCollection._newFromPairs_(["foo",["bar", [(1), [(2), (3)]], "baz"],"moo","zoo"]);
  684. $recv(model)._axes_transform_(["foo", (2)],(function(r){
  685. return "new";
  686. }));
  687. $recv(model)._axes_consume_(["foo", (2)],(function(r){
  688. result=r;
  689. return result;
  690. }));
  691. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  692. $ctx1.sendIdx["axes:consume:"]=1;
  693. //>>excludeEnd("ctx");
  694. $self._assert_equals_("new",result);
  695. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  696. $ctx1.sendIdx["assert:equals:"]=1;
  697. //>>excludeEnd("ctx");
  698. $recv(model)._axes_consume_([],(function(r){
  699. result=r;
  700. return result;
  701. }));
  702. $self._assert_equals_($globals.HashedCollection._newFromPairs_(["foo",["bar", "new", "baz"],"moo","zoo"]),result);
  703. return self;
  704. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  705. }, function($ctx1) {$ctx1.fill(self,"testNontrivialModelTransformsAppropriateValue",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  706. //>>excludeEnd("ctx");
  707. },
  708. //>>excludeStart("ide", pragmas.excludeIdeData);
  709. args: [],
  710. source: "testNontrivialModelTransformsAppropriateValue\x0a| model result |\x0aresult := nil.\x0amodel := #{ 'foo' -> #('bar' #(1 #(2 3)) 'baz'). 'moo' -> 'zoo' }.\x0amodel axes: #(foo 2) transform: [:r | #new].\x0amodel axes: #(foo 2) consume: [:r | result := r].\x0aself assert: #new equals: result.\x0amodel axes: #() consume: [:r | result := r].\x0aself assert: #{ 'foo' -> #('bar' #new 'baz'). 'moo' -> 'zoo' } equals: result",
  711. referencedClasses: [],
  712. //>>excludeEnd("ide");
  713. messageSends: ["axes:transform:", "axes:consume:", "assert:equals:"]
  714. }),
  715. $globals.PlainConsumeTransformTest);
  716. $core.addMethod(
  717. $core.method({
  718. selector: "testRootModelCannotTransform",
  719. protocol: "tests",
  720. fn: function (){
  721. var self=this,$self=this;
  722. var model,result;
  723. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  724. return $core.withContext(function($ctx1) {
  725. //>>excludeEnd("ctx");
  726. result=nil;
  727. model=[(1), [(2), (3)]];
  728. $self._should_raise_((function(){
  729. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  730. return $core.withContext(function($ctx2) {
  731. //>>excludeEnd("ctx");
  732. return $recv(model)._axes_transform_([],(function(r){
  733. return $globals.HashedCollection._newFromPairs_(["foo",[(4), (5), (6)]]);
  734. }));
  735. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  736. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  737. //>>excludeEnd("ctx");
  738. }),$globals.Error);
  739. return self;
  740. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  741. }, function($ctx1) {$ctx1.fill(self,"testRootModelCannotTransform",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  742. //>>excludeEnd("ctx");
  743. },
  744. //>>excludeStart("ide", pragmas.excludeIdeData);
  745. args: [],
  746. source: "testRootModelCannotTransform\x0a| model result |\x0aresult := nil.\x0amodel := #(1 #(2 3)).\x0aself should: [ model axes: #() transform: [:r | #{'foo'->#(4 5 6)}] ] raise: Error",
  747. referencedClasses: ["Error"],
  748. //>>excludeEnd("ide");
  749. messageSends: ["should:raise:", "axes:transform:"]
  750. }),
  751. $globals.PlainConsumeTransformTest);
  752. $core.addMethod(
  753. $core.method({
  754. selector: "testRootModelReturnsDirectRoot",
  755. protocol: "tests",
  756. fn: function (){
  757. var self=this,$self=this;
  758. var model,result;
  759. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  760. return $core.withContext(function($ctx1) {
  761. //>>excludeEnd("ctx");
  762. result=nil;
  763. model=[(1), [(2), (4)]];
  764. $recv(model)._axes_consume_([],(function(r){
  765. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  766. return $core.withContext(function($ctx2) {
  767. //>>excludeEnd("ctx");
  768. return $recv(r)._at_put_((2),nil);
  769. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  770. }, function($ctx2) {$ctx2.fillBlock({r:r},$ctx1,1)});
  771. //>>excludeEnd("ctx");
  772. }));
  773. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  774. $ctx1.sendIdx["axes:consume:"]=1;
  775. //>>excludeEnd("ctx");
  776. $recv(model)._axes_consume_([],(function(r){
  777. result=r;
  778. return result;
  779. }));
  780. $self._assert_equals_([(1), nil],result);
  781. return self;
  782. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  783. }, function($ctx1) {$ctx1.fill(self,"testRootModelReturnsDirectRoot",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  784. //>>excludeEnd("ctx");
  785. },
  786. //>>excludeStart("ide", pragmas.excludeIdeData);
  787. args: [],
  788. source: "testRootModelReturnsDirectRoot\x0a| model result |\x0aresult := nil.\x0amodel := #(1 #(2 4)).\x0amodel axes: #() consume: [:r | r at: 2 put: nil].\x0amodel axes: #() consume: [:r | result := r].\x0aself assert: #(1 nil) equals: result",
  789. referencedClasses: [],
  790. //>>excludeEnd("ide");
  791. messageSends: ["axes:consume:", "at:put:", "assert:equals:"]
  792. }),
  793. $globals.PlainConsumeTransformTest);
  794. $core.addMethod(
  795. $core.method({
  796. selector: "testRootModelReturnsRoot",
  797. protocol: "tests",
  798. fn: function (){
  799. var self=this,$self=this;
  800. var model,result;
  801. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  802. return $core.withContext(function($ctx1) {
  803. //>>excludeEnd("ctx");
  804. result=nil;
  805. model=[(1), [(2), (3)]];
  806. $recv(model)._axes_consume_([],(function(r){
  807. result=r;
  808. return result;
  809. }));
  810. $self._assert_equals_([(1), [(2), (3)]],result);
  811. return self;
  812. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  813. }, function($ctx1) {$ctx1.fill(self,"testRootModelReturnsRoot",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  814. //>>excludeEnd("ctx");
  815. },
  816. //>>excludeStart("ide", pragmas.excludeIdeData);
  817. args: [],
  818. source: "testRootModelReturnsRoot\x0a| model result |\x0aresult := nil.\x0amodel := #(1 #(2 3)).\x0amodel axes: #() consume: [:r | result := r].\x0aself assert: #(1 #(2 3)) equals: result",
  819. referencedClasses: [],
  820. //>>excludeEnd("ide");
  821. messageSends: ["axes:consume:", "assert:equals:"]
  822. }),
  823. $globals.PlainConsumeTransformTest);
  824. $core.addMethod(
  825. $core.method({
  826. selector: "testRootTransformBlockIsRun",
  827. protocol: "tests",
  828. fn: function (){
  829. var self=this,$self=this;
  830. var model,result;
  831. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  832. return $core.withContext(function($ctx1) {
  833. //>>excludeEnd("ctx");
  834. result=nil;
  835. model=[(2), [(1), (0)]];
  836. $recv((function(){
  837. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  838. return $core.withContext(function($ctx2) {
  839. //>>excludeEnd("ctx");
  840. return $recv(model)._axes_transform_([],(function(r){
  841. result=r;
  842. result;
  843. return model;
  844. }));
  845. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  846. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  847. //>>excludeEnd("ctx");
  848. }))._on_do_($globals.Error,(function(){
  849. }));
  850. $self._assert_equals_(result,model);
  851. return self;
  852. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  853. }, function($ctx1) {$ctx1.fill(self,"testRootTransformBlockIsRun",{model:model,result:result},$globals.PlainConsumeTransformTest)});
  854. //>>excludeEnd("ctx");
  855. },
  856. //>>excludeStart("ide", pragmas.excludeIdeData);
  857. args: [],
  858. source: "testRootTransformBlockIsRun\x0a| model result |\x0aresult := nil.\x0amodel := #(2 #(1 0)).\x0a[model axes: #() transform: [:r | result := r. model]] on: Error do: [].\x0aself assert: result equals: model",
  859. referencedClasses: ["Error"],
  860. //>>excludeEnd("ide");
  861. messageSends: ["on:do:", "axes:transform:", "assert:equals:"]
  862. }),
  863. $globals.PlainConsumeTransformTest);
  864. $core.addMethod(
  865. $core.method({
  866. selector: "testRootTransformFailsOnActualChange",
  867. protocol: "tests",
  868. fn: function (){
  869. var self=this,$self=this;
  870. var model;
  871. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  872. return $core.withContext(function($ctx1) {
  873. //>>excludeEnd("ctx");
  874. model=[(2), [(1), (0)]];
  875. $self._should_raise_((function(){
  876. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  877. return $core.withContext(function($ctx2) {
  878. //>>excludeEnd("ctx");
  879. return $recv(model)._axes_transform_([],(function(r){
  880. return "new";
  881. }));
  882. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  883. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  884. //>>excludeEnd("ctx");
  885. }),$globals.Error);
  886. return self;
  887. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  888. }, function($ctx1) {$ctx1.fill(self,"testRootTransformFailsOnActualChange",{model:model},$globals.PlainConsumeTransformTest)});
  889. //>>excludeEnd("ctx");
  890. },
  891. //>>excludeStart("ide", pragmas.excludeIdeData);
  892. args: [],
  893. source: "testRootTransformFailsOnActualChange\x0a| model |\x0amodel := #(2 #(1 0)).\x0aself should: [model axes: #() transform: [:r | #new]] raise: Error",
  894. referencedClasses: ["Error"],
  895. //>>excludeEnd("ide");
  896. messageSends: ["should:raise:", "axes:transform:"]
  897. }),
  898. $globals.PlainConsumeTransformTest);
  899. $core.addClass("TestSpyAxon", $globals.DumbAxon, ["changedAspectLog"], "Axxord-Tests");
  900. //>>excludeStart("ide", pragmas.excludeIdeData);
  901. $globals.TestSpyAxon.comment="I am an axon that logs changed aspects. I am useful in tests.";
  902. //>>excludeEnd("ide");
  903. $core.addMethod(
  904. $core.method({
  905. selector: "changed:",
  906. protocol: "action",
  907. fn: function (anAspect){
  908. var self=this;
  909. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  910. return $core.withContext(function($ctx1) {
  911. //>>excludeEnd("ctx");
  912. $recv(self["@changedAspectLog"])._add_(anAspect);
  913. return self;
  914. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  915. }, function($ctx1) {$ctx1.fill(self,"changed:",{anAspect:anAspect},$globals.TestSpyAxon)});
  916. //>>excludeEnd("ctx");
  917. },
  918. //>>excludeStart("ide", pragmas.excludeIdeData);
  919. args: ["anAspect"],
  920. source: "changed: anAspect\x0a\x09changedAspectLog add: anAspect",
  921. referencedClasses: [],
  922. //>>excludeEnd("ide");
  923. messageSends: ["add:"]
  924. }),
  925. $globals.TestSpyAxon);
  926. $core.addMethod(
  927. $core.method({
  928. selector: "changedAspectLog",
  929. protocol: "accessing",
  930. fn: function (){
  931. var self=this;
  932. var $1;
  933. $1=self["@changedAspectLog"];
  934. return $1;
  935. },
  936. //>>excludeStart("ide", pragmas.excludeIdeData);
  937. args: [],
  938. source: "changedAspectLog\x0a\x09^ changedAspectLog",
  939. referencedClasses: [],
  940. //>>excludeEnd("ide");
  941. messageSends: []
  942. }),
  943. $globals.TestSpyAxon);
  944. $core.addMethod(
  945. $core.method({
  946. selector: "changedAspectLog:",
  947. protocol: "accessing",
  948. fn: function (anObject){
  949. var self=this;
  950. self["@changedAspectLog"]=anObject;
  951. return self;
  952. },
  953. //>>excludeStart("ide", pragmas.excludeIdeData);
  954. args: ["anObject"],
  955. source: "changedAspectLog: anObject\x0a\x09changedAspectLog := anObject",
  956. referencedClasses: [],
  957. //>>excludeEnd("ide");
  958. messageSends: []
  959. }),
  960. $globals.TestSpyAxon);
  961. $core.addMethod(
  962. $core.method({
  963. selector: "initialize",
  964. protocol: "initialization",
  965. fn: function (){
  966. var self=this;
  967. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  968. return $core.withContext(function($ctx1) {
  969. //>>excludeEnd("ctx");
  970. (
  971. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  972. $ctx1.supercall = true,
  973. //>>excludeEnd("ctx");
  974. $globals.TestSpyAxon.superclass.fn.prototype._initialize.apply($recv(self), []));
  975. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  976. $ctx1.supercall = false;
  977. //>>excludeEnd("ctx");;
  978. self["@changedAspectLog"]=[];
  979. return self;
  980. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  981. }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestSpyAxon)});
  982. //>>excludeEnd("ctx");
  983. },
  984. //>>excludeStart("ide", pragmas.excludeIdeData);
  985. args: [],
  986. source: "initialize\x0a\x09super initialize.\x0a\x0a\x09changedAspectLog := #()",
  987. referencedClasses: [],
  988. //>>excludeEnd("ide");
  989. messageSends: ["initialize"]
  990. }),
  991. $globals.TestSpyAxon);
  992. });