3 * @copyright Copyright (C) 2010-2021, the Friendica project
5 * @license GNU AGPL version 3 or any later version
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as
9 * published by the Free Software Foundation, either version 3 of the
10 * License, or (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 namespace Friendica\Test\src\Util;
24 use Friendica\Test\MockedTest;
25 use Friendica\Test\Util\HTTPInputDataDouble;
26 use Friendica\Util\HTTPInputData;
29 * Testing HTTPInputData
32 class HTTPInputDataTest extends MockedTest
35 * Returns the data stream for the unit test
36 * Each array element of the first hierarchy represents one test run
37 * Each array element of the second hierarchy represents the parameters, passed to the test function
40 public function dataStream()
44 'contenttype' => 'multipart/form-data;boundary=43395968-f65c-437e-b536-5b33e3e3c7e5;charset=utf8',
45 'input' => file_get_contents(__DIR__ . '/../../datasets/http/example1.httpinput'),
48 'display_name' => 'User Name',
51 'fields_attributes' => [
53 'name' => 'variable 1',
57 'name' => 'variable 2',
69 * Tests the HTTPInputData::process() method
70 * @see HTTPInputData::process()
71 * @param string $contenttype The content typer of the transmitted data
72 * @param string $input The input, we got from the data stream
73 * @param array $expected The expected output
74 * @dataProvider dataStream
76 public function testHttpInput(string $contenttype, string $input, array $expected)
78 $_SERVER['CONTENT_TYPE'] = $contenttype;
80 HTTPInputDataDouble::setPhpInputContent($input);
81 $stream = fopen('php://memory', 'r+');
82 fwrite($stream, $input);
85 HTTPInputDataDouble::setPhpInputStream($stream);
86 $output = HTTPInputDataDouble::process();
87 $this->assertEqualsCanonicalizing($expected, $output);