compiler/tests/PEGFsaDeterminizationTest.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Mon, 17 Aug 2015 12:13:16 +0100
changeset 515 b5316ef15274
parent 502 1e45d3c96ec5
child 519 1563dce3c5b4
permissions -rw-r--r--
Updated to PetitCompiler-JanKurs.160, PetitCompiler-Tests-JanKurs.112, PetitCompiler-Extras-Tests-JanKurs.25, PetitCompiler-Benchmarks-JanKurs.17 Name: PetitCompiler-JanKurs.160 Author: JanKurs Time: 17-08-2015, 09:52:26.291 AM UUID: 3b4bfc98-8098-4951-af83-a59e2585b121 Name: PetitCompiler-Tests-JanKurs.112 Author: JanKurs Time: 16-08-2015, 05:00:32.936 PM UUID: 85613d47-08f3-406f-9823-9cdab451e805 Name: PetitCompiler-Extras-Tests-JanKurs.25 Author: JanKurs Time: 16-08-2015, 05:00:10.328 PM UUID: 09731810-51a1-4151-8d3a-56b636fbd1f7 Name: PetitCompiler-Benchmarks-JanKurs.17 Author: JanKurs Time: 05-08-2015, 05:29:32.407 PM UUID: e544b5f1-bcf8-470b-93a6-d2363e4dfc8a

"{ Package: 'stx:goodies/petitparser/compiler/tests' }"

"{ NameSpace: Smalltalk }"

TestCase subclass:#PEGFsaDeterminizationTest
	instanceVariableNames:'parser1 parser2 fsa generator'
	classVariableNames:''
	poolDictionaries:''
	category:'PetitCompiler-Tests-FSA'
!

!PEGFsaDeterminizationTest methodsFor:'as yet unclassified'!

determinizator
    ^ PEGFsaDeterminizator new
!

fsaFrom: aNode
    ^ (aNode accept: generator)
        determinize;
        yourself
!

merge
    | startState fsa1 fsa2 |
    fsa := PEGFsa new.
    startState := PEGFsaState new.

    fsa addState: startState.	
    fsa startState: startState.

    fsa1 := self fsaFrom: parser1 asCompilerTree.
    fsa1 retval: #token1.
    fsa adopt: fsa1.
    fsa addTransitionFrom: startState to: fsa1 startState.
    

    fsa2 := self fsaFrom: parser2 asCompilerTree.
    fsa2 retval: #token2.
    fsa adopt: fsa2.
    fsa addTransitionFrom: startState to: fsa2 startState.
    
    self determinizator determinize: fsa 
!

setUp
    super setUp.
    generator := PEGFsaGenerator new.
!

testA_A
    parser1 := 'a' asParser.
    parser2 := 'a' asParser.
    
    self merge.
    
    self assert: fsa states size = 2.
    self assert: fsa finalStates size = 1.
    self assert: fsa finalStates anyOne retvals size = 2.
    self assert: (fsa finalStates anyOne retvals includes: #token1).	
    self assert: (fsa finalStates anyOne retvals includes: #token2).		
!

testA_AB
    parser1 := 'a' asParser.
    parser2 := 'ab' asParser.
    
    self merge.
    
    self assert: fsa states size = 3.
    self assert: fsa finalStates size = 2.
    self assert: fsa startState destination retvals size = 1.
    self assert: fsa startState destination retval = #token1.

    self assert: fsa startState destination destination retvals size = 1.
    self assert: fsa startState destination destination retval = #token2.
!

testID_KW
    parser1 := #word asParser plus.
    parser2 := #word asParser plus, $: asParser.
    
    self merge.
    
    self assert: fsa states size = 3.
    self assert: fsa finalStates size = 2.

    self assert: (fsa finalStates anySatisfy: [ :fs | fs retvals includes: #token1 ]).	
    self assert: (fsa finalStates anySatisfy: [ :fs | fs retvals includes: #token2 ]).	
    
!

testTrue_ID
    parser1 := 'true' asParser.
    parser2 := #word asParser plus.
    
    self merge.
    
    self assert: fsa states size = 6.
    self assert: fsa finalStates size = 5.
    "Only 1 state with both #token1 and #token2"
    self assert: ((fsa finalStates select: [:fs | fs retvals size = 2]) size = 1).	
!

testTrue_True
    parser1 := 'true' asParser.
    parser2 := 'true' asParser.
    
    self merge.
    
    self assert: fsa states size = 5.
    self assert: fsa finalStates size = 1.
    self assert: fsa finalStates anyOne retvals size = 2.
    self assert: (fsa finalStates anyOne retvals includes: #token1).	
    self assert: (fsa finalStates anyOne retvals includes: #token2).		
! !