File: tests/Component/PhpFileTest.php

Recommend this page to a friend!
  Classes of WsdlToPhp  >  PHP Code Generator  >  tests/Component/PhpFileTest.php  >  Download  
File: tests/Component/PhpFileTest.php
Role: Unit test script
Content type: text/plain
Description: Unit test script
Class: PHP Code Generator
Generate PHP code elements programatically
Author: By
Last change: upgrade source in order to use most of PHP 7.2 features
refactor sources and tests
add feature to PHP CS settings
Date: 1 year ago
Size: 5,133 bytes
 

Contents

Class file image Download
<?php

declare(strict_types=1);

namespace
WsdlToPhp\PhpGenerator\Tests\Component;

use
WsdlToPhp\PhpGenerator\Component\PhpClass as PhpClassComponent;
use
WsdlToPhp\PhpGenerator\Component\PhpFile as PhpFileComponent;
use
WsdlToPhp\PhpGenerator\Component\PhpInterface as PhpInterfaceComponent;
use
WsdlToPhp\PhpGenerator\Element\PhpFunctionParameter as PhpFunctionParameterElement;
use
WsdlToPhp\PhpGenerator\Element\PhpAnnotation as PhpAnnotationElement;
use
WsdlToPhp\PhpGenerator\Element\PhpProperty as PhpPropertyElement;

class
PhpFileTest extends AbstractComponent
{
    public function
testSimpleClassToString()
    {
       
$file = new PhpFileComponent('Foo');
       
$class = new PhpClassComponent('Foo', true, 'stdClass');

       
$class
           
->addAnnotationBlock('@var string')
            ->
addConstant('FOO', 'theValue')
            ->
addAnnotationBlock('@var string')
            ->
addConstant('BAR', 'theOtherValue')
            ->
addAnnotationBlock(new PhpAnnotationElement('var', 'int'))
            ->
addProperty('bar', 1)
            ->
addAnnotationBlock(new PhpAnnotationElement('var', 'bool'))
            ->
addPropertyElement(new PhpPropertyElement('sample', true))
            ->
addAnnotationBlock([
                new
PhpAnnotationElement(PhpAnnotationElement::NO_NAME, 'This method is very useful'),
                new
PhpAnnotationElement('date', '2012-03-01'),
               
'@return mixed',
            ])
            ->
addMethod('getMyValue', [
                new
PhpFunctionParameterElement('asString', true),
               
'unusedParameter',
            ])
            ->
addAnnotationBlock([
                new
PhpAnnotationElement(PhpAnnotationElement::NO_NAME, 'This method is very useless'),
                new
PhpAnnotationElement('date', '2012-03-01'),
               
'@return void',
            ])
            ->
addMethod('uselessMethod', [
                new
PhpFunctionParameterElement('uselessParameter', null),
               
'unusedParameter',
            ]);

       
$file
           
->setNamespace('My\\Testing\\NamespaceName')
            ->
addUse('My\\Testing\\ParentNamespace\\Model')
            ->
addUse('My\\Testing\\ParentNamespace\\Repository')
            ->
addUse('My\\Testing\\ParentNamespace\\Generator')
            ->
addUse('My\\Testing\\ParentNamespace\\Foo', 'FooType', true)
            ->
addClassComponent($class);

       
$this->assertSameContent(__FUNCTION__, $file);
    }

   
/**
     * @expectedException InvalidArgumentException
     */
   
public function testSetMainElementWithException()
    {
       
$file = new PhpFileComponent('Foo');

       
$file->setMainElement(new PhpFunctionParameterElement('bar'));
    }

    public function
testAddVariableToString()
    {
       
$file = new PhpFileComponent('Foo');

       
$file->addVariable('foo', 0);

       
$this->assertSame("<?php\n\$foo = 0;\n", $file->toString());
    }

    public function
testAddFunctionToString()
    {
       
$file = new PhpFileComponent('Foo');

       
$file->addFunction('name', [
           
'bar',
        ]);

       
$this->assertSame("<?php\nfunction name(\$bar)\n{\n}\n", $file->toString());
    }
    public function
testSimpleInterfaceToString()
    {
       
$file = new PhpFileComponent('Foo');
       
$interface = new PhpInterfaceComponent('Foo', true, null, [
           
'stdClass',
        ]);

       
$interface
           
->addAnnotationBlock('@var string')
            ->
addConstant('FOO', 'theValue')
            ->
addAnnotationBlock('@var string')
            ->
addConstant('BAR', 'theOtherValue')
            ->
addAnnotationBlock(new PhpAnnotationElement('var', 'int'))
            ->
addProperty('bar', 1)
            ->
addAnnotationBlock(new PhpAnnotationElement('var', 'bool'))
            ->
addPropertyElement(new PhpPropertyElement('sample', true))
            ->
addAnnotationBlock([
                new
PhpAnnotationElement(PhpAnnotationElement::NO_NAME, 'This method is very useful'),
                new
PhpAnnotationElement('date', '2012-03-01'),
               
'@return mixed',
            ])
            ->
addMethod('getMyValue', [
                new
PhpFunctionParameterElement('asString', true),
               
'unusedParameter',
            ])
            ->
addAnnotationBlock([
                new
PhpAnnotationElement(PhpAnnotationElement::NO_NAME, 'This method is very useless'),
                new
PhpAnnotationElement('date', '2012-03-01'),
               
'@return void',
            ])
            ->
addMethod('uselessMethod', [
                new
PhpFunctionParameterElement('uselessParameter', null),
               
'unusedParameter',
            ]);

       
$file
           
->setNamespace('My\\Testing\\NamespaceName')
            ->
addUse('My\\Testing\\ParentNamespace\\Model')
            ->
addUse('My\\Testing\\ParentNamespace\\Repository')
            ->
addUse('My\\Testing\\ParentNamespace\\Generator')
            ->
addUse('My\\Testing\\ParentNamespace\\Foo', 'FooType', true)
            ->
addInterfaceComponent($interface);

       
$this->assertSameContent(__FUNCTION__, $file);
    }
}


For more information send a message to info at phpclasses dot org.