FileWidgetTest.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  5. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  6. *
  7. * Licensed under The MIT License
  8. * For full copyright and license information, please see the LICENSE.txt
  9. * Redistributions of files must retain the above copyright notice.
  10. *
  11. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  12. * @link https://cakephp.org CakePHP(tm) Project
  13. * @since 3.0.0
  14. * @license https://opensource.org/licenses/mit-license.php MIT License
  15. */
  16. namespace Cake\Test\TestCase\View\Widget;
  17. use Cake\Core\Configure;
  18. use Cake\Http\ServerRequest;
  19. use Cake\TestSuite\TestCase;
  20. use Cake\View\Form\NullContext;
  21. use Cake\View\StringTemplate;
  22. use Cake\View\Widget\FileWidget;
  23. /**
  24. * File input test.
  25. */
  26. class FileWidgetTest extends TestCase
  27. {
  28. /**
  29. * setup
  30. *
  31. * @return void
  32. */
  33. public function setUp(): void
  34. {
  35. parent::setUp();
  36. $templates = [
  37. 'file' => '<input type="file" name="{{name}}"{{attrs}}>',
  38. ];
  39. $this->templates = new StringTemplate($templates);
  40. $this->context = new NullContext(new ServerRequest(), []);
  41. }
  42. /**
  43. * Test render in a simple case.
  44. *
  45. * @return void
  46. */
  47. public function testRenderSimple()
  48. {
  49. $input = new FileWidget($this->templates);
  50. $result = $input->render(['name' => 'image'], $this->context);
  51. $expected = [
  52. 'input' => ['type' => 'file', 'name' => 'image'],
  53. ];
  54. $this->assertHtml($expected, $result);
  55. }
  56. /**
  57. * Test render with a value
  58. *
  59. * @return void
  60. */
  61. public function testRenderAttributes()
  62. {
  63. $input = new FileWidget($this->templates);
  64. $data = ['name' => 'image', 'required' => true, 'val' => 'nope'];
  65. $result = $input->render($data, $this->context);
  66. $expected = [
  67. 'input' => ['type' => 'file', 'required' => 'required', 'name' => 'image'],
  68. ];
  69. $this->assertHtml($expected, $result);
  70. }
  71. /**
  72. * Ensure templateVars option is hooked up.
  73. *
  74. * @return void
  75. */
  76. public function testRenderTemplateVars()
  77. {
  78. $this->templates->add([
  79. 'file' => '<input custom="{{custom}}" type="file" name="{{name}}"{{attrs}}>',
  80. ]);
  81. $input = new FileWidget($this->templates);
  82. $data = [
  83. 'templateVars' => ['custom' => 'value'],
  84. 'name' => 'files',
  85. ];
  86. $result = $input->render($data, $this->context);
  87. $expected = [
  88. 'input' => [
  89. 'type' => 'file',
  90. 'name' => 'files',
  91. 'custom' => 'value',
  92. ],
  93. ];
  94. $this->assertHtml($expected, $result);
  95. }
  96. /**
  97. * Test secureFields
  98. *
  99. * @return void
  100. */
  101. public function testSecureFields()
  102. {
  103. $input = new FileWidget($this->templates);
  104. $data = ['name' => 'image', 'required' => true, 'val' => 'nope'];
  105. $this->assertEquals(['image'], $input->secureFields($data));
  106. Configure::write('App.uploadedFilesAsObjects', false);
  107. $this->assertEquals(
  108. ['image[name]', 'image[type]', 'image[tmp_name]', 'image[error]', 'image[size]'],
  109. $input->secureFields($data)
  110. );
  111. }
  112. }