PHP 8.2.31
Preview: FileValidatorTest.php Size: 10.18 KB
/opt/alt/php53/usr/share/pear/test/Validator/Symfony/Component/Validator/Tests/Constraints/FileValidatorTest.php

<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\Validator\Tests\Constraints;

use Symfony\Component\Validator\Constraints\File;
use Symfony\Component\Validator\Constraints\FileValidator;
use Symfony\Component\HttpFoundation\File\UploadedFile;

abstract class FileValidatorTest extends \PHPUnit_Framework_TestCase
{
    protected $context;
    protected $validator;
    protected $path;
    protected $file;

    protected function setUp()
    {
        $this->context = $this->getMock('Symfony\Component\Validator\ExecutionContext', array(), array(), '', false);
        $this->validator = new FileValidator();
        $this->validator->initialize($this->context);
        $this->path = sys_get_temp_dir().DIRECTORY_SEPARATOR.'FileValidatorTest';
        $this->file = fopen($this->path, 'w');
    }

    protected function tearDown()
    {
        fclose($this->file);

        $this->context = null;
        $this->validator = null;
        $this->path = null;
        $this->file = null;
    }

    public function testNullIsValid()
    {
        $this->context->expects($this->never())
            ->method('addViolation');

        $this->validator->validate(null, new File());
    }

    public function testEmptyStringIsValid()
    {
        $this->context->expects($this->never())
            ->method('addViolation');

        $this->validator->validate('', new File());
    }

    /**
     * @expectedException \Symfony\Component\Validator\Exception\UnexpectedTypeException
     */
    public function testExpectsStringCompatibleTypeOrFile()
    {
        $this->validator->validate(new \stdClass(), new File());
    }

    public function testValidFile()
    {
        $this->context->expects($this->never())
            ->method('addViolation');

        $this->validator->validate($this->path, new File());
    }

    public function testValidUploadedfile()
    {
        $this->context->expects($this->never())
            ->method('addViolation');

        $file = new UploadedFile($this->path, 'originalName', null, null, null, true);
        $this->validator->validate($file, new File());
    }

    public function testTooLargeBytes()
    {
        fwrite($this->file, str_repeat('0', 11));

        $constraint = new File(array(
            'maxSize'           => 10,
            'maxSizeMessage'    => 'myMessage',
        ));

        $this->context->expects($this->once())
            ->method('addViolation')
            ->with('myMessage', array(
                '{{ limit }}'   => '10',
                '{{ size }}'    => '11',
                '{{ suffix }}'  => 'bytes',
                '{{ file }}'    => $this->path,
            ));

        $this->validator->validate($this->getFile($this->path), $constraint);
    }

    public function testTooLargeKiloBytes()
    {
        fwrite($this->file, str_repeat('0', 1400));

        $constraint = new File(array(
            'maxSize'           => '1k',
            'maxSizeMessage'    => 'myMessage',
        ));

        $this->context->expects($this->once())
            ->method('addViolation')
            ->with('myMessage', array(
                '{{ limit }}'   => '1',
                '{{ size }}'    => '1.4',
                '{{ suffix }}'  => 'kB',
                '{{ file }}'    => $this->path,
            ));

        $this->validator->validate($this->getFile($this->path), $constraint);
    }

    public function testTooLargeMegaBytes()
    {
        fwrite($this->file, str_repeat('0', 1400000));

        $constraint = new File(array(
            'maxSize'           => '1M',
            'maxSizeMessage'    => 'myMessage',
        ));

        $this->context->expects($this->once())
            ->method('addViolation')
            ->with('myMessage', array(
                '{{ limit }}'   => '1',
                '{{ size }}'    => '1.4',
                '{{ suffix }}'  => 'MB',
                '{{ file }}'    => $this->path,
            ));

        $this->validator->validate($this->getFile($this->path), $constraint);
    }

    /**
     * @expectedException \Symfony\Component\Validator\Exception\ConstraintDefinitionException
     */
    public function testInvalidMaxSize()
    {
        $constraint = new File(array(
            'maxSize' => '1abc',
        ));

        $this->validator->validate($this->path, $constraint);
    }

    public function testValidMimeType()
    {
        $file = $this
            ->getMockBuilder('Symfony\Component\HttpFoundation\File\File')
            ->disableOriginalConstructor()
            ->getMock()
        ;
        $file
            ->expects($this->once())
            ->method('getPathname')
            ->will($this->returnValue($this->path))
        ;
        $file
            ->expects($this->once())
            ->method('getMimeType')
            ->will($this->returnValue('image/jpg'))
        ;

        $this->context->expects($this->never())
            ->method('addViolation');

        $constraint = new File(array(
            'mimeTypes' => array('image/png', 'image/jpg'),
        ));

        $this->validator->validate($file, $constraint);
    }

    public function testValidWildcardMimeType()
    {
        $file = $this
            ->getMockBuilder('Symfony\Component\HttpFoundation\File\File')
            ->disableOriginalConstructor()
            ->getMock()
        ;
        $file
            ->expects($this->once())
            ->method('getPathname')
            ->will($this->returnValue($this->path))
        ;
        $file
            ->expects($this->once())
            ->method('getMimeType')
            ->will($this->returnValue('image/jpg'))
        ;

        $this->context->expects($this->never())
            ->method('addViolation');

        $constraint = new File(array(
            'mimeTypes' => array('image/*'),
        ));

        $this->validator->validate($file, $constraint);
    }

    public function testInvalidMimeType()
    {
        $file = $this
            ->getMockBuilder('Symfony\Component\HttpFoundation\File\File')
            ->disableOriginalConstructor()
            ->getMock()
        ;
        $file
            ->expects($this->once())
            ->method('getPathname')
            ->will($this->returnValue($this->path))
        ;
        $file
            ->expects($this->once())
            ->method('getMimeType')
            ->will($this->returnValue('application/pdf'))
        ;

        $constraint = new File(array(
            'mimeTypes' => array('image/png', 'image/jpg'),
            'mimeTypesMessage' => 'myMessage',
        ));

        $this->context->expects($this->once())
            ->method('addViolation')
            ->with('myMessage', array(
                '{{ type }}'    => '"application/pdf"',
                '{{ types }}'   => '"image/png", "image/jpg"',
                '{{ file }}'    => $this->path,
            ));

        $this->validator->validate($file, $constraint);
    }

    public function testInvalidWildcardMimeType()
    {
        $file = $this
            ->getMockBuilder('Symfony\Component\HttpFoundation\File\File')
            ->disableOriginalConstructor()
            ->getMock()
        ;
        $file
            ->expects($this->once())
            ->method('getPathname')
            ->will($this->returnValue($this->path))
        ;
        $file
            ->expects($this->once())
            ->method('getMimeType')
            ->will($this->returnValue('application/pdf'))
        ;

        $constraint = new File(array(
            'mimeTypes' => array('image/*', 'image/jpg'),
            'mimeTypesMessage' => 'myMessage',
        ));

        $this->context->expects($this->once())
            ->method('addViolation')
            ->with('myMessage', array(
                '{{ type }}'    => '"application/pdf"',
                '{{ types }}'   => '"image/*", "image/jpg"',
                '{{ file }}'    => $this->path,
            ));

        $this->validator->validate($file, $constraint);
    }

    /**
     * @dataProvider uploadedFileErrorProvider
     */
    public function testUploadedFileError($error, $message, array $params = array(), $maxSize = null)
    {
        $file = new UploadedFile('/path/to/file', 'originalName', 'mime', 0, $error);

        $constraint = new File(array(
            $message => 'myMessage',
            'maxSize' => $maxSize
        ));

        $this->context->expects($this->once())
            ->method('addViolation')
            ->with('myMessage', $params);

        $this->validator->validate($file, $constraint);

    }

    public function uploadedFileErrorProvider()
    {
        $tests = array(
            array(UPLOAD_ERR_FORM_SIZE, 'uploadFormSizeErrorMessage'),
            array(UPLOAD_ERR_PARTIAL, 'uploadPartialErrorMessage'),
            array(UPLOAD_ERR_NO_FILE, 'uploadNoFileErrorMessage'),
            array(UPLOAD_ERR_NO_TMP_DIR, 'uploadNoTmpDirErrorMessage'),
            array(UPLOAD_ERR_CANT_WRITE, 'uploadCantWriteErrorMessage'),
            array(UPLOAD_ERR_EXTENSION, 'uploadExtensionErrorMessage'),
        );

        if (class_exists('Symfony\Component\HttpFoundation\File\UploadedFile')) {
            // when no maxSize is specified on constraint, it should use the ini value
            $tests[] = array(UPLOAD_ERR_INI_SIZE, 'uploadIniSizeErrorMessage', array(
                '{{ limit }}' => UploadedFile::getMaxFilesize(),
                '{{ suffix }}' => 'bytes',
            ));

            // it should use the smaller limitation (maxSize option in this case)
            $tests[] = array(UPLOAD_ERR_INI_SIZE, 'uploadIniSizeErrorMessage', array(
                '{{ limit }}' => 1,
                '{{ suffix }}' => 'bytes',
            ), '1');

            // it correctly parses the maxSize option and not only uses simple string comparison
            // 1000M should be bigger than the ini value
            $tests[] = array(UPLOAD_ERR_INI_SIZE, 'uploadIniSizeErrorMessage', array(
                '{{ limit }}' => UploadedFile::getMaxFilesize(),
                '{{ suffix }}' => 'bytes',
            ), '1000M');
        }

        return $tests;
    }

    abstract protected function getFile($filename);
}

Directory Contents

Dirs: 1 × Files: 52

Name Size Perms Modified Actions
Fixtures DIR
- drwxr-xr-x 2024-03-03 22:55:08
Edit Download
3.46 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
966 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
3.16 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.87 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
10.11 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
4.65 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
7.93 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.94 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
482 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
458 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.72 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
10.94 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.89 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
509 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
824 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.20 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.99 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
3.10 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.82 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.62 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.56 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.79 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.57 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
495 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
875 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download
10.18 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.51 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.87 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
8.17 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.71 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
7.97 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
12.32 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.67 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.30 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.96 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
6.25 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.77 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.80 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.63 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
3.32 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.59 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.58 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.60 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.64 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.83 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.93 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
4.57 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
2.83 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
1.58 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.31 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
5.58 KB lrw-r--r-- 2019-12-18 11:20:44
Edit Download
676 B lrw-r--r-- 2019-12-18 11:20:44
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).