compiler/tests/PPCCompilerTest.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Tue, 12 May 2015 01:24:03 +0100
changeset 459 4751c407bb40
parent 452 9f4558b3be66
child 515 b5316ef15274
permissions -rw-r--r--
Merged with PetitCompiler-JanKurs.20150510144201, PetitCompiler-Tests-JanKurs.20150510144201, PetitCompiler-Extras-Tests-JanKurs.20150510144201, PetitCompiler-Benchmarks-JanKurs.20150510144201 Name: PetitCompiler-JanKurs.20150510144201 Author: JanKurs Time: 10-05-2015, 04:42:29.192 PM UUID: 58a4786b-1182-4904-8b44-a13d3918f244 Name: PetitCompiler-Tests-JanKurs.20150510144201 Author: JanKurs Time: 10-05-2015, 04:32:12.870 PM UUID: 2a8fd41a-331b-4dcf-a7a3-752a50ce86e7 Name: PetitCompiler-Extras-Tests-JanKurs.20150510144201 Author: JanKurs Time: 10-05-2015, 04:59:25.308 PM UUID: ef43bd1a-be60-4e88-b749-8b635622c969 Name: PetitCompiler-Benchmarks-JanKurs.20150510144201 Author: JanKurs Time: 10-05-2015, 05:04:54.561 PM UUID: d8e764fd-016b-46e2-9fc1-17c38c18f0e5

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

"{ NameSpace: Smalltalk }"

PPAbstractParserTest subclass:#PPCCompilerTest
	instanceVariableNames:'parser result context node compiler id node2 id2 id1 node1 node3
		arguments configuration'
	classVariableNames:''
	poolDictionaries:''
	category:'PetitCompiler-Tests-Core'
!


!PPCCompilerTest methodsFor:'as yet unclassified'!

assert: p parse: whatever
    ^ result := super assert: p parse: whatever.
!

context	
    ^ context := PPCProfilingContext new
!

setUp
    arguments := PPCArguments default
        profile: true;
        yourself.
        
    configuration := PPCUniversalConfiguration new
        arguments: arguments;
        yourself.
!

tearDown
    | parserClass |

    parserClass := (Smalltalk at: #PPGeneratedParser ifAbsent: [nil]).
    parserClass notNil ifTrue:[ 
        parserClass removeFromSystem
    ].
! !

!PPCCompilerTest methodsFor:'tests - guard'!

testChoiceGuard
    parser := ('foo' asParser trimmingToken / 'bar' asParser trimmingToken / $d asParser trimmingToken plus) 
        compileWithConfiguration: configuration.
    
    self assert: parser parse: 'foo'.
    self assert: result inputValue = 'foo'.	
    self assert: (context invocations anySatisfy: [ :e | e beginsWith: 'token' ]).

    self assert: parser parse: 'bar'.
    self assert: result inputValue = 'bar'.	

    self assert: parser parse: ' foo'.
    self assert: result inputValue = 'foo'.	

    self assert: parser parse: '  d'.
    self assert: result first inputValue = 'd'.	

    self assert: parser fail: ''.
    self assert: (context invocations noneSatisfy: [ :e | e beginsWith: 'predicate' ]).
    self assert: (context invocations noneSatisfy: [ :e | e beginsWith: 'token' ]).

    self assert: parser fail: 'zorg'.		
    self assert: (context invocations noneSatisfy: [ :e | e beginsWith: 'token' ]).
!

testEmptyChoiceGuard
    parser := ('foo' asParser trimmingToken / 'bar' asParser trimmingToken / $d asParser trimmingToken star) 
        compileWithConfiguration: configuration.
    
    self assert: parser parse: 'foo'.
    self assert: result inputValue = 'foo'.	

    self assert: parser parse: 'bar'.
    self assert: result inputValue = 'bar'.	

    self assert: parser parse: ' foo'.
    self assert: result inputValue = 'foo'.	

    self assert: parser parse: '  d'.
    self assert: result first inputValue = 'd'.	

    self assert: parser parse: ''.

    self assert: parser parse: 'zorg' end: 0.	
!

testGuardSmalltlakToken
    parser := (#letter asParser, #word asParser star) smalltalkToken compileWithConfiguration: configuration.
    
    self assert: parser parse: 'bar'.
    self assert: (context invocations anySatisfy: [ :e | e beginsWith: 'seq' ]).
    
    self assert: parser fail: '123'.
    self assert: (context invocations noneSatisfy: [ :e | e beginsWith: 'seq' ]).
!

testSequenceGuard
    parser := ((#any asParser, #any asParser) wrapped, (#any asParser, #any asParser)) compileWithConfiguration: configuration.
    
    self assert: parser parse: 'fooo' to: #(#($f $o) #($o $o)).	
    self assert: parser parse: 'fo oo' to: #(#($f $o) #($  $o)) end: 4.	
    self assert: parser fail: 'fo'.
    
!

testTrimmerGuard
    parser := $a asParser trim, $b asParser compileWithConfiguration: configuration.
    
    self assert: parser parse: 'ab'.
    self assert: parser parse: ' ab'.
! !

!PPCCompilerTest methodsFor:'tests - ids'!

testId1
    node := PPCNode new
        name: 'foo'.
    compiler := PPCCompiler new.
    
    id := compiler idFor: node.
    
    self assert: compiler ids size = 1.
    self assert: id = 'foo'.
!

testId2
    node1 := PPCNode new
        name: 'foo'.
    
    node2 := PPCNode new
        name: 'foo'.
    compiler := PPCCompiler new.

    id1 := compiler idFor: node1.
    self assert: compiler ids size = 1.
    self assert: id1 = 'foo'.
    
    id2 := compiler idFor: node2.
    self assert: compiler ids size = 2.
    self assert: id2 = 'foo_1'.	
            
    self assert: (id1 = id2) not.
!

testId3
    node1 := PPCNode new
        name: 'foo'.
    
    node2 := node1.
    compiler := PPCCompiler new.
        
    id1 := compiler idFor: node1.
    self assert: compiler ids size = 1.
    self assert: id1 = 'foo'.
    
    id2 := compiler idFor: node2.
    self assert: compiler ids size = 1.
    self assert: id2 = 'foo'.	
            
    self assert: (id1 == id2).
!

testId4
    node1 := PPCNode new
        name: 'foo+='.
    
    node2 := PPCNode new
        name: 'foo+='.
    compiler := PPCCompiler new.
        
    id1 := compiler idFor: node1.
    self assert: compiler ids size = 1.
    self assert: id1 = 'foo'.
    
    id2 := compiler idFor: node2.
    self assert: compiler ids size = 2.
    self assert: id2 = 'foo_1'.	
            
    self assert: (id1 = id2) not.
!

testId5
    node1 := PPCNode new
        name: 'foo_bar'.
    
    compiler := PPCCompiler new.
        
    id1 := compiler idFor: node1.
    self assert: compiler ids size = 1.
    self assert: id1 = 'foo_bar'.
! !

!PPCCompilerTest class methodsFor:'documentation'!

version_HG

    ^ '$Changeset: <not expanded> $'
! !