| <?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' ) |
| ); |
| } |
| } |
| |
| ?> |