RegressionTests__SortTests.st
author Stefan Vogel <sv@exept.de>
Tue, 11 Jun 2019 10:34:41 +0200
changeset 2321 32ea6329f5ad
parent 1447 2351db93aa5b
child 1500 d406a10b2965
permissions -rw-r--r--
class: stx_goodies_regression class changed: #classNamesAndAttributes make classes autoloaded that stc cannot compile (yet)

"{ Package: 'stx:goodies/regression' }"

"{ NameSpace: RegressionTests }"

TestCase subclass:#SortTests
	instanceVariableNames:''
	classVariableNames:''
	poolDictionaries:''
	category:'tests-Regression-Collections'
!

!SortTests class methodsFor:'documentation'!

documentation
"
    documentation to be added.

    [author:]
	mb (mb@sixtyfour)

    [instance variables:]

    [class variables:]

    [see also:]

"
! !

!SortTests methodsFor:'helpers'!

checkSort:data
     |mergeSorted quickSorted definitivelySorted|

     definitivelySorted := self goodSort:(data copy).

     mergeSorted := data copy mergeSort.
     self assert:(mergeSorted isSorted).
     self assert:(mergeSorted = definitivelySorted).

     quickSorted := data copy quickSort.
     self assert:(quickSorted isSorted).
     self assert:(quickSorted = definitivelySorted).
!

goodSort:data
     |tree|

     tree := BinaryTree withAll:data.
     ^ tree asArray
! !

!SortTests methodsFor:'tests'!

test01_smallArrays
     self checkSort: #(1 16 7 98 3 19 4 0).
     self checkSort: #(1 16 7 98 9 3 19 4 0).

     self checkSort: #(1 16 7 98 7 1 3 19 4 0).
     self checkSort: #(1 16 7 98 7 1 3 19 4 0).
!

test02_largeArrays
     |data|

     data := (1 to:22581) collect:[:i | Random nextInteger] as:Array.

     self checkSort: data.
! !

!SortTests class methodsFor:'documentation'!

version_CVS
    ^ '$Header$'
! !