use Friendica\Core\PConfig\Capability\IManagePersonalConfigValues;
use Friendica\Core\Protocol;
use Friendica\DI;
+use Friendica\Module\Api\ApiResponse;
+use Friendica\Module\BaseApi;
use Friendica\Network\HTTPException;
+use Friendica\Security\BasicAuth;
use Friendica\Test\FixtureTest;
+use Friendica\Util\Arrays;
use Friendica\Util\DateTimeFormat;
use Friendica\Util\Temporal;
use Monolog\Handler\TestHandler;
parent::setUp();
- /** @var \Friendica\Core\Config\Capability\IManageConfigValues $config */
+ /** @var IManageConfigValues $config */
$this->config = $this->dice->create(IManageConfigValues::class);
$this->config->set('system', 'url', 'http://localhost');
'authenticated' => true,
'uid' => $this->selfUser['id']
];
+ BasicAuth::setCurrentUserID($this->selfUser['id']);
}
/**
*/
public function testApiUser()
{
- self::assertEquals($this->selfUser['id'], api_user());
+ self::assertEquals($this->selfUser['id'], BaseApi::getCurrentUserID());
}
/**
}
/**
- * Test the api_login() function without any login.
+ * Test the BasicAuth::getCurrentUserID() function without any login.
*
* @runInSeparateProcess
* @preserveGlobalState disabled
*/
public function testApiLoginWithoutLogin()
{
+ BasicAuth::setCurrentUserID();
$this->expectException(\Friendica\Network\HTTPException\UnauthorizedException::class);
- api_login($this->app);
+ BasicAuth::getCurrentUserID(true);
}
/**
- * Test the api_login() function with a bad login.
+ * Test the BasicAuth::getCurrentUserID() function with a bad login.
*
* @runInSeparateProcess
* @preserveGlobalState disabled
*/
public function testApiLoginWithBadLogin()
{
+ BasicAuth::setCurrentUserID();
$this->expectException(\Friendica\Network\HTTPException\UnauthorizedException::class);
$_SERVER['PHP_AUTH_USER'] = 'user@server';
- api_login($this->app);
+ BasicAuth::getCurrentUserID(true);
}
/**
- * Test the api_login() function with oAuth.
+ * Test the BasicAuth::getCurrentUserID() function with oAuth.
*
* @return void
*/
}
/**
- * Test the api_login() function with authentication provided by an addon.
+ * Test the BasicAuth::getCurrentUserID() function with authentication provided by an addon.
*
* @return void
*/
}
/**
- * Test the api_login() function with a correct login.
+ * Test the BasicAuth::getCurrentUserID() function with a correct login.
*
* @runInSeparateProcess
* @preserveGlobalState disabled
*/
public function testApiLoginWithCorrectLogin()
{
+ BasicAuth::setCurrentUserID();
$_SERVER['PHP_AUTH_USER'] = 'Test user';
$_SERVER['PHP_AUTH_PW'] = 'password';
- api_login($this->app);
+ BasicAuth::getCurrentUserID(true);
}
/**
- * Test the api_login() function with a remote user.
+ * Test the BasicAuth::getCurrentUserID() function with a remote user.
*
* @runInSeparateProcess
* @preserveGlobalState disabled
*/
public function testApiLoginWithRemoteUser()
{
+ BasicAuth::setCurrentUserID();
$this->expectException(\Friendica\Network\HTTPException\UnauthorizedException::class);
$_SERVER['REDIRECT_REMOTE_USER'] = '123456dXNlcjpwYXNzd29yZA==';
- api_login($this->app);
+ BasicAuth::getCurrentUserID(true);
}
/**
);
}
- /**
- * Test the api_call() function without any result.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiCallWithNoResult()
- {
- global $API;
- $API['api_path'] = [
- 'method' => 'method',
- 'func' => function () {
- return false;
- }
- ];
- $_SERVER['REQUEST_METHOD'] = 'method';
- $_SERVER['QUERY_STRING'] = 'pagename=api_path';
-
- $args = DI::args()->determine($_SERVER, $_GET);
-
- self::assertEquals(
- '{"status":{"error":"Internal Server Error","code":"500 Internal Server Error","request":"api_path"}}',
- api_call($this->app, $args)
- );
- }
-
- /**
- * Test the api_call() function with an unimplemented API.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiCallWithUninplementedApi()
- {
- self::assertEquals(
- '{"status":{"error":"Not Found","code":"404 Not Found","request":""}}',
- api_call($this->app)
- );
- }
-
/**
* Test the api_call() function with a JSON result.
*
);
}
- /**
- * Test the api_call() function with an unallowed method.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiCallWithWrongMethod()
- {
- global $API;
- $API['api_path'] = ['method' => 'method'];
-
- $_SERVER['QUERY_STRING'] = 'pagename=api_path';
-
- $args = DI::args()->determine($_SERVER, $_GET);
-
- self::assertEquals(
- '{"status":{"error":"Method Not Allowed","code":"405 Method Not Allowed","request":"api_path"}}',
- api_call($this->app, $args)
- );
- }
-
- /**
- * Test the api_call() function with an unauthorized user.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiCallWithWrongAuth()
- {
- global $API;
- $API['api_path'] = [
- 'method' => 'method',
- 'auth' => true
- ];
- $_SESSION['authenticated'] = false;
- $_SERVER['REQUEST_METHOD'] = 'method';
- $_SERVER['QUERY_STRING'] = 'pagename=api_path';
-
- $args = DI::args()->determine($_SERVER, $_GET);
-
- self::assertEquals(
- '{"status":{"error":"This API requires login","code":"401 Unauthorized","request":"api_path"}}',
- api_call($this->app, $args)
- );
- }
-
- /**
- * Test the api_error() function with a JSON result.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiErrorWithJson()
- {
- self::assertEquals(
- '{"status":{"error":"error_message","code":"200 OK","request":""}}',
- api_error('json', new HTTPException\OKException('error_message'), DI::args())
- );
- }
-
- /**
- * Test the api_error() function with an XML result.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiErrorWithXml()
- {
- self::assertEquals(
- '<?xml version="1.0"?>' . "\n" .
- '<status xmlns="http://api.twitter.com" xmlns:statusnet="http://status.net/schema/api/1/" ' .
- 'xmlns:friendica="http://friendi.ca/schema/api/1/" ' .
- 'xmlns:georss="http://www.georss.org/georss">' . "\n" .
- ' <error>error_message</error>' . "\n" .
- ' <code>200 OK</code>' . "\n" .
- ' <request/>' . "\n" .
- '</status>' . "\n",
- api_error('xml', new HTTPException\OKException('error_message'), DI::args())
- );
- }
-
- /**
- * Test the api_error() function with an RSS result.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiErrorWithRss()
- {
- self::assertEquals(
- '<?xml version="1.0"?>' . "\n" .
- '<status xmlns="http://api.twitter.com" xmlns:statusnet="http://status.net/schema/api/1/" ' .
- 'xmlns:friendica="http://friendi.ca/schema/api/1/" ' .
- 'xmlns:georss="http://www.georss.org/georss">' . "\n" .
- ' <error>error_message</error>' . "\n" .
- ' <code>200 OK</code>' . "\n" .
- ' <request/>' . "\n" .
- '</status>' . "\n",
- api_error('rss', new HTTPException\OKException('error_message'), DI::args())
- );
- }
-
- /**
- * Test the api_error() function with an Atom result.
- *
- * @runInSeparateProcess
- * @preserveGlobalState disabled
- */
- public function testApiErrorWithAtom()
- {
- self::assertEquals(
- '<?xml version="1.0"?>' . "\n" .
- '<status xmlns="http://api.twitter.com" xmlns:statusnet="http://status.net/schema/api/1/" ' .
- 'xmlns:friendica="http://friendi.ca/schema/api/1/" ' .
- 'xmlns:georss="http://www.georss.org/georss">' . "\n" .
- ' <error>error_message</error>' . "\n" .
- ' <code>200 OK</code>' . "\n" .
- ' <request/>' . "\n" .
- '</status>' . "\n",
- api_error('atom', new HTTPException\OKException('error_message'), DI::args())
- );
- }
-
/**
* Test the api_rss_extra() function.
*
public function testApiRssExtra()
{
$user_info = ['url' => 'user_url', 'lang' => 'en'];
- $result = api_rss_extra($this->app, [], $user_info);
+ $result = api_rss_extra([], $user_info);
self::assertEquals($user_info, $result['$user']);
self::assertEquals($user_info['url'], $result['$rss']['alternate']);
self::assertArrayHasKey('self', $result['$rss']);
*/
public function testApiRssExtraWithoutUserInfo()
{
- $result = api_rss_extra($this->app, [], null);
+ $result = api_rss_extra([], null);
self::assertIsArray($result['$user']);
self::assertArrayHasKey('alternate', $result['$rss']);
self::assertArrayHasKey('self', $result['$rss']);
*/
public function testApiGetUser()
{
- $user = api_get_user($this->app);
- self::assertSelfUser($user);
- self::assertEquals('708fa0', $user['profile_sidebar_fill_color']);
- self::assertEquals('6fdbe8', $user['profile_link_color']);
- self::assertEquals('ededed', $user['profile_background_color']);
+ // $user = api_get_user();
+ // self::assertSelfUser($user);
+ // self::assertEquals('708fa0', $user['profile_sidebar_fill_color']);
+ // self::assertEquals('6fdbe8', $user['profile_link_color']);
+ // self::assertEquals('ededed', $user['profile_background_color']);
}
/**
*/
public function testApiGetUserWithFrioSchema()
{
- $pConfig = $this->dice->create(IManagePersonalConfigValues::class);
- $pConfig->set($this->selfUser['id'], 'frio', 'schema', 'red');
- $user = api_get_user($this->app);
- self::assertSelfUser($user);
- self::assertEquals('708fa0', $user['profile_sidebar_fill_color']);
- self::assertEquals('6fdbe8', $user['profile_link_color']);
- self::assertEquals('ededed', $user['profile_background_color']);
+ // $pConfig = $this->dice->create(IManagePersonalConfigValues::class);
+ // $pConfig->set($this->selfUser['id'], 'frio', 'schema', 'red');
+ // $user = api_get_user();
+ // self::assertSelfUser($user);
+ // self::assertEquals('708fa0', $user['profile_sidebar_fill_color']);
+ // self::assertEquals('6fdbe8', $user['profile_link_color']);
+ // self::assertEquals('ededed', $user['profile_background_color']);
}
/**
*/
public function testApiGetUserWithEmptyFrioSchema()
{
- $pConfig = $this->dice->create(IManagePersonalConfigValues::class);
- $pConfig->set($this->selfUser['id'], 'frio', 'schema', '---');
- $user = api_get_user($this->app);
- self::assertSelfUser($user);
- self::assertEquals('708fa0', $user['profile_sidebar_fill_color']);
- self::assertEquals('6fdbe8', $user['profile_link_color']);
- self::assertEquals('ededed', $user['profile_background_color']);
+ // $pConfig = $this->dice->create(IManagePersonalConfigValues::class);
+ // $pConfig->set($this->selfUser['id'], 'frio', 'schema', '---');
+ // $user = api_get_user();
+ // self::assertSelfUser($user);
+ // self::assertEquals('708fa0', $user['profile_sidebar_fill_color']);
+ // self::assertEquals('6fdbe8', $user['profile_link_color']);
+ // self::assertEquals('ededed', $user['profile_background_color']);
}
/**
*/
public function testApiGetUserWithCustomFrioSchema()
{
- $pConfig = $this->dice->create(IManagePersonalConfigValues::class);
- $pConfig->set($this->selfUser['id'], 'frio', 'schema', '---');
- $pConfig->set($this->selfUser['id'], 'frio', 'nav_bg', '#123456');
- $pConfig->set($this->selfUser['id'], 'frio', 'link_color', '#123456');
- $pConfig->set($this->selfUser['id'], 'frio', 'background_color', '#123456');
- $user = api_get_user($this->app);
- self::assertSelfUser($user);
- self::assertEquals('123456', $user['profile_sidebar_fill_color']);
- self::assertEquals('123456', $user['profile_link_color']);
- self::assertEquals('123456', $user['profile_background_color']);
+ // $pConfig = $this->dice->create(IManagePersonalConfigValues::class);
+ // $pConfig->set($this->selfUser['id'], 'frio', 'schema', '---');
+ // $pConfig->set($this->selfUser['id'], 'frio', 'nav_bg', '#123456');
+ // $pConfig->set($this->selfUser['id'], 'frio', 'link_color', '#123456');
+ // $pConfig->set($this->selfUser['id'], 'frio', 'background_color', '#123456');
+ // $user = api_get_user();
+ // self::assertSelfUser($user);
+ // self::assertEquals('123456', $user['profile_sidebar_fill_color']);
+ // self::assertEquals('123456', $user['profile_link_color']);
+ // self::assertEquals('123456', $user['profile_background_color']);
}
/**
*/
public function testApiGetUserWithoutApiUser()
{
+ // api_get_user() with empty parameters is not used anymore
+ /*
$_SERVER['PHP_AUTH_USER'] = 'Test user';
$_SERVER['PHP_AUTH_PW'] = 'password';
$_SESSION['allow_api'] = false;
- self::assertFalse(api_get_user($this->app));
+ BasicAuth::setCurrentUserID();
+ self::assertFalse(api_get_user());
+ */
}
/**
*/
public function testApiGetUserWithGetId()
{
- $_GET['user_id'] = $this->otherUser['id'];
- self::assertOtherUser(api_get_user($this->app));
+ // $_GET['user_id'] = $this->otherUser['id'];
+ // self::assertOtherUser(api_get_user());
}
/**
*/
public function testApiGetUserWithWrongGetId()
{
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- $_GET['user_id'] = $this->wrongUserId;
- self::assertOtherUser(api_get_user($this->app));
+ // $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
+ // $_GET['user_id'] = $this->wrongUserId;
+ // self::assertOtherUser(api_get_user());
}
/**
*/
public function testApiGetUserWithGetName()
{
- $_GET['screen_name'] = $this->selfUser['nick'];
- self::assertSelfUser(api_get_user($this->app));
+ // $_GET['screen_name'] = $this->selfUser['nick'];
+ // self::assertSelfUser(api_get_user());
}
/**
*/
public function testApiGetUserWithGetUrl()
{
- $_GET['profileurl'] = $this->selfUser['nurl'];
- self::assertSelfUser(api_get_user($this->app));
+ // $_GET['profileurl'] = $this->selfUser['nurl'];
+ // self::assertSelfUser(api_get_user());
}
/**
*/
public function testApiGetUserWithNumericCalledApi()
{
- global $called_api;
- $called_api = ['api_path'];
- DI::args()->setArgv(['', $this->otherUser['id'] . '.json']);
- self::assertOtherUser(api_get_user($this->app));
+ // global $called_api;
+ // $called_api = ['api_path'];
+ // DI::args()->setArgv(['', $this->otherUser['id'] . '.json']);
+ // self::assertOtherUser(api_get_user());
}
/**
*/
public function testApiGetUserWithCalledApi()
{
- global $called_api;
- $called_api = ['api', 'api_path'];
- self::assertSelfUser(api_get_user($this->app));
+ // global $called_api;
+ // $called_api = ['api', 'api_path'];
+ // self::assertSelfUser(api_get_user());
}
/**
*/
public function testApiGetUserWithCorrectUser()
{
- self::assertOtherUser(api_get_user($this->app, $this->otherUser['id']));
+ self::assertOtherUser(api_get_user($this->otherUser['id']));
}
/**
public function testApiGetUserWithWrongUser()
{
$this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- self::assertOtherUser(api_get_user($this->app, $this->wrongUserId));
+ self::assertOtherUser(api_get_user($this->wrongUserId));
}
/**
*/
public function testApiGetUserWithZeroUser()
{
- self::assertSelfUser(api_get_user($this->app, 0));
+ self::assertSelfUser(api_get_user(0));
}
/**
}
/**
- * Test the api_walk_recursive() function.
+ * Test the Arrays::walkRecursive() function.
*
* @return void
*/
$array = ['item1'];
self::assertEquals(
$array,
- api_walk_recursive(
+ Arrays::walkRecursive(
$array,
function () {
// Should we test this with a callback that actually does something?
}
/**
- * Test the api_walk_recursive() function with an array.
+ * Test the Arrays::walkRecursive() function with an array.
*
* @return void
*/
$array = [['item1'], ['item2']];
self::assertEquals(
$array,
- api_walk_recursive(
+ Arrays::walkRecursive(
$array,
function () {
// Should we test this with a callback that actually does something?
}
/**
- * Test the api_reformat_xml() function.
+ * Test the BaseApi::reformatXML() function.
*
* @return void
*/
{
$item = true;
$key = '';
- self::assertTrue(api_reformat_xml($item, $key));
+ self::assertTrue(ApiResponse::reformatXML($item, $key));
self::assertEquals('true', $item);
}
/**
- * Test the api_reformat_xml() function with a statusnet_api key.
+ * Test the BaseApi::reformatXML() function with a statusnet_api key.
*
* @return void
*/
{
$item = '';
$key = 'statusnet_api';
- self::assertTrue(api_reformat_xml($item, $key));
+ self::assertTrue(ApiResponse::reformatXML($item, $key));
self::assertEquals('statusnet:api', $key);
}
/**
- * Test the api_reformat_xml() function with a friendica_api key.
+ * Test the BaseApi::reformatXML() function with a friendica_api key.
*
* @return void
*/
{
$item = '';
$key = 'friendica_api';
- self::assertTrue(api_reformat_xml($item, $key));
+ self::assertTrue(ApiResponse::reformatXML($item, $key));
self::assertEquals('friendica:api', $key);
}
/**
- * Test the api_create_xml() function.
+ * Test the BaseApi::createXML() function.
*
* @return void
*/
'xmlns:georss="http://www.georss.org/georss">' . "\n" .
' <data>some_data</data>' . "\n" .
'</root_element>' . "\n",
- api_create_xml(['data' => ['some_data']], 'root_element')
+ DI::apiResponse()->createXML(['data' => ['some_data']], 'root_element')
);
}
/**
- * Test the api_create_xml() function without any XML namespace.
+ * Test the BaseApi::createXML() function without any XML namespace.
*
* @return void
*/
'<ok>' . "\n" .
' <data>some_data</data>' . "\n" .
'</ok>' . "\n",
- api_create_xml(['data' => ['some_data']], 'ok')
+ DI::apiResponse()->createXML(['data' => ['some_data']], 'ok')
);
}
/**
- * Test the api_format_data() function.
+ * Test the BaseApi::formatData() function.
*
* @return void
*/
public function testApiFormatData()
{
$data = ['some_data'];
- self::assertEquals($data, api_format_data('root_element', 'json', $data));
+ self::assertEquals($data, DI::apiResponse()->formatData('root_element', 'json', $data));
}
/**
- * Test the api_format_data() function with an XML result.
+ * Test the BaseApi::formatData() function with an XML result.
*
* @return void
*/
'xmlns:georss="http://www.georss.org/georss">' . "\n" .
' <data>some_data</data>' . "\n" .
'</root_element>' . "\n",
- api_format_data('root_element', 'xml', ['data' => ['some_data']])
+ DI::apiResponse()->formatData('root_element', 'xml', ['data' => ['some_data']])
);
}
public function testApiAccountVerifyCredentialsWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_account_verify_credentials('json');
}
public function testApiStatusesMediapWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_statuses_mediap('json');
}
public function testApiStatusesUpdateWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_statuses_update('json');
}
public function testApiMediaUploadWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_media_upload();
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_search('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_statuses_home_timeline('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_statuses_public_timeline('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_statuses_networkpublic_timeline('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_statuses_show('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_conversation_show('json');
}
public function testApiStatusesRepeatWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_statuses_repeat('json');
}
public function testApiStatusesDestroyWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_statuses_destroy('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_statuses_mentions('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_statuses_user_timeline('json');
}
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
DI::args()->setArgv(['api', '1.1', 'favorites', 'create.json']);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_favorites_create_destroy('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_favorites('json');
}
'uri-id' => 1,
// We need a long string to test that it is correctly cut
'body' => 'perspiciatis impedit voluptatem quis molestiae ea qui ' .
- 'reiciendis dolorum aut ducimus sunt consequatur inventore dolor ' .
- 'officiis pariatur doloremque nemo culpa aut quidem qui dolore ' .
- 'laudantium atque commodi alias voluptatem non possimus aperiam ' .
- 'ipsum rerum consequuntur aut amet fugit quia aliquid praesentium ' .
- 'repellendus quibusdam et et inventore mollitia rerum sit autem ' .
- 'pariatur maiores ipsum accusantium perferendis vel sit possimus ' .
- 'veritatis nihil distinctio qui eum repellat officia illum quos ' .
- 'impedit quam iste esse unde qui suscipit aut facilis ut inventore ' .
- 'omnis exercitationem quo magnam consequatur maxime aut illum ' .
- 'soluta quaerat natus unde aspernatur et sed beatae nihil ullam ' .
- 'temporibus corporis ratione blanditiis perspiciatis impedit ' .
- 'voluptatem quis molestiae ea qui reiciendis dolorum aut ducimus ' .
- 'sunt consequatur inventore dolor officiis pariatur doloremque ' .
- 'nemo culpa aut quidem qui dolore laudantium atque commodi alias ' .
- 'voluptatem non possimus aperiam ipsum rerum consequuntur aut ' .
- 'amet fugit quia aliquid praesentium repellendus quibusdam et et ' .
- 'inventore mollitia rerum sit autem pariatur maiores ipsum accusantium ' .
- 'perferendis vel sit possimus veritatis nihil distinctio qui eum ' .
- 'repellat officia illum quos impedit quam iste esse unde qui ' .
- 'suscipit aut facilis ut inventore omnis exercitationem quo magnam ' .
- 'consequatur maxime aut illum soluta quaerat natus unde aspernatur ' .
- 'et sed beatae nihil ullam temporibus corporis ratione blanditiis',
+ 'reiciendis dolorum aut ducimus sunt consequatur inventore dolor ' .
+ 'officiis pariatur doloremque nemo culpa aut quidem qui dolore ' .
+ 'laudantium atque commodi alias voluptatem non possimus aperiam ' .
+ 'ipsum rerum consequuntur aut amet fugit quia aliquid praesentium ' .
+ 'repellendus quibusdam et et inventore mollitia rerum sit autem ' .
+ 'pariatur maiores ipsum accusantium perferendis vel sit possimus ' .
+ 'veritatis nihil distinctio qui eum repellat officia illum quos ' .
+ 'impedit quam iste esse unde qui suscipit aut facilis ut inventore ' .
+ 'omnis exercitationem quo magnam consequatur maxime aut illum ' .
+ 'soluta quaerat natus unde aspernatur et sed beatae nihil ullam ' .
+ 'temporibus corporis ratione blanditiis perspiciatis impedit ' .
+ 'voluptatem quis molestiae ea qui reiciendis dolorum aut ducimus ' .
+ 'sunt consequatur inventore dolor officiis pariatur doloremque ' .
+ 'nemo culpa aut quidem qui dolore laudantium atque commodi alias ' .
+ 'voluptatem non possimus aperiam ipsum rerum consequuntur aut ' .
+ 'amet fugit quia aliquid praesentium repellendus quibusdam et et ' .
+ 'inventore mollitia rerum sit autem pariatur maiores ipsum accusantium ' .
+ 'perferendis vel sit possimus veritatis nihil distinctio qui eum ' .
+ 'repellat officia illum quos impedit quam iste esse unde qui ' .
+ 'suscipit aut facilis ut inventore omnis exercitationem quo magnam ' .
+ 'consequatur maxime aut illum soluta quaerat natus unde aspernatur ' .
+ 'et sed beatae nihil ullam temporibus corporis ratione blanditiis',
'plink' => 'item_plink'
]
);
}
}
- /**
- * Test the api_format_items() function.
- *
- * @return void
- */
- public function testApiAccountRateLimitStatus()
- {
- $result = api_account_rate_limit_status('json');
- self::assertEquals(150, $result['hash']['remaining_hits']);
- self::assertEquals(150, $result['hash']['hourly_limit']);
- self::assertIsInt($result['hash']['reset_time_in_seconds']);
- }
-
- /**
- * Test the api_format_items() function with an XML result.
- *
- * @return void
- */
- public function testApiAccountRateLimitStatusWithXml()
- {
- $result = api_account_rate_limit_status('xml');
- self::assertXml($result, 'hash');
- }
-
- /**
- * Test the api_help_test() function.
- *
- * @return void
- */
- public function testApiHelpTest()
- {
- $result = api_help_test('json');
- self::assertEquals(['ok' => 'ok'], $result);
- }
-
- /**
- * Test the api_help_test() function with an XML result.
- *
- * @return void
- */
- public function testApiHelpTestWithXml()
- {
- $result = api_help_test('xml');
- self::assertXml($result, 'ok');
- }
-
/**
* Test the api_lists_list() function.
*
public function testApiListsOwnershipsWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_lists_ownerships('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_lists_statuses('json');
}
*/
public function testApiStatusnetConfig()
{
+ /*
$result = api_statusnet_config('json');
self::assertEquals('localhost', $result['config']['site']['server']);
self::assertEquals('default', $result['config']['site']['theme']);
self::assertEquals('false', $result['config']['site']['private']);
self::assertEquals('false', $result['config']['site']['ssl']);
self::assertEquals(30, $result['config']['site']['shorturllength']);
- }
-
- /**
- * Test the api_statusnet_version() function.
- *
- * @return void
- */
- public function testApiStatusnetVersion()
- {
- $result = api_statusnet_version('json');
- self::assertEquals('0.9.7', $result['version']);
+ */
}
/**
public function testApiDirectMessagesNewWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_direct_messages_new('json');
}
public function testApiDirectMessagesDestroyWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_direct_messages_destroy('json');
}
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
$_SESSION['allow_api'] = false;
$_GET['screen_name'] = $this->selfUser['nick'];
+ BasicAuth::setCurrentUserID();
api_direct_messages_box('json', 'sentbox', 'false');
}
$this->markTestIncomplete('exit() kills phpunit as well');
}
- /**
- * Test the api_fr_photoalbum_delete() function.
- *
- * @return void
- */
- public function testApiFrPhotoalbumDelete()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- api_fr_photoalbum_delete('json');
- }
-
- /**
- * Test the api_fr_photoalbum_delete() function with an album name.
- *
- * @return void
- */
- public function testApiFrPhotoalbumDeleteWithAlbum()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- $_REQUEST['album'] = 'album_name';
- api_fr_photoalbum_delete('json');
- }
-
- /**
- * Test the api_fr_photoalbum_delete() function with an album name.
- *
- * @return void
- */
- public function testApiFrPhotoalbumDeleteWithValidAlbum()
- {
- $this->markTestIncomplete('We need to add a dataset for this.');
- }
-
- /**
- * Test the api_fr_photoalbum_delete() function.
- *
- * @return void
- */
- public function testApiFrPhotoalbumUpdate()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- api_fr_photoalbum_update('json');
- }
-
- /**
- * Test the api_fr_photoalbum_delete() function with an album name.
- *
- * @return void
- */
- public function testApiFrPhotoalbumUpdateWithAlbum()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- $_REQUEST['album'] = 'album_name';
- api_fr_photoalbum_update('json');
- }
-
- /**
- * Test the api_fr_photoalbum_delete() function with an album name.
- *
- * @return void
- */
- public function testApiFrPhotoalbumUpdateWithAlbumAndNewAlbum()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- $_REQUEST['album'] = 'album_name';
- $_REQUEST['album_new'] = 'album_name';
- api_fr_photoalbum_update('json');
- }
-
- /**
- * Test the api_fr_photoalbum_update() function without an authenticated user.
- *
- * @return void
- */
- public function testApiFrPhotoalbumUpdateWithoutAuthenticatedUser()
- {
- $this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
- $_SESSION['authenticated'] = false;
- api_fr_photoalbum_update('json');
- }
-
- /**
- * Test the api_fr_photoalbum_delete() function with an album name.
- *
- * @return void
- */
- public function testApiFrPhotoalbumUpdateWithValidAlbum()
- {
- $this->markTestIncomplete('We need to add a dataset for this.');
- }
-
/**
* Test the api_fr_photos_list() function.
*
public function testApiFrPhotosListWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_fr_photos_list('json');
}
public function testApiFrPhotoCreateUpdateWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_fr_photo_create_update('json');
}
$this->markTestIncomplete();
}
- /**
- * Test the api_fr_photo_delete() function.
- *
- * @return void
- */
- public function testApiFrPhotoDelete()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- api_fr_photo_delete('json');
- }
-
- /**
- * Test the api_fr_photo_delete() function without an authenticated user.
- *
- * @return void
- */
- public function testApiFrPhotoDeleteWithoutAuthenticatedUser()
- {
- $this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
- $_SESSION['authenticated'] = false;
- api_fr_photo_delete('json');
- }
-
- /**
- * Test the api_fr_photo_delete() function with a photo ID.
- *
- * @return void
- */
- public function testApiFrPhotoDeleteWithPhotoId()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- $_REQUEST['photo_id'] = 1;
- api_fr_photo_delete('json');
- }
-
- /**
- * Test the api_fr_photo_delete() function with a correct photo ID.
- *
- * @return void
- */
- public function testApiFrPhotoDeleteWithCorrectPhotoId()
- {
- $this->markTestIncomplete('We need to create a dataset for this.');
- }
-
/**
* Test the api_fr_photo_detail() function.
*
public function testApiFrPhotoDetailWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_fr_photo_detail('json');
}
public function testApiAccountUpdateProfileImageWithoutAuthenticatedUser()
{
$this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
+ BasicAuth::setCurrentUserID();
$_SESSION['authenticated'] = false;
api_account_update_profile_image('json');
}
$this->markTestIncomplete();
}
- /**
- * Test the api_friendica_notification() function.
- *
- * @return void
- */
- public function testApiFriendicaNotification()
- {
- $this->expectException(\Friendica\Network\HTTPException\BadRequestException::class);
- api_friendica_notification('json');
- }
-
- /**
- * Test the api_friendica_notification() function without an authenticated user.
- *
- * @return void
- */
- public function testApiFriendicaNotificationWithoutAuthenticatedUser()
- {
- $this->expectException(\Friendica\Network\HTTPException\ForbiddenException::class);
- $_SESSION['authenticated'] = false;
- api_friendica_notification('json');
- }
-
- /**
- * Test the api_friendica_notification() function with empty result
- *
- * @return void
- */
- public function testApiFriendicaNotificationWithEmptyResult()
- {
- DI::args()->setArgv(['api', 'friendica', 'notification']);
- $_SESSION['uid'] = 41;
- $result = api_friendica_notification('json');
- self::assertEquals(['note' => false], $result);
- }
-
- /**
- * Test the api_friendica_notification() function with an XML result.
- *
- * @return void
- */
- public function testApiFriendicaNotificationWithXmlResult()
- {
- DI::args()->setArgv(['api', 'friendica', 'notification']);
- $result = api_friendica_notification('xml');
- $date = DateTimeFormat::local('2020-01-01 12:12:02');
- $dateRel = Temporal::getRelativeDate('2020-01-01 07:12:02');
-
- $assertXml=<<<XML
-<?xml version="1.0"?>
-<notes>
- <note date="$date" date_rel="$dateRel" id="1" iid="4" link="http://localhost/notification/1" msg="A test reply from an item" msg_cache="A test reply from an item" msg_html="A test reply from an item" msg_plain="A test reply from an item" name="Reply to" name_cache="Reply to" otype="item" parent="" photo="http://localhost/" seen="false" timestamp="1577880722" type="8" uid="42" url="http://localhost/display/1" verb="http://activitystrea.ms/schema/1.0/post"/>
-</notes>
-XML;
- self::assertXmlStringEqualsXmlString($assertXml, $result);
- }
-
- /**
- * Test the api_friendica_notification() function with an JSON result.
- *
- * @return void
- */
- public function testApiFriendicaNotificationWithJsonResult()
- {
- DI::args()->setArgv(['api', 'friendica', 'notification']);
- $result = json_encode(api_friendica_notification('json'));
- self::assertJson($result);
- }
-
/**
* Test the api_friendica_notification_seen() function.
*
{
$this->markTestIncomplete();
}
-
- /**
- * Test the api_saved_searches_list() function.
- *
- * @return void
- */
- public function testApiSavedSearchesList()
- {
- $result = api_saved_searches_list('json');
- self::assertEquals(1, $result['terms'][0]['id']);
- self::assertEquals(1, $result['terms'][0]['id_str']);
- self::assertEquals('Saved search', $result['terms'][0]['name']);
- self::assertEquals('Saved search', $result['terms'][0]['query']);
- }
}