LimitCharacters()} */ function testLimitCharacters() { $cases = array( 'The little brown fox jumped over the lazy cow.' => 'The little brown fox...', '
This is some text in a paragraph.
' => 'This is some text...' ); foreach($cases as $originalValue => $expectedValue) { $textObj = new Text('Test'); $textObj->setValue($originalValue); $this->assertEquals($expectedValue, $textObj->LimitCharacters()); } } /** * Test {@link Text->LimitWordCount()} */ function testLimitWordCount() { $cases = array( /* Standard words limited, ellipsis added if truncated */ 'The little brown fox jumped over the lazy cow.' => 'The little brown...', ' This text has white space around the ends ' => 'This text has...', /* Words less than the limt word count don't get truncated, ellipsis not added */ 'Two words' => 'Two words', // Two words shouldn't have an ellipsis 'One' => 'One', // Neither should one word '' => '', // No words produces nothing! /* HTML tags get stripped out, leaving the raw text */ '
Text inside a paragraph tag should also work
' => 'Text inside a...', 'Text nested inside another tag should also work
' => 'Text nested inside...', 'Two words
' => 'Two words' ); foreach($cases as $originalValue => $expectedValue) { $textObj = new Text('Test'); $textObj->setValue($originalValue); $this->assertEquals($expectedValue, $textObj->LimitWordCount(3)); } } /** * Test {@link Text->LimitWordCountXML()} */ function testLimitWordCountXML() { $cases = array( 'Stuff & stuff
' => 'Stuff &...', "Stuff\nBlah Blah Blah" => "Stuff\nBlah Blah...", "StuffFirst sentence.
' => 'First sentence.', 'First sentence. Second sentence. Third sentence
' => 'First sentence. Second sentence.', 'First sentence. Second sentence. Third sentence
' => 'First sentence. Second sentence.', 'First sentence. Second sentence. Third sentence
' => 'First sentence. Second sentence.' ); foreach($cases as $originalValue => $expectedValue) { $textObj = new Text('Test'); $textObj->setValue($originalValue); $this->assertEquals($expectedValue, $textObj->LimitSentences(2)); } } /** * Test {@link Text->BigSummary()} */ function testBigSummary() { $cases = array( 'This text has multiple sentences. Big Summary uses this to split sentences up.' => 'This text has multiple...', 'This text does not have multiple sentences' => 'This text does not...', 'Very short' => 'Very short', '' => '' ); foreach($cases as $originalValue => $expectedValue) { $textObj = DBField::create('Text', $originalValue); $this->assertEquals($expectedValue, $textObj->BigSummary(4)); } } function testContextSummary() { $testString1 = 'This is some text. It is a test
'; $testKeywords1 = 'test'; $testString2 = 'This is some test text. Test test what if you have multiple keywords.
'; $testKeywords2 = 'some test'; $testString3 = 'A dog ate a cat while looking at a Foobar
'; $testKeyword3 = 'a'; $testKeyword3a = 'ate'; $textObj = DBField::create('Text', $testString1, 'Text'); $this->assertEquals( '... text. It is a test...', $textObj->ContextSummary(20, $testKeywords1) ); $textObj->setValue($testString2); $this->assertEquals( 'This is some test text. test test what if you have...', $textObj->ContextSummary(50, $testKeywords2) ); $textObj->setValue($testString3); // test that it does not highlight too much (eg every a) $this->assertEquals( 'A dog ate a cat while looking at a Foobar', $textObj->ContextSummary(100, $testKeyword3) ); // it should highlight 3 letters or more. $this->assertEquals( 'A dog ate a cat while looking at a Foobar', $textObj->ContextSummary(100, $testKeyword3a) ); } public function testRAW() { $data = DBField::create('Text', 'This & This'); $this->assertEquals($data->RAW(), 'This & This'); } public function testXML() { $data = DBField::create('Text', 'This & This'); $this->assertEquals($data->XML(), 'This & This'); } public function testHTML() { $data = DBField::create('Text', 'This & This'); $this->assertEquals($data->HTML(), 'This & This'); } public function testJS() { $data = DBField::create('Text', '"this is a test"'); $this->assertEquals($data->JS(), '\"this is a test\"'); } public function testATT() { $data = DBField::create('Text', '"this is a test"'); $this->assertEquals($data->ATT(), '"this is a test"'); } }