1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846 |
- Smalltalk current createPackage: 'Kernel-Tests'!
- TestCase subclass: #BlockClosureTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !BlockClosureTest methodsFor: 'tests'!
- testCanClearInterval
- self shouldnt: [([Error new signal] valueWithInterval: 0) clearInterval] raise: Error
- !
- testCanClearTimeout
- self shouldnt: [([Error new signal] valueWithTimeout: 0) clearTimeout] raise: Error
- !
- testCompiledSource
- self assert: ([1+1] compiledSource includesSubString: 'function')
- !
- testCurrySelf
- | curriedMethod array |
- curriedMethod := [ :selfarg :x | selfarg at: x ] currySelf asCompiledMethod: 'foo:'.
- array := #(3 1 4).
- ClassBuilder new installMethod: curriedMethod forClass: Array category: '**test helper'.
- [ self assert: (array foo: 2) equals: 1 ]
- ensure: [ Array removeCompiledMethod: curriedMethod ]
- !
- testEnsure
- self assert: ([3] ensure: [4]) equals: 3
- !
- testEnsureRaises
- self should: [[Error new signal] ensure: [true]] raise: Error
- !
- testExceptionSemantics
- "See https://github.com/NicolasPetton/amber/issues/314"
- self timeout: 100.
-
- (self async: [
- [
- self assert: true.
- Error signal.
- "The following should *not* be run"
- self deny: true.
- self finished.
- ] on: Error do: [ :ex | self finished ]
- ]) valueWithTimeout: 0
- !
- testNewWithValues
- <
- function theTestPrototype() {this.name = "theTestPrototype";}
- function theTestConstructor(arg1, arg2, arg3) {}
- theTestConstructor.prototype = new theTestPrototype;
- var theWrappedConstructor = _st(theTestConstructor);
- var theResult = theWrappedConstructor._newWithValues_([1, 2, 3]);
- self._assert_equals_(Object.getPrototypeOf(theResult).name, 'theTestPrototype');
- "newWithValues: cannot help if the argument list is wrong, and should warn that a mistake was made."
- function constructionShouldFail() {var anotherResult = theWrappedConstructor._newWithValues_('This is so wrong');}
- self._should_raise_(_st(constructionShouldFail), smalltalk.Error);
- >
- !
- testNumArgs
- self assert: [] numArgs equals: 0.
- self assert: [:a :b | ] numArgs equals: 2
- !
- testOnDo
- self assert: ([Error new signal] on: Error do: [:ex | true])
- !
- testValue
- self assert: ([1+1] value) equals: 2.
- self assert: ([:x | x +1] value: 2) equals: 3.
- self assert: ([:x :y | x*y] value: 2 value: 4) equals: 8.
- "Arguments are optional in Amber. This isn't ANSI compliant."
- self assert: ([:a :b :c | 1] value) equals: 1
- !
- testValueWithPossibleArguments
- self assert: ([1] valueWithPossibleArguments: #(3 4)) equals: 1.
- self assert: ([:a | a + 4] valueWithPossibleArguments: #(3 4)) equals: 7.
- self assert: ([:a :b | a + b] valueWithPossibleArguments: #(3 4 5)) equals: 7.
- !
- testWhileFalse
- | i |
- i := 0.
- [i > 5] whileFalse: [i := i + 1].
- self assert: i equals: 6.
- i := 0.
- [i := i + 1. i > 5] whileFalse.
- self assert: i equals: 6
- !
- testWhileTrue
- | i |
- i := 0.
- [i < 5] whileTrue: [i := i + 1].
- self assert: i equals: 5.
- i := 0.
- [i := i + 1. i < 5] whileTrue.
- self assert: i equals: 5
- ! !
- TestCase subclass: #BooleanTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !BooleanTest methodsFor: 'tests'!
- testEquality
- "We're on top of JS...just be sure to check the basics!!"
- self deny: 0 = false.
- self deny: false = 0.
- self deny: '' = false.
- self deny: false = ''.
- self assert: (true = true).
- self deny: false = true.
- self deny: true = false.
- self assert: (false = false).
- "JS may do some type coercing after sending a message"
- self assert: (true yourself = true).
- self assert: (true yourself = true yourself)
- !
- testIdentity
- "We're on top of JS...just be sure to check the basics!!"
- self deny: 0 == false.
- self deny: false == 0.
- self deny: '' == false.
- self deny: false == ''.
- self assert: true == true.
- self deny: false == true.
- self deny: true == false.
- self assert: false == false.
- "JS may do some type coercing after sending a message"
- self assert: true yourself == true.
- self assert: true yourself == true yourself
- !
- testIfTrueIfFalse
- self assert: (true ifTrue: ['alternative block']) equals: 'alternative block'.
- self assert: (true ifFalse: ['alternative block']) equals: nil.
- self assert: (false ifTrue: ['alternative block']) equals: nil.
- self assert: (false ifFalse: ['alternative block']) equals: 'alternative block'.
- self assert: (false ifTrue: ['alternative block'] ifFalse: ['alternative block2']) equals: 'alternative block2'.
- self assert: (false ifFalse: ['alternative block'] ifTrue: ['alternative block2']) equals: 'alternative block'.
- self assert: (true ifTrue: ['alternative block'] ifFalse: ['alternative block2']) equals: 'alternative block'.
- self assert: (true ifFalse: ['alternative block'] ifTrue: ['alternative block2']) equals: 'alternative block2'.
- !
- testIfTrueIfFalseWithBoxing
- self assert: (true yourself ifTrue: ['alternative block']) equals: 'alternative block'.
- self assert: (true yourself ifFalse: ['alternative block']) equals: nil.
- self assert: (false yourself ifTrue: ['alternative block']) equals: nil.
- self assert: (false yourself ifFalse: ['alternative block']) equals: 'alternative block'.
- self assert: (false yourself ifTrue: ['alternative block'] ifFalse: ['alternative block2']) equals: 'alternative block2'.
- self assert: (false yourself ifFalse: ['alternative block'] ifTrue: ['alternative block2']) equals: 'alternative block'.
- self assert: (true yourself ifTrue: ['alternative block'] ifFalse: ['alternative block2']) equals: 'alternative block'.
- self assert: (true yourself ifFalse: ['alternative block'] ifTrue: ['alternative block2']) equals: 'alternative block2'.
- !
- testLogic
- "Trivial logic table"
- self assert: (true & true);
- deny: (true & false);
- deny: (false & true);
- deny: (false & false).
- self assert: (true | true);
- assert: (true | false);
- assert: (false | true);
- deny: (false | false).
- "Checking that expressions work fine too"
- self assert: (true & (1 > 0));
- deny: ((1 > 0) & false);
- deny: ((1 > 0) & (1 > 2)).
- self assert: (false | (1 > 0));
- assert: ((1 > 0) | false);
- assert: ((1 > 0) | (1 > 2))
- !
- testLogicKeywords
- "Trivial logic table"
- self
- assert: (true and: [ true]);
- deny: (true and: [ false ]);
- deny: (false and: [ true ]);
- deny: (false and: [ false ]).
- self
- assert: (true or: [ true ]);
- assert: (true or: [ false ]);
- assert: (false or: [ true ]);
- deny: (false or: [ false ]).
-
- "Checking that expressions work fine too"
- self
- assert: (true and: [ 1 > 0 ]);
- deny: ((1 > 0) and: [ false ]);
- deny: ((1 > 0) and: [ 1 > 2 ]).
- self
- assert: (false or: [ 1 > 0 ]);
- assert: ((1 > 0) or: [ false ]);
- assert: ((1 > 0) or: [ 1 > 2 ])
- !
- testNonBooleanError
- self should: [ '' ifTrue: [] ifFalse: [] ] raise: NonBooleanReceiver
- ! !
- TestCase subclass: #ClassBuilderTest
- instanceVariableNames: 'builder theClass'
- package: 'Kernel-Tests'!
- !ClassBuilderTest methodsFor: 'running'!
- setUp
- builder := ClassBuilder new
- !
- tearDown
- theClass ifNotNil: [Smalltalk current removeClass: theClass. theClass := nil]
- ! !
- !ClassBuilderTest methodsFor: 'tests'!
- testClassCopy
- theClass := builder copyClass: ObjectMock named: 'ObjectMock2'.
- self assert: theClass superclass == ObjectMock superclass.
- self assert: theClass instanceVariableNames == ObjectMock instanceVariableNames.
- self assert: theClass name equals: 'ObjectMock2'.
- self assert: theClass package == ObjectMock package.
- self assert: theClass methodDictionary keys equals: ObjectMock methodDictionary keys
- !
- testClassMigration
- | instance oldClass |
-
- oldClass := builder copyClass: ObjectMock named: 'ObjectMock2'.
- instance := (Smalltalk current at: 'ObjectMock2') new.
-
- "Change the superclass of ObjectMock2"
- ObjectMock subclass: (Smalltalk current at: 'ObjectMock2')
- instanceVariableNames: ''
- package: 'Kernel-Tests'.
-
- self deny: oldClass == ObjectMock2.
-
- self assert: ObjectMock2 superclass == ObjectMock.
- self assert: ObjectMock2 instanceVariableNames isEmpty.
- self assert: ObjectMock2 selectors equals: oldClass selectors.
- self assert: ObjectMock2 comment equals: oldClass comment.
- self assert: ObjectMock2 package name equals: 'Kernel-Tests'.
-
- self deny: instance class == ObjectMock2.
- "Commeting this out. Tests implementation detail."
- "self assert: instance class name equals: 'OldObjectMock2'."
-
- self assert: (Smalltalk current at: instance class name) isNil.
-
- Smalltalk current removeClass: ObjectMock2
- !
- testClassMigrationWithClassInstanceVariables
-
- builder copyClass: ObjectMock named: 'ObjectMock2'.
- ObjectMock2 class instanceVariableNames: 'foo bar'.
-
- "Change the superclass of ObjectMock2"
- ObjectMock subclass: (Smalltalk current at: 'ObjectMock2')
- instanceVariableNames: ''
- package: 'Kernel-Tests'.
-
- self assert: ObjectMock2 class instanceVariableNames equals: #('foo' 'bar').
-
- Smalltalk current removeClass: ObjectMock2
- !
- testClassMigrationWithSubclasses
-
- builder copyClass: ObjectMock named: 'ObjectMock2'.
- ObjectMock2 subclass: 'ObjectMock3' instanceVariableNames: '' package: 'Kernel-Tests'.
- ObjectMock3 subclass: 'ObjectMock4' instanceVariableNames: '' package: 'Kernel-Tests'.
-
- "Change the superclass of ObjectMock2"
- ObjectMock subclass: (Smalltalk current at: 'ObjectMock2')
- instanceVariableNames: ''
- package: 'Kernel-Tests'.
-
- self assert: (ObjectMock subclasses includes: ObjectMock2).
- self assert: (ObjectMock2 subclasses includes: ObjectMock3).
- self assert: (ObjectMock3 subclasses includes: ObjectMock4).
-
- ObjectMock allSubclasses do: [ :each | Smalltalk current removeClass: each ]
- !
- testInstanceVariableNames
- self assert: (builder instanceVariableNamesFor: ' hello world ') equals: #('hello' 'world')
- ! !
- TestCase subclass: #CollectionTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !CollectionTest methodsFor: 'accessing'!
- collection
- ^ self collectionClass withAll: self defaultValues
- !
- collectionClass
- ^ self class collectionClass
- !
- collectionWithDuplicates
- ^ self collectionClass withAll: #('a' 'b' 'c' 1 2 1 'a')
- !
- defaultValues
- ^ #(1 2 3 -4)
- ! !
- !CollectionTest methodsFor: 'convenience'!
- assertSameContents: aCollection as: anotherCollection
- self assert: (aCollection size = anotherCollection size).
- aCollection do: [ :each |
- self assert: ((aCollection occurrencesOf: each) = (anotherCollection occurrencesOf: each)) ]
- ! !
- !CollectionTest methodsFor: 'testing'!
- isCollectionReadOnly
- ^ false
- ! !
- !CollectionTest methodsFor: 'tests'!
- testAsArray
- self
- assertSameContents: self collection
- as: self collection asArray
- !
- testAsOrderedCollection
- self
- assertSameContents: self collection
- as: self collection asOrderedCollection
- !
- testAsSet
- | c set |
- c := self collectionWithDuplicates.
- set := c asSet.
- self assert: set size equals: 5.
- c do: [ :each |
- self assert: (set includes: each) ]
- !
- testCollect
- | newCollection |
- newCollection := #(1 2 3 4).
- self
- assertSameContents: (self collection collect: [ :each |
- each abs ])
- as: newCollection
- !
- testDetect
- self assert: (self collection detect: [ :each | each < 0 ]) equals: -4.
- self
- should: [ self collection detect: [ :each | each = 6 ] ]
- raise: Error
- !
- testDo
- | newCollection |
- newCollection := OrderedCollection new.
- self collection do: [ :each |
- newCollection add: each ].
- self
- assertSameContents: self collection
- as: newCollection
- !
- testIsEmpty
- self assert: self collectionClass new isEmpty.
- self deny: self collection isEmpty
- !
- testSelect
- | newCollection |
- newCollection := #(2 -4).
- self
- assertSameContents: (self collection select: [ :each |
- each even ])
- as: newCollection
- !
- testSize
- self assert: self collectionClass new size equals: 0.
- self assert: self collection size equals: 4
- ! !
- !CollectionTest class methodsFor: 'accessing'!
- collectionClass
- ^ nil
- ! !
- !CollectionTest class methodsFor: 'testing'!
- isAbstract
- ^ self collectionClass isNil
- ! !
- CollectionTest subclass: #IndexableCollectionTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !IndexableCollectionTest methodsFor: 'tests'!
- testAt
- self assert: (self collection at: 4) equals: -4.
- self should: [ self collection at: 5 ] raise: Error
- !
- testAtIfAbsent
- self assert: (self collection at: (self collection size + 1) ifAbsent: [ 'none' ]) equals: 'none'
- !
- testContains
- | collection |
- collection := self collection.
-
- self assert: (self collection contains: [ :each | each = self collection first ]).
- self deny: (self collection contains: [ :each | each = Object new ])
- !
- testIndexOf
- self assert: (self collection indexOf: 2) equals: 2.
- self should: [ self collection indexOf: 999 ] raise: Error.
- self assert: (self collection indexOf: 999 ifAbsent: [ 'sentinel' ]) equals: 'sentinel'
- !
- testWithIndexDo
- | collection |
- collection := self collection.
-
- self collection withIndexDo: [ :each :index |
- self assert: (collection at: index) equals: each ]
- ! !
- IndexableCollectionTest subclass: #HashedCollectionTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !HashedCollectionTest methodsFor: 'accessing'!
- collection
- ^ #{ 'b' -> 1. 'a' -> 2. 'c' -> 3. 'd' -> -4 }
- !
- collectionWithDuplicates
- ^ #{ 'b' -> 1. 'a' -> 2. 'c' -> 3. 'd' -> -4. 'e' -> 1. 'f' -> 2. 'g' -> 10 }
- ! !
- !HashedCollectionTest methodsFor: 'tests'!
- testAsDictionary
- self assert: ( self collectionClass new asDictionary isMemberOf: Dictionary ).
- !
- testAt
- self assert: (self collection at: 'a') equals: 2.
- self should: [ self collection at: 5 ] raise: Error
- !
- testContains
- | collection |
- collection := self collection.
-
- self assert: (self collection contains: [ :each | each = self collection values first ]).
- self deny: (self collection contains: [ :each | each = Object new ])
- !
- testFrom
- "Accept a collection of associations."
- | associations |
- associations := { 'a' -> 1. 'b' -> 2 }.
- self assertSameContents: ( self class collectionClass from: associations ) as: #{ 'a' -> 1. 'b' -> 2 }.
- !
- testIndexOf
- self assert: (self collection indexOf: 2) equals: 'a'.
- self should: [ self collection indexOf: 999 ] raise: Error.
- self assert: (self collection indexOf: 999 ifAbsent: [ 'sentinel' ]) equals: 'sentinel'
- !
- testNewFromPairs
- "Accept an array in which all odd indexes are keys and evens are values."
- | flattenedAssociations |
- flattenedAssociations := { 'a'. 1. 'b'. 2 }.
- self assertSameContents: ( self class collectionClass newFromPairs: flattenedAssociations ) as: #{ 'a' -> 1. 'b' -> 2 }.
- ! !
- !HashedCollectionTest class methodsFor: 'accessing'!
- collectionClass
- ^ HashedCollection
- ! !
- HashedCollectionTest subclass: #DictionaryTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !DictionaryTest methodsFor: 'accessing'!
- collection
- ^ Dictionary new
- at: 1 put: 1;
- at: 'a' put: 2;
- at: true put: 3;
- at: 4 put: -4;
- yourself
- !
- collectionWithDuplicates
- ^ Dictionary new
- at: 1 put: 1;
- at: 'a' put: 2;
- at: true put: 3;
- at: 4 put: -4;
- at: 'b' put: 1;
- at: 3 put: 3;
- at: false put: 12;
- yourself
- ! !
- !DictionaryTest methodsFor: 'tests'!
- testAccessing
- | d |
- d := Dictionary new.
- d at: 'hello' put: 'world'.
- self assert: (d at: 'hello') equals: 'world'.
- self assert: (d at: 'hello' ifAbsent: [nil]) equals: 'world'.
- self deny: (d at: 'foo' ifAbsent: [nil]) = 'world'.
- self assert: (d includesKey: 'hello').
- self deny: (d includesKey: 'foo').
- d at: 1 put: 2.
- self assert: (d at: 1) equals: 2.
- d at: 1@3 put: 3.
- self assert: (d at: 1@3) equals: 3.
- self assert: (d includesKey: 1@3).
- self deny: (d includesKey: 3@1)
- !
- testAsHashedCollection
- self assert: ( self collectionClass new asHashedCollection isMemberOf: HashedCollection ).
- !
- testDynamicDictionaries
- self assert: #{'hello' -> 1} asDictionary equals: (Dictionary with: 'hello' -> 1)
- !
- testEquality
- | d1 d2 |
- self assert: (Dictionary new = Dictionary new).
-
- d1 := Dictionary new at: 1 put: 2; yourself.
- d2 := Dictionary new at: 1 put: 2; yourself.
- self assert: (d1 = d2).
- d2 := Dictionary new at: 1 put: 3; yourself.
- self deny: d1 = d2.
- d2 := Dictionary new at: 2 put: 2; yourself.
- self deny: d1 = d2.
- d2 := Dictionary new at: 1 put: 2; at: 3 put: 4; yourself.
- self deny: d1 = d2.
- !
- testIfAbsent
- | d visited |
- visited := false.
- d := Dictionary new.
- d at: 'hello' ifAbsent: [ visited := true ].
- self assert: visited.
- !
- testIfPresent
- | d visited absent |
- visited := false.
- d := Dictionary new.
- d at: 'hello' put: 'world'.
- d at: 'hello' ifPresent: [ :value | visited := value ].
- self assert: visited equals: 'world'.
- absent := d at: 'bye' ifPresent: [ :value | visited := value ].
- self assert: absent isNil.
- !
- testIfPresentIfAbsent
- | d visited |
- visited := false.
- d := Dictionary new.
- d at: 'hello' put: 'world'.
- d at: 'hello' ifPresent: [ :value | visited := value ] ifAbsent: [ visited := true ].
- self assert: visited equals: 'world'.
- d at: 'buy' ifPresent: [ :value | visited := value ] ifAbsent: [ visited := true ].
- self assert: visited.
- !
- testKeys
- | d |
- d := Dictionary new.
- d at: 1 put: 2.
- d at: 2 put: 3.
- d at: 3 put: 4.
- self assert: d keys equals: #(1 2 3)
- !
- testPointKey
- | d |
- d := Dictionary new.
-
- d at: 1@1 put: 'foo'.
- self assert: (d at: 1@1) equals: 'foo'.
- d at: 1@1 put: 'bar'.
- self assert: (d at: 1@1) equals: 'bar'.
- d removeKey: 1@1.
- self assert: (d at: 1@1 ifAbsent: [ 'baz' ]) equals: 'baz'.
- self deny: (d includesKey: 1@1)
- !
- testPrintString
- self
- assert: (Dictionary new
- at:'firstname' put: 'James';
- at:'lastname' put: 'Bond';
- printString)
- equals: 'a Dictionary (''firstname'' -> ''James'' , ''lastname'' -> ''Bond'')'
- !
- testRemoveKey
- | d key |
- d := Dictionary new.
- d at: 1 put: 2.
- d at: 2 put: 3.
- d at: 3 put: 4.
- key := 2.
- self assert: d keys equals: #(1 2 3).
- d removeKey: key.
- self assert: d keys equals: #(1 3).
- self assert: d values equals: #(2 4).
- self deny: (d includesKey: 2)
- !
- testRemoveKeyIfAbsent
- | d key |
- d := Dictionary new.
- d at: 1 put: 2.
- d at: 2 put: 3.
- d at: 3 put: 4.
- key := 2.
- self assert: (d removeKey: key) equals: 3.
- key := 3.
- self assert: (d removeKey: key ifAbsent: [42]) equals: 4.
- key := 'why'.
- self assert: (d removeKey: key ifAbsent: [42] ) equals: 42.
- !
- testSize
- | d |
- d := Dictionary new.
- self assert: d size equals: 0.
- d at: 1 put: 2.
- self assert: d size equals: 1.
- d at: 2 put: 3.
- self assert: d size equals: 2.
- !
- testValues
- | d |
- d := Dictionary new.
- d at: 1 put: 2.
- d at: 2 put: 3.
- d at: 3 put: 4.
- self assert: d values equals: #(2 3 4)
- ! !
- !DictionaryTest class methodsFor: 'accessing'!
- collectionClass
- ^ Dictionary
- ! !
- IndexableCollectionTest subclass: #SequenceableCollectionTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- SequenceableCollectionTest subclass: #ArrayTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !ArrayTest methodsFor: 'tests'!
- testAtIfAbsent
- | array |
- array := #('hello' 'world').
- self assert: (array at: 1) equals: 'hello'.
- self assert: (array at: 2) equals: 'world'.
- self assert: (array at: 2 ifAbsent: ['not found']) equals: 'world'.
- self assert: (array at: 0 ifAbsent: ['not found']) equals: 'not found'.
- self assert: (array at: -10 ifAbsent: ['not found']) equals: 'not found'.
- self assert: (array at: 3 ifAbsent: ['not found']) equals: 'not found'.
- !
- testFirstN
- self assert: ({1. 2. 3. 4. 5} first: 3) equals: {1. 2. 3}
- !
- testIfEmpty
- self assert: ( '' ifEmpty: ['zork'] ) equals: 'zork'
- !
- testPrintString
- | array |
- array := Array new.
- self assert: array printString equals: 'an Array ()'.
- array add: 1; add: 3.
- self assert: array printString equals: 'an Array (1 3)'.
- array add: 'foo'.
- self assert: array printString equals: 'an Array (1 3 ''foo'')'.
- array remove: 1; remove: 3.
- self assert: array printString equals: 'an Array (''foo'')'.
- array addLast: 3.
- self assert: array printString equals: 'an Array (''foo'' 3)'.
- array addLast: 3.
- self assert: array printString equals: 'an Array (''foo'' 3 3)'.
- !
- testRemoveFromTo
-
- self assert: (#(1 2 3 4) removeFrom: 1 to: 3) equals: #(4).
- self assert: (#(1 2 3 4) removeFrom: 2 to: 3) equals: #(1 4).
- self assert: (#(1 2 3 4) removeFrom: 2 to: 4) equals: #(1)
- !
- testRemoveIndex
-
- self assert: (#(1 2 3 4) removeIndex: 2) equals: #(1 3 4).
- self assert: (#(1 2 3 4) removeIndex: 1) equals: #(2 3 4).
- self assert: (#('hello') removeIndex: 1) equals: #()
- ! !
- !ArrayTest class methodsFor: 'accessing'!
- collectionClass
- ^ Array
- ! !
- SequenceableCollectionTest subclass: #StringTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !StringTest methodsFor: 'accessing'!
- collection
- ^'hello'
- !
- collectionWithDuplicates
- ^ 'abbaerte'
- ! !
- !StringTest methodsFor: 'tests'!
- testAddRemove
- self should: ['hello' add: 'a'] raise: Error.
- self should: ['hello' remove: 'h'] raise: Error
- !
- testAsArray
- self assert: 'hello' asArray equals: #('h' 'e' 'l' 'l' 'o').
- !
- testAt
- self assert: ('hello' at: 1) equals: 'h'.
- self assert: ('hello' at: 5) equals: 'o'.
- self assert: ('hello' at: 6 ifAbsent: [nil]) equals: nil
- !
- testAtPut
- "String instances are read-only"
- self should: ['hello' at: 1 put: 'a'] raise: Error
- !
- testCollect
- | newCollection |
- newCollection := 'hheelllloo'.
- self
- assertSameContents: (self collection collect: [ :each |
- each, each ])
- as: newCollection
- !
- testCopyWithoutAll
- self
- assert: ('*hello* *world*' copyWithoutAll: '*')
- equals: 'hello world'
- !
- testDetect
- self assert: (self collection detect: [ :each | each = 'h' ]) equals: 'h'.
- self
- should: [ self collection detect: [ :each | each = 6 ] ]
- raise: Error
- !
- testEquality
- self assert: 'hello' equals: 'hello'.
- self deny: 'hello' = 'world'.
-
- "Test for issue 459"
- self deny: 'hello' = (#() at: 1 ifAbsent: [ ]).
- self assert: 'hello' equals: 'hello' yourself.
- self assert: 'hello' yourself equals: 'hello'.
- "test JS falsy value"
- self deny: '' = 0
- !
- testIdentity
- self assert: 'hello' == 'hello'.
- self deny: 'hello' == 'world'.
- self assert: 'hello' == 'hello' yourself.
- self assert: 'hello' yourself == 'hello'.
- "test JS falsy value"
- self deny: '' == 0
- !
- testIncludesSubString
- self assert: ('amber' includesSubString: 'ber').
- self deny: ('amber' includesSubString: 'zork').
- !
- testIndexOf
- self assert: (self collection indexOf: 'e') equals: 2.
- self should: [ self collection indexOf: 999 ] raise: Error.
- self assert: (self collection indexOf: 999 ifAbsent: [ 'sentinel' ]) equals: 'sentinel'
- !
- testJoin
- self assert: (',' join: #('hello' 'world')) equals: 'hello,world'
- !
- testSelect
- | newCollection |
- newCollection := 'o'.
- self
- assertSameContents: (self collection select: [ :each |
- each = 'o' ])
- as: newCollection
- !
- testSize
- self assert: 'smalltalk' size equals: 9.
- self assert: '' size equals: 0
- !
- testStreamContents
- self
- assert: (String streamContents: [ :aStream |
- aStream
- nextPutAll: 'hello'; space;
- nextPutAll: 'world' ])
- equals: 'hello world'
- ! !
- !StringTest class methodsFor: 'accessing'!
- collectionClass
- ^ String
- ! !
- TestCase subclass: #ConsoleTranscriptTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !ConsoleTranscriptTest methodsFor: 'tests'!
- testShow
- | originalTranscript |
- originalTranscript := Transcript current.
- Transcript register: ConsoleTranscript new.
- self shouldnt: [ Transcript show: 'Hello console!!' ] raise: Error.
- self shouldnt: [ Transcript show: console ] raise: Error.
- Transcript register: originalTranscript.
- ! !
- TestCase subclass: #JSObjectProxyTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !JSObjectProxyTest methodsFor: 'accessing'!
- jsObject
- <return jsObject = {a: 1, b: function() {return 2;}, c: function(object) {return object;}, d: '', 'e': null, 'f': undefined}>
- ! !
- !JSObjectProxyTest methodsFor: 'tests'!
- testAtIfAbsent
- | testObject |
- testObject := self jsObject.
- self assert: (testObject at: 'abc' ifAbsent: ['Property does not exist']) equals: 'Property does not exist'.
- self assert: (testObject at: 'e' ifAbsent: ['Property does not exist']) equals: nil.
- self assert: (testObject at: 'a' ifAbsent: ['Property does not exist']) equals: 1.
- self assert: (testObject at: 'f' ifAbsent: ['Property does not exist']) equals: nil.
- !
- testAtIfPresent
- | testObject |
-
- testObject := self jsObject.
-
- self assert: (testObject at: 'abc' ifPresent: [ :x | 'hello ',x asString ]) equals: nil.
- self assert: (testObject at: 'e' ifPresent: [:x | 'hello ',x asString ]) equals: 'hello nil'.
- self assert: (testObject at: 'a' ifPresent: [:x | 'hello ',x asString ]) equals: 'hello 1'.
- self assert: (testObject at: 'f' ifPresent: [:x | 'hello ',x asString ]) equals: 'hello nil'.
- !
- testAtIfPresentIfAbsent
- | testObject |
- testObject := self jsObject.
- self assert: (testObject at: 'abc' ifPresent: [:x|'hello ',x asString] ifAbsent: ['not present']) equals: 'not present'.
- self assert: (testObject at: 'e' ifPresent: [:x|'hello ',x asString] ifAbsent: ['not present']) equals: 'hello nil'.
- self assert: (testObject at: 'a' ifPresent: [:x|'hello ',x asString] ifAbsent: ['not present']) equals: 'hello 1'.
- self assert: (testObject at: 'f' ifPresent: [:x|'hello ',x asString] ifAbsent: ['not present']) equals: 'hello nil'.
- !
- testDNU
- self should: [self jsObject foo] raise: MessageNotUnderstood
- !
- testMessageSend
- self assert: self jsObject a equals: 1.
- self assert: self jsObject b equals: 2.
- self assert: (self jsObject c: 3) equals: 3
- !
- testMethodWithArguments
- self assert: (self jsObject c: 1) equals: 1
- !
- testPrinting
- self assert: self jsObject printString equals: '[object Object]'
- !
- testPropertyThatReturnsEmptyString
- | object |
- object := self jsObject.
- self assert: object d equals: ''.
- object d: 'hello'.
- self assert: object d equals: 'hello'
- !
- testPropertyThatReturnsUndefined
- | object |
- object := self jsObject.
- self shouldnt: [ object e ] raise: MessageNotUnderstood.
- self assert: object e isNil
- !
- testValue
- | testObject |
- testObject := self jsObject.
- self assert: testObject value printString equals: '[object Object]'.
- testObject at: 'value' put: 'aValue'.
- self assert: testObject value equals: 'aValue'
- !
- testYourself
- | object |
- object := self jsObject
- d: 'test';
- yourself.
- self assert: object d equals: 'test'
- ! !
- TestCase subclass: #JavaScriptExceptionTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !JavaScriptExceptionTest methodsFor: 'helpers'!
- throwException
- <throw 'test'>
- ! !
- !JavaScriptExceptionTest methodsFor: 'tests'!
- testCatchingException
- [ self throwException ]
- on: Error
- do: [ :error |
- self assert: error exception = 'test' ]
- !
- testRaisingException
- self should: [ self throwException ] raise: JavaScriptException
- ! !
- TestCase subclass: #MessageSendTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !MessageSendTest methodsFor: 'tests'!
- testValue
- | messageSend |
-
- messageSend := MessageSend new
- receiver: Object new;
- selector: #asString;
- yourself.
-
- self assert: messageSend value equals: 'an Object'
- !
- testValueWithArguments
- | messageSend |
-
- messageSend := MessageSend new
- receiver: 2;
- selector: '+';
- yourself.
-
- self assert: (messageSend value: 3) equals: 5.
-
- self assert: (messageSend valueWithPossibleArguments: #(4)) equals: 6
- ! !
- TestCase subclass: #NumberTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !NumberTest methodsFor: 'tests'!
- testAbs
- self assert: 4 abs equals: 4.
- self assert: -4 abs equals: 4
- !
- testArithmetic
-
- "We rely on JS here, so we won't test complex behavior, just check if
- message sends are corrects"
- self assert: 1.5 + 1 equals: 2.5.
- self assert: 2 - 1 equals: 1.
- self assert: -2 - 1 equals: -3.
- self assert: 12 / 2 equals: 6.
- self assert: 3 * 4 equals: 12.
- "Simple parenthesis and execution order"
- self assert: 1 + 2 * 3 equals: 9.
- self assert: 1 + (2 * 3) equals: 7
- !
- testComparison
- self assert: 3 > 2.
- self assert: 2 < 3.
-
- self deny: 3 < 2.
- self deny: 2 > 3.
- self assert: 3 >= 3.
- self assert: 3.1 >= 3.
- self assert: 3 <= 3.
- self assert: 3 <= 3.1
- !
- testCopying
- self assert: 1 copy == 1.
- self assert: 1 deepCopy == 1
- !
- testEquality
- self assert: (1 = 1).
- self assert: (0 = 0).
- self deny: (1 = 0).
- self assert: (1 yourself = 1).
- self assert: (1 = 1 yourself).
- self assert: (1 yourself = 1 yourself).
-
- self deny: 0 = false.
- self deny: false = 0.
- self deny: '' = 0.
- self deny: 0 = ''
- !
- testHexNumbers
- self assert: 16r9 equals: 9.
- self assert: 16rA truncated equals: 10.
- self assert: 16rB truncated equals: 11.
- self assert: 16rC truncated equals: 12.
- self assert: 16rD truncated equals: 13.
- self assert: 16rE truncated equals: 14.
- self assert: 16rF truncated equals: 15
- !
- testIdentity
- self assert: 1 == 1.
- self assert: 0 == 0.
- self deny: 1 == 0.
- self assert: 1 yourself == 1.
- self assert: 1 == 1 yourself.
- self assert: 1 yourself == 1 yourself.
-
- self deny: 1 == 2
- !
- testInvalidHexNumbers
- self should: [16rG] raise: MessageNotUnderstood.
- self should: [16rg] raise: MessageNotUnderstood.
- self should: [16rH] raise: MessageNotUnderstood.
- self should: [16rh] raise: MessageNotUnderstood.
- self should: [16rI] raise: MessageNotUnderstood.
- self should: [16ri] raise: MessageNotUnderstood.
- self should: [16rJ] raise: MessageNotUnderstood.
- self should: [16rj] raise: MessageNotUnderstood.
- self should: [16rK] raise: MessageNotUnderstood.
- self should: [16rk] raise: MessageNotUnderstood.
- self should: [16rL] raise: MessageNotUnderstood.
- self should: [16rl] raise: MessageNotUnderstood.
- self should: [16rM] raise: MessageNotUnderstood.
- self should: [16rm] raise: MessageNotUnderstood.
- self should: [16rN] raise: MessageNotUnderstood.
- self should: [16rn] raise: MessageNotUnderstood.
- self should: [16rO] raise: MessageNotUnderstood.
- self should: [16ro] raise: MessageNotUnderstood.
- self should: [16rP] raise: MessageNotUnderstood.
- self should: [16rp] raise: MessageNotUnderstood.
- self should: [16rQ] raise: MessageNotUnderstood.
- self should: [16rq] raise: MessageNotUnderstood.
- self should: [16rR] raise: MessageNotUnderstood.
- self should: [16rr] raise: MessageNotUnderstood.
- self should: [16rS] raise: MessageNotUnderstood.
- self should: [16rs] raise: MessageNotUnderstood.
- self should: [16rT] raise: MessageNotUnderstood.
- self should: [16rt] raise: MessageNotUnderstood.
- self should: [16rU] raise: MessageNotUnderstood.
- self should: [16ru] raise: MessageNotUnderstood.
- self should: [16rV] raise: MessageNotUnderstood.
- self should: [16rv] raise: MessageNotUnderstood.
- self should: [16rW] raise: MessageNotUnderstood.
- self should: [16rw] raise: MessageNotUnderstood.
- self should: [16rX] raise: MessageNotUnderstood.
- self should: [16rx] raise: MessageNotUnderstood.
- self should: [16rY] raise: MessageNotUnderstood.
- self should: [16ry] raise: MessageNotUnderstood.
- self should: [16rZ] raise: MessageNotUnderstood.
- self should: [16rz] raise: MessageNotUnderstood.
- self should: [16rABcdEfZ] raise: MessageNotUnderstood.
- !
- testMinMax
-
- self assert: (2 max: 5) equals: 5.
- self assert: (2 min: 5) equals: 2
- !
- testNegated
- self assert: 3 negated equals: -3.
- self assert: -3 negated equals: 3
- !
- testPrintShowingDecimalPlaces
- self assert: (23 printShowingDecimalPlaces: 2) equals: '23.00'.
- self assert: (23.5698 printShowingDecimalPlaces: 2) equals: '23.57'.
- self assert: (234.567 negated printShowingDecimalPlaces: 5) equals: '-234.56700'.
- self assert: (23.4567 printShowingDecimalPlaces: 0) equals: '23'.
- self assert: (23.5567 printShowingDecimalPlaces: 0) equals: '24'.
- self assert: (23.4567 negated printShowingDecimalPlaces: 0) equals: '-23'.
- self assert: (23.5567 negated printShowingDecimalPlaces: 0) equals: '-24'.
- self assert: (100000000 printShowingDecimalPlaces: 1) equals: '100000000.0'.
- self assert: (0.98 printShowingDecimalPlaces: 5) equals: '0.98000'.
- self assert: (0.98 negated printShowingDecimalPlaces: 2) equals: '-0.98'.
- self assert: (2.567 printShowingDecimalPlaces: 2) equals: '2.57'.
- self assert: (-2.567 printShowingDecimalPlaces: 2) equals: '-2.57'.
- self assert: (0 printShowingDecimalPlaces: 2) equals: '0.00'.
- !
- testRounded
-
- self assert: 3 rounded equals: 3.
- self assert: 3.212 rounded equals: 3.
- self assert: 3.51 rounded equals: 4
- !
- testSqrt
-
- self assert: 4 sqrt equals: 2.
- self assert: 16 sqrt equals: 4
- !
- testSquared
-
- self assert: 4 squared equals: 16
- !
- testTimesRepeat
- | i |
- i := 0.
- 0 timesRepeat: [i := i + 1].
- self assert: i equals: 0.
- 5 timesRepeat: [i := i + 1].
- self assert: i equals: 5
- !
- testTo
- self assert: (1 to: 5) equals: #(1 2 3 4 5)
- !
- testToBy
- self assert: (0 to: 6 by: 2) equals: #(0 2 4 6).
- self should: [1 to: 4 by: 0] raise: Error
- !
- testTruncated
-
- self assert: 3 truncated equals: 3.
- self assert: 3.212 truncated equals: 3.
- self assert: 3.51 truncated equals: 3
- ! !
- Object subclass: #ObjectMock
- instanceVariableNames: 'foo bar'
- package: 'Kernel-Tests'!
- !ObjectMock commentStamp!
- ObjectMock is there only to perform tests on classes.!
- !ObjectMock methodsFor: 'not yet classified'!
- foo
- ^foo
- !
- foo: anObject
- foo := anObject
- ! !
- ObjectMock subclass: #ObjectMock2
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !ObjectMock2 commentStamp!
- ObjectMock is there only to perform tests on classes.!
- !ObjectMock2 methodsFor: 'not yet classified'!
- foo
- ^foo
- !
- foo: anObject
- foo := anObject
- ! !
- ObjectMock2 subclass: #ObjectMock3
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- ObjectMock3 subclass: #ObjectMock4
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- TestCase subclass: #ObjectTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !ObjectTest methodsFor: 'tests'!
- notDefined
- <return undefined;>
- !
- testBasicAccess
- | o |
- o := Object new.
- o basicAt: 'a' put: 1.
- self assert: (o basicAt: 'a') equals: 1.
- self assert: (o basicAt: 'b') equals: nil
- !
- testBasicPerform
- | o |
- o := Object new.
- o basicAt: 'func' put: ['hello'].
- o basicAt: 'func2' put: [:a | a + 1].
- self assert: (o basicPerform: 'func') equals: 'hello'.
- self assert: (o basicPerform: 'func2' withArguments: #(3)) equals: 4
- !
- testDNU
- self should: [Object new foo] raise: MessageNotUnderstood
- !
- testEquality
- | o |
- o := Object new.
- self deny: o = Object new.
- self assert: (o = o).
- self assert: (o yourself = o).
- self assert: (o = o yourself)
- !
- testHalt
- self should: [Object new halt] raise: Error
- !
- testIdentity
- | o |
- o := Object new.
- self deny: o == Object new.
- self assert: o == o.
- self assert: o yourself == o.
- self assert: o == o yourself
- !
- testIfNil
- self deny: Object new isNil.
- self deny: (Object new ifNil: [true]) = true.
- self assert: (Object new ifNotNil: [true]) equals: true.
- self assert: (Object new ifNil: [false] ifNotNil: [true]) equals: true.
- self assert: (Object new ifNotNil: [true] ifNil: [false]) equals: true
- !
- testInstVars
- | o |
- o := ObjectMock new.
- self assert: (o instVarAt: #foo) equals: nil.
- o instVarAt: #foo put: 1.
- self assert: (o instVarAt: #foo) equals: 1.
- self assert: (o instVarAt: 'foo') equals: 1
- !
- testNilUndefined
- "nil in Smalltalk is the undefined object in JS"
- self assert: self notDefined equals: nil
- !
- testYourself
- | o |
- o := ObjectMock new.
- self assert: o yourself == o
- !
- testidentityHash
- | o1 o2 |
-
- o1 := Object new.
- o2 := Object new.
- self assert: o1 identityHash == o1 identityHash.
- self deny: o1 identityHash == o2 identityHash
- ! !
- TestCase subclass: #PackageTest
- instanceVariableNames: 'zorkPackage grulPackage backUpCommitPathJs backUpCommitPathSt'
- package: 'Kernel-Tests'!
- !PackageTest methodsFor: 'running'!
- setUp
- backUpCommitPathJs := Package defaultCommitPathJs.
- backUpCommitPathSt := Package defaultCommitPathSt.
- Package resetCommitPaths.
- zorkPackage := Package new name: 'Zork'.
- grulPackage := Package new
- name: 'Grul';
- commitPathJs: 'server/grul/js';
- commitPathSt: 'grul/st';
- yourself
- !
- tearDown
- Package
- defaultCommitPathJs: backUpCommitPathJs;
- defaultCommitPathSt: backUpCommitPathSt
- ! !
- !PackageTest methodsFor: 'tests'!
- testGrulCommitPathJsShouldBeServerGrulJs
- self assert: grulPackage commitPathJs equals: 'server/grul/js'
- !
- testGrulCommitPathStShouldBeGrulSt
- self assert: grulPackage commitPathSt equals: 'grul/st'
- !
- testZorkCommitPathJsShouldBeJs
- self assert: zorkPackage commitPathJs equals: 'js'
- !
- testZorkCommitPathStShouldBeSt
- self assert: zorkPackage commitPathSt equals: 'st'
- ! !
- PackageTest subclass: #PackageWithDefaultCommitPathChangedTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !PackageWithDefaultCommitPathChangedTest methodsFor: 'running'!
- setUp
- super setUp.
- Package
- defaultCommitPathJs: 'javascripts/';
- defaultCommitPathSt: 'smalltalk/'.
- ! !
- !PackageWithDefaultCommitPathChangedTest methodsFor: 'tests'!
- testGrulCommitPathJsShouldBeServerGrulJs
- self assert: grulPackage commitPathJs equals: 'server/grul/js'
- !
- testGrulCommitPathStShouldBeGrulSt
- self assert: grulPackage commitPathSt equals: 'grul/st'
- !
- testZorkCommitPathJsShouldBeJavascript
- self assert: zorkPackage commitPathJs equals: 'javascripts/'
- !
- testZorkCommitPathStShouldBeSmalltalk
- self assert: zorkPackage commitPathSt equals: 'smalltalk/'
- ! !
- !PackageWithDefaultCommitPathChangedTest class methodsFor: 'accessing'!
- shouldInheritSelectors
- ^ false
- ! !
- TestCase subclass: #PointTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !PointTest methodsFor: 'tests'!
- testAccessing
- self assert: (Point x: 3 y: 4) x equals: 3.
- self assert: (Point x: 3 y: 4) y equals: 4.
- self assert: (Point new x: 3) x equals: 3.
- self assert: (Point new y: 4) y equals: 4
- !
- testArithmetic
- self assert: 3@4 * (3@4 ) equals: (Point x: 9 y: 16).
- self assert: 3@4 + (3@4 ) equals: (Point x: 6 y: 8).
- self assert: 3@4 - (3@4 ) equals: (Point x: 0 y: 0).
- self assert: 6@8 / (3@4 ) equals: (Point x: 2 y: 2)
- !
- testAt
- self assert: 3@4 equals: (Point x: 3 y: 4)
- !
- testEgality
- self assert: (3@4 = (3@4)).
- self deny: 3@5 = (3@6)
- !
- testTranslateBy
- self assert: (3@3 translateBy: 0@1) equals: 3@4.
- self assert: (3@3 translateBy: 0@1 negated) equals: 3@2.
- self assert: (3@3 translateBy: 2@3) equals: 5@6.
- self assert: (3@3 translateBy: 3 negated @0) equals: 0@3.
- ! !
- TestCase subclass: #RandomTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !RandomTest methodsFor: 'tests'!
- textNext
- 10000 timesRepeat: [
- | current next |
- next := Random new next.
- self assert: (next >= 0).
- self assert: (next < 1).
- self deny: current = next.
- next = current]
- ! !
- TestCase subclass: #SetTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !SetTest methodsFor: 'tests'!
- testAddRemove
- | set |
- set := Set new.
-
- self assert: set isEmpty.
- set add: 3.
- self assert: (set includes: 3).
- set add: 5.
- self assert: (set includes: 5).
- set remove: 3.
- self deny: (set includes: 3)
- !
- testAt
- self should: [Set new at: 1 put: 2] raise: Error
- !
- testCollect
- self assert: (#(5 6 8) asSet collect: [ :x | x \\ 3 ]) equals: #(0 2) asSet
- !
- testComparing
- self assert: #(0 2) asSet equals: #(0 2) asSet.
- self assert: #(2 0) asSet equals: #(0 2) asSet.
- self deny: #(0 2 3) asSet = #(0 2) asSet.
- self deny: #(1 2) asSet = #(0 2) asSet
- !
- testPrintString
- | set |
- set := Set new.
- self assert: set printString equals: 'a Set ()'.
- set add: 1; add: 3.
- self assert: set printString equals: 'a Set (1 3)'.
- set add: 'foo'.
- self assert: set printString equals: 'a Set (1 3 ''foo'')'.
- set remove: 1; remove: 3.
- self assert: set printString equals: 'a Set (''foo'')'.
- set add: 3.
- self assert: set printString equals: 'a Set (''foo'' 3)'.
- set add: 3.
- self assert: set printString equals: 'a Set (''foo'' 3)'
- !
- testSize
- self assert: Set new size equals: 0.
- self assert: (Set withAll: #(1 2 3 4)) size equals: 4.
- self assert: (Set withAll: #(1 1 1 1)) size equals: 1
- !
- testUnboxedObjects
- self assert: {'foo' yourself. 'foo' yourself} asSet asArray equals: #('foo')
- !
- testUnicity
- | set |
- set := Set new.
- set add: 21.
- set add: 'hello'.
- set add: 21.
- self assert: set size equals: 2.
-
- set add: 'hello'.
- self assert: set size equals: 2.
- self assert: set asArray equals: #(21 'hello')
- ! !
- TestCase subclass: #StreamTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !StreamTest methodsFor: 'accessing'!
- collectionClass
- ^ self class collectionClass
- !
- newCollection
- ^ self collectionClass new
- !
- newStream
- ^ self collectionClass new stream
- ! !
- !StreamTest methodsFor: 'tests'!
- testAtStartAtEnd
- | stream |
-
- stream := self newStream.
- self assert: stream atStart.
- self assert: stream atEnd.
-
- stream nextPutAll: self newCollection.
- self assert: stream atEnd.
- self deny: stream atStart.
-
- stream position: 1.
- self deny: stream atEnd.
- self deny: stream atStart
- !
- testContents
- | stream |
-
- stream := self newStream.
- stream nextPutAll: self newCollection.
-
- self assert: stream contents equals: self newCollection
- !
- testIsEmpty
- | stream |
-
- stream := self newStream.
- self assert: stream isEmpty.
-
- stream nextPutAll: self newCollection.
- self deny: stream isEmpty
- !
- testPosition
- | collection stream |
-
- collection := self newCollection.
- stream := self newStream.
-
- stream nextPutAll: collection.
- self assert: stream position equals: collection size.
-
- stream position: 0.
- self assert: stream position equals: 0.
-
- stream next.
- self assert: stream position equals: 1.
-
- stream next.
- self assert: stream position equals: 2
- !
- testReading
- | stream collection |
-
- collection := self newCollection.
- stream := self newStream.
-
- stream
- nextPutAll: collection;
- position: 0.
-
- collection do: [ :each |
- self assert: stream next equals: each ].
-
- self assert: stream next isNil
- !
- testStreamContents
- !
- testWrite
- | stream collection |
-
- collection := self newCollection.
- stream := self newStream.
-
- collection do: [ :each | stream << each ].
- self assert: stream contents equals: collection
- !
- testWriting
- | stream collection |
-
- collection := self newCollection.
- stream := self newStream.
-
- collection do: [ :each | stream nextPut: each ].
- self assert: stream contents equals: collection.
-
- stream := self newStream.
- stream nextPutAll: collection.
- self assert: stream contents equals: collection
- ! !
- !StreamTest class methodsFor: 'accessing'!
- collectionClass
- ^ nil
- ! !
- !StreamTest class methodsFor: 'testing'!
- isAbstract
- ^ self collectionClass isNil
- ! !
- StreamTest subclass: #ArrayStreamTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !ArrayStreamTest methodsFor: 'accessing'!
- newCollection
- ^ { true. 1. 3@4. 'foo' }
- ! !
- !ArrayStreamTest class methodsFor: 'accessing'!
- collectionClass
- ^ Array
- ! !
- StreamTest subclass: #StringStreamTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !StringStreamTest methodsFor: 'accessing'!
- newCollection
- ^ 'hello world'
- ! !
- !StringStreamTest class methodsFor: 'accessing'!
- collectionClass
- ^ String
- ! !
- TestCase subclass: #UndefinedTest
- instanceVariableNames: ''
- package: 'Kernel-Tests'!
- !UndefinedTest methodsFor: 'tests'!
- testCopying
- self assert: nil copy equals: nil
- !
- testDeepCopy
- self assert: nil deepCopy = nil
- !
- testIfNil
- self assert: (nil ifNil: [true]) equals: true.
- self deny: (nil ifNotNil: [true]) = true.
- self assert: (nil ifNil: [true] ifNotNil: [false]) equals: true.
- self deny: (nil ifNotNil: [true] ifNil: [false]) = true
- !
- testIsNil
- self assert: nil isNil.
- self deny: nil notNil.
- ! !
|