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/multipart.httpinput'),
48 'display_name' => 'User Name',
51 'fields_attributes' => [
53 'name' => 'variable 1',
57 'name' => 'variable 2',
65 'form-urlencoded' => [
66 'contenttype' => 'application/x-www-form-urlencoded;charset=utf8',
67 'input' => file_get_contents(__DIR__ . '/../../datasets/http/form-urlencoded.httpinput'),
75 'form-urlencoded-json' => [
76 'contenttype' => 'application/x-www-form-urlencoded;charset=utf8',
77 'input' => file_get_contents(__DIR__ . '/../../datasets/http/form-urlencoded-json.httpinput'),
82 'status' => 'Test Status',
83 'visibility' => 'private',
84 'spoiler_text' => 'Title'
93 * Tests the HTTPInputData::process() method
94 * @see HTTPInputData::process()
95 * @param string $contenttype The content typer of the transmitted data
96 * @param string $input The input, we got from the data stream
97 * @param array $expected The expected output
98 * @dataProvider dataStream
100 public function testHttpInput(string $contenttype, string $input, array $expected)
102 $_SERVER['CONTENT_TYPE'] = $contenttype;
104 HTTPInputDataDouble::setPhpInputContent($input);
105 $stream = fopen('php://memory', 'r+');
106 fwrite($stream, $input);
109 HTTPInputDataDouble::setPhpInputStream($stream);
110 $output = HTTPInputDataDouble::process();
111 $this->assertEqualsCanonicalizing($expected, $output);