TplBlock/vendor/zetacomponents/document/tests/pcss/style_inference_test.php
2018-03-26 21:57:35 +02:00

467 lines
14 KiB
PHP

<?php
/**
* ezcDocumentPdfStyleInferenceTests
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
* @package Document
* @version //autogen//
* @subpackage Tests
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
*/
/**
* Test suite for class.
*
* @package Document
* @subpackage Tests
*/
class ezcDocumentPcssStyleInferenceTests extends ezcTestCase
{
protected $document;
protected $xpath;
public static function suite()
{
return new PHPUnit_Framework_TestSuite( __CLASS__ );
}
public function setUp()
{
$this->document = new DOMDocument();
$this->document->registerNodeClass( 'DOMElement', 'ezcDocumentLocateableDomElement' );
$this->document->load( dirname( __FILE__ ) . '/../files/docbook/pdf/location_ids.xml' );
$this->xpath = new DOMXPath( $this->document );
$this->xpath->registerNamespace( 'doc', 'http://docbook.org/ns/docbook' );
}
public function testRootNodeWithoutFormats()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
$this->assertEquals(
array(),
$inferencer->inferenceFormattingRules( $element )
);
}
public function testRootNodeFormatting()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'foo' => 'bar',
)
),
) );
$this->assertEquals(
array(
'foo' => new ezcDocumentPcssStyleStringValue( 'bar' ),
),
$inferencer->inferenceFormattingRules( $element )
);
}
public function testRootNodeFormattingPartialOverwrite()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'foo' => 'bar',
'baz' => 'bar',
)
),
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'foo' => 'blubb',
)
),
) );
$this->assertEquals(
array(
'foo' => new ezcDocumentPcssStyleStringValue( 'blubb' ),
'baz' => new ezcDocumentPcssStyleStringValue( 'bar' ),
),
$inferencer->inferenceFormattingRules( $element )
);
}
public function testRootNodeFormattingRuleInheritance()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:section' )->item( 0 );
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'foo' => 'bar',
'baz' => 'bar',
)
),
new ezcDocumentPcssLayoutDirective(
array( 'article', '> section' ),
array(
'foo' => 'blubb',
)
),
) );
$this->assertEquals(
array(
'foo' => new ezcDocumentPcssStyleStringValue( 'blubb' ),
'baz' => new ezcDocumentPcssStyleStringValue( 'bar' ),
),
$inferencer->inferenceFormattingRules( $element )
);
}
public function testIntValueHandler()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'text-columns' => '1',
)
),
) );
$this->assertEquals(
array(
'text-columns' => new ezcDocumentPcssStyleIntValue( 1 ),
),
$inferencer->inferenceFormattingRules( $element )
);
}
public function testMeasureValueHandler()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'font-size' => '10',
)
),
) );
$this->assertEquals(
array(
'font-size' => new ezcDocumentPcssStyleMeasureValue( 10 ),
),
$inferencer->inferenceFormattingRules( $element )
);
}
public function testExceptionPostDecoration()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
try
{
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective(
array( 'article' ),
array(
'font-size' => 'unparseable',
),
'my.css', 23, 42
),
) );
$this->fail( 'Expected ezcDocumentParserException.' );
}
catch ( ezcDocumentParserException $e )
{
$this->assertEquals(
'Parse error: Fatal error: \'Could not parse \'unparseable\' as size value.\' in file \'my.css\' in line 23 at position 42.',
$e->getMessage()
);
}
}
protected function assertCorrectMerge( $property, $styles, $expected )
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$element = $this->xpath->query( '//doc:article' )->item( 0 );
$inferencer->appendStyleDirectives( array(
new ezcDocumentPcssLayoutDirective( array( 'article' ), $styles ),
) );
$rules = $inferencer->inferenceFormattingRules( $element );
$this->assertTrue( isset( $rules[$property] ), "Missing property $property in inferenced rules." );
$this->assertEquals( 1, count( $rules ), "Wrong number of inferenced rules" );
$this->assertEquals( $expected, (string) $rules[$property] );
}
public static function getMarginDefinitions()
{
return array(
array(
array(
'margin' => '10mm',
),
'10.00mm 10.00mm 10.00mm 10.00mm',
),
array(
array(
'margin-top' => '10mm',
),
'10.00mm 0.00mm 0.00mm 0.00mm',
),
array(
array(
'margin' => '10mm',
'margin-top' => '20',
),
'20.00mm 10.00mm 10.00mm 10.00mm',
),
array(
array(
'margin' => '10mm',
'margin-top' => '20',
'margin-right' => '30',
'margin-left' => '40',
'margin-bottom' => '50',
),
'20.00mm 30.00mm 50.00mm 40.00mm',
),
array(
array(
'margin-top' => '20',
'margin-right' => '30',
'margin-left' => '40',
'margin-bottom' => '50',
'margin' => '0in',
),
'0.00mm 0.00mm 0.00mm 0.00mm',
),
);
}
/**
* @dataProvider getMarginDefinitions
*/
public function testMergeMarginValues( $styles, $expected )
{
$this->assertCorrectMerge( 'margin', $styles, $expected );
}
public static function getPaddingDefinitions()
{
return array(
array(
array(
'padding' => '10mm',
'padding-top' => '20',
),
'20.00mm 10.00mm 10.00mm 10.00mm',
),
);
}
/**
* @dataProvider getPaddingDefinitions
*/
public function testMergePaddingValues( $styles, $expected )
{
$this->assertCorrectMerge( 'padding', $styles, $expected );
}
public static function getBorderColorDefinitions()
{
return array(
array(
array(
'border-color' => '#f00',
'border-color-top' => '#00f',
),
'0.00mm solid #0000ff 0.00mm solid #ff0000 0.00mm solid #ff0000 0.00mm solid #ff0000',
),
);
}
/**
* @dataProvider getBorderColorDefinitions
*/
public function testMergeBorderColorValues( $styles, $expected )
{
$this->assertCorrectMerge( 'border', $styles, $expected );
}
public static function getBorderStyleDefinitions()
{
return array(
array(
array(
'border-style' => 'solid double',
'border-style-top' => 'inset',
),
'0.00mm inset #ffffff 0.00mm double #ffffff 0.00mm solid #ffffff 0.00mm double #ffffff',
),
);
}
/**
* @dataProvider getBorderStyleDefinitions
*/
public function testMergeBorderStyleValues( $styles, $expected )
{
$this->assertCorrectMerge( 'border', $styles, $expected );
}
public static function getBorderWidthDefinitions()
{
return array(
array(
array(
'border-width' => '1mm 2mm 3mm 4mm',
'border-width-left' => '5mm',
),
'1.00mm solid #ffffff 2.00mm solid #ffffff 3.00mm solid #ffffff 5.00mm solid #ffffff',
),
);
}
/**
* @dataProvider getBorderWidthDefinitions
*/
public function testMergeBorderWidthValues( $styles, $expected )
{
$this->assertCorrectMerge( 'border', $styles, $expected );
}
public static function getBorderDefinitions()
{
return array(
array(
array(
'border' => '1mm 2mm #0f0 3mm inset 4mm ',
'border-left' => '5mm',
),
'1.00mm solid #ffffff 2.00mm solid #00ff00 3.00mm inset #ffffff 5.00mm solid #ffffff',
),
array(
array(
'border' => '1mm 2mm #0f0 3mm inset 4mm double',
'border-width-left' => '5mm',
'border-color-right' => '#0f0f0f',
),
'1.00mm solid #ffffff 2.00mm solid #0f0f0f 3.00mm inset #ffffff 5.00mm double #ffffff',
),
array(
array(
'border' => '1mm 2mm #0f0 3mm inset 4mm double',
'border-width-left' => '5mm',
'border-color-right' => '#0f0f0f',
'border-style-top' => 'outset',
),
'1.00mm outset #ffffff 2.00mm solid #0f0f0f 3.00mm inset #ffffff 5.00mm double #ffffff',
),
array(
array(
'border' => '1mm 2mm #0f0 3mm inset 4mm double',
'border-color' => '#0f0f0f',
),
'1.00mm solid #0f0f0f 2.00mm solid #0f0f0f 3.00mm inset #0f0f0f 4.00mm double #0f0f0f',
),
array(
array(
'border-color' => '#0f0f0f',
'border' => '1mm 2mm #0f0 3mm inset 4mm double',
),
'1.00mm solid #ffffff 2.00mm solid #00ff00 3.00mm inset #ffffff 4.00mm double #ffffff',
),
);
}
/**
* @dataProvider getBorderDefinitions
*/
public function testMergeBorder( $styles, $expected )
{
$this->assertCorrectMerge( 'border', $styles, $expected );
}
public function testDefinitionExtraction1()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$inferencer->appendStyleDirectives( array(
$d1 = new ezcDocumentPcssDeclarationDirective(
'@font-face',
array(
'font-size' => '10',
)
),
) );
$this->assertEquals(
array( $d1 ),
$inferencer->getDefinitions( 'font-face' )
);
}
public function testDefinitionExtraction2()
{
$inferencer = new ezcDocumentPcssStyleInferencer( false );
$inferencer->appendStyleDirectives( array(
$d1 = new ezcDocumentPcssDeclarationDirective(
'@font-FACE',
array(
'font-size' => '10',
)
),
new ezcDocumentPcssDeclarationDirective(
'@unknown',
array(
'font-size' => '10',
)
),
) );
$this->assertEquals(
array( $d1 ),
$inferencer->getDefinitions( 'font-face' )
);
}
}
?>