File: tests/Component/PhpInterfaceTest.php

Recommend this page to a friend!
  Classes of WsdlToPhp  >  PHP Code Generator  >  tests/Component/PhpInterfaceTest.php  >  Download  
File: tests/Component/PhpInterfaceTest.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: 2,025 bytes
 

Contents

Class file image Download
<?php

declare(strict_types=1);

namespace
WsdlToPhp\PhpGenerator\Tests\Component;

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;
use
WsdlToPhp\PhpGenerator\Element\PhpMethod;

class
PhpInterfaceTest extends AbstractComponent
{
    public function
testSimpleToString()
    {
       
$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',
            ])
            ->
addMethodElement(new PhpMethod('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',
            ]);

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


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