Class { #name : 'PPPredicateTest', #superclass : 'PPAbstractParserTest', #category : 'PetitTests-Tests' } { #category : 'utilities' } PPPredicateTest >> assertCharacterSets: aParser [ "Assert the character set of aParser does not overlap with the character set with the negated parser, and that they both cover the complete character space." | positives negatives | positives := self parsedCharacterSet: aParser. negatives := self parsedCharacterSet: aParser negate. self charactersDo: [ :char | | positive negative | positive := positives includes: char. negative := negatives includes: char. self assert: ((positive and: [ negative not ]) or: [ positive not and: [ negative ] ]) description: char printString , ' should be in exactly one set' ] ] { #category : 'private' } PPPredicateTest >> charactersDo: aBlock [ 1 to: 256 do: [ :index | aBlock value: (Character codePoint: index) ] ] { #category : 'utilities' } PPPredicateTest >> parsedCharacterSet: aParser [ | result | result := WriteStream on: String new. self charactersDo: [ :char | (aParser matches: (char asString)) ifTrue: [ result nextPut: char ] ]. ^ result contents ] { #category : 'testing-objects' } PPPredicateTest >> testAny [ | parser | parser := #any asParser. self assertCharacterSets: parser. self assert: parser parse: ' ' to: $ . self assert: parser parse: '1' to: $1. self assert: parser parse: 'a' to: $a. self assert: parser fail: '' ] { #category : 'testing-objects' } PPPredicateTest >> testAnyExceptAnyOf [ | parser | parser := PPPredicateObjectParser anyExceptAnyOf: #($: $,). self assertCharacterSets: parser. self assert: parser parse: 'a' to: $a. self assert: parser parse: 'z' to: $z. self assert: parser fail: ':'. self assert: parser fail: ',' ] { #category : 'testing-objects' } PPPredicateTest >> testAnyOf [ | parser | parser := PPPredicateObjectParser anyOf: #($a $z). self assertCharacterSets: parser. self assert: parser parse: 'a' to: $a. self assert: parser parse: 'z' to: $z. self assert: parser fail: 'x' ] { #category : 'testing-objects' } PPPredicateTest >> testBetweenAnd [ | parser | parser := PPPredicateObjectParser between: $b and: $d. self assertCharacterSets: parser. self assert: parser fail: 'a'. self assert: parser parse: 'b' to: $b. self assert: parser parse: 'c' to: $c. self assert: parser parse: 'd' to: $d. self assert: parser fail: 'e' ] { #category : 'testing-chars' } PPPredicateTest >> testBlank [ | parser | parser := #blank asParser. self assertCharacterSets: parser. self assert: parser parse: (String with: Character space) to: Character space. self assert: parser parse: (String with: Character tab) to: Character tab. self assert: parser fail: ''. self assert: parser fail: '1'. self assert: parser fail: (String with: Character cr) ] { #category : 'testing-chars' } PPPredicateTest >> testChar [ | parser | parser := $* asParser. self assertCharacterSets: parser. self assert: parser parse: '*' to: $*. self assert: parser parse: '**' to: $* end: 1. self assert: parser fail: ''. self assert: parser fail: '1'. self assert: parser fail: 'a' ] { #category : 'testing-chars' } PPPredicateTest >> testCr [ | parser | parser := #cr asParser. self assertCharacterSets: parser. self assert: parser parse: (String with: (Character codePoint: 13)) to: (Character codePoint: 13) ] { #category : 'testing-chars' } PPPredicateTest >> testDigit [ | parser | parser := #digit asParser. self assertCharacterSets: parser. self assert: parser parse: '0' to: $0. self assert: parser parse: '9' to: $9. self assert: parser fail: ''. self assert: parser fail: 'a' ] { #category : 'testing-chars' } PPPredicateTest >> testEndOfFile [ | parser | parser := (#letter asParser / #blank asParser) star, #eof asParser. self assert: parser parse: 'lorem ipsum'. parser := #any asParser, #eof asParser, #any asParser star. self assert: parser fail: 'a', Character cr asString, 'b'. self assert: parser fail: Character cr asString , Character lf asString. self assert: parser parse: 'a'. ] { #category : 'testing-chars' } PPPredicateTest >> testEndOfLine [ | cr crlf lf parser | cr := Character cr asString. crlf := Character cr asString , Character lf asString. lf := Character lf asString. parser := (#letter asParser / #blank asParser) star, #endOfLine asParser. self assert: parser parse: 'lorem ipsum'. parser := #any asParser, #endOfLine asParser, #any asParser star. self assert: parser parse: 'a', cr, 'b'. self assert: parser fail: crlf. self assert: parser fail: 'lorem ipsum'. parser := #endOfLine asParser, #any asParser, #endOfLine asParser negate star, #endOfLine asParser. self assert: parser parse: cr, 'lorem ipsum'. self assert: parser parse: lf, 'lorem ipsum'. self assert: parser parse: crlf, 'lorem ipsum'. self assert: parser parse: crlf. self assert: parser parse: cr. self assert: parser parse: lf. parser := #endOfLine asParser negate star, #endOfLine asParser, #any asParser star. self assert: parser parse: crlf, 'lorem ipsum'. self assert: parser parse: crlf. ] { #category : 'testing-objects' } PPPredicateTest >> testExpect [ | parser | parser := PPPredicateObjectParser expect: $a. self assertCharacterSets: parser. self assert: parser parse: 'a' to: $a. self assert: parser fail: 'b'. self assert: parser fail: '' ] { #category : 'testing-chars' } PPPredicateTest >> testHex [ | parser | parser := #hex asParser. self assertCharacterSets: parser. self assert: parser parse: '0' to: $0. self assert: parser parse: '5' to: $5. self assert: parser parse: '9' to: $9. self assert: parser parse: 'A' to: $A. self assert: parser parse: 'D' to: $D. self assert: parser parse: 'F' to: $F. self assert: parser parse: 'a' to: $a. self assert: parser parse: 'e' to: $e. self assert: parser parse: 'f' to: $f. self assert: parser fail: ''. self assert: parser fail: 'g' ] { #category : 'testing-chars' } PPPredicateTest >> testLetter [ | parser | parser := #letter asParser. self assertCharacterSets: parser. self assert: parser parse: 'a' to: $a. self assert: parser parse: 'Z' to: $Z. self assert: parser fail: ''. self assert: parser fail: '0' ] { #category : 'testing-chars' } PPPredicateTest >> testLf [ | parser | parser := #lf asParser. self assertCharacterSets: parser. self assert: parser parse: (String with: Character lf) to: Character lf ] { #category : 'testing-chars' } PPPredicateTest >> testLowercase [ | parser | parser := #lowercase asParser. self assertCharacterSets: parser. self assert: parser parse: 'a' to: $a. self assert: parser parse: 'z' to: $z. self assert: parser fail: ''. self assert: parser fail: 'A'. self assert: parser fail: '0' ] { #category : 'testing-chars' } PPPredicateTest >> testNewline [ | parser | parser := #newline asParser. self assertCharacterSets: parser. self assert: parser parse: (String with: Character cr) to: Character cr. self assert: parser parse: (String with: Character lf) to: Character lf. self assert: parser fail: ' ' ] { #category : 'testing' } PPPredicateTest >> testOnMessage [ | block parser | block := [ :char | char = $* ]. parser := PPPredicateObjectParser on: block message: 'starlet'. self assert: parser block equals: block. self assert: parser message equals: 'starlet'. self assertCharacterSets: parser. self assert: parser parse: '*' to: $*. self assert: parser parse: '**' to: $* end: 1. self assert: parser fail: ''. self assert: parser fail: '1'. self assert: parser fail: 'a' ] { #category : 'testing-chars' } PPPredicateTest >> testPunctuation [ | parser | parser := #punctuation asParser. self assertCharacterSets: parser. self assert: parser parse: '.' to: $.. self assert: parser parse: ',' to: $,. self assert: parser fail: ''. self assert: parser fail: 'a'. self assert: parser fail: '1' ] { #category : 'testing-sequence' } PPPredicateTest >> testSequenceParser [ | parser | parser := PPPredicateSequenceParser on: [ :value | value first isUppercase ] message: 'uppercase 3 letter words' size: 3. self assert: parser size equals: 3. self assert: parser parse: 'Abc'. self assert: parser parse: 'ABc'. self assert: parser parse: 'ABC'. self assert: parser fail: 'abc'. self assert: parser fail: 'aBC'. self assert: parser fail: 'Ab'. parser := parser negate. self assert: parser size equals: 3. self assert: parser fail: 'Abc'. self assert: parser fail: 'ABc'. self assert: parser fail: 'ABC'. self assert: parser parse: 'abc'. self assert: parser parse: 'aBC'. self assert: parser fail: 'Ab' ] { #category : 'testing-chars' } PPPredicateTest >> testSpace [ | parser | parser := #space asParser. self assertCharacterSets: parser. self assert: parser parse: (String with: Character tab) to: Character tab. self assert: parser parse: ' ' to: Character space. self assert: parser fail: ''. self assert: parser fail: 'a' ] { #category : 'testing-chars' } PPPredicateTest >> testStartOfLine [ | cr crlf lf parser | cr := Character cr asString. crlf := Character cr asString , Character lf asString. lf := Character lf asString. parser := #startOfLine asParser, #any asParser star. self assert: parser parse: 'lorem ipsum'. parser := #any asParser, #startOfLine asParser, #any asParser star. self assert: parser fail: 'lorem ipsum'. parser := #startOfLine asParser, #any asParser, #startOfLine asParser, #any asParser star. self assert: parser parse: cr, 'lorem ipsum'. self assert: parser parse: lf, 'lorem ipsum'. self assert: parser fail: crlf, 'lorem ipsum'. self assert: parser fail: crlf. self assert: parser parse: cr. self assert: parser parse: lf. parser := #startOfLine asParser, #any asParser, #any asParser, #startOfLine asParser, #any asParser star. self assert: parser parse: crlf, 'lorem ipsum'. self assert: parser parse: crlf. ] { #category : 'testing-chars' } PPPredicateTest >> testStartOfLogicalLine [ | parser | parser := #startOfLogicalLine asParser, #any asParser star. self assert: parser parse: 'lorem'. self assert: parser fail: ' lorem'. parser := #any asParser, #startOfLogicalLine asParser, #any asParser star. self assert: parser fail: 'lorem'. self assert: parser fail: ' lorem'. self assert: parser parse: ' lorem'. self assert: parser parse: ' lorem'. ] { #category : 'testing-chars' } PPPredicateTest >> testStartOfWord [ | parser | parser := #startOfWord asParser, #word asParser plus. self assert: parser parse: 'lorem'. parser := #any asParser, #startOfWord asParser, #word asParser plus. self assert: parser fail: 'lorem'. self assert: parser fail: '1234'. self assert: parser parse: ' lorem'. self assert: parser parse: ' 123'. self assert: parser parse: ')lorem'. self assert: parser parse: ':lorem'. parser := #startOfWord asParser, #any asParser optional. self assert: parser fail: ''. self assert: parser parse: 'a'. self assert: parser fail: '.'. ] { #category : 'testing-chars' } PPPredicateTest >> testTab [ | parser | parser := #tab asParser. self assertCharacterSets: parser. self assert: parser parse: (String with: Character tab) to: Character tab ] { #category : 'testing-chars' } PPPredicateTest >> testUppercase [ | parser | parser := #uppercase asParser. self assertCharacterSets: parser. self assert: parser parse: 'A' to: $A. self assert: parser parse: 'Z' to: $Z. self assert: parser fail: ''. self assert: parser fail: 'a'. self assert: parser fail: '0' ] { #category : 'testing-chars' } PPPredicateTest >> testWord [ | parser | parser := #word asParser. self assertCharacterSets: parser. self assert: parser parse: 'a' to: $a. self assert: parser parse: 'A' to: $A. self assert: parser parse: '0' to: $0. self assert: parser fail: ''. self assert: parser fail: '-' ]