Skip to content
Snippets Groups Projects

add unit test to confirm core functionality

Merged Patrick Kenny requested to merge issue/jsonapi_links-3497804:unit_test into 1.1.x
Files
4
 
<?php
 
 
declare(strict_types=1);
 
 
namespace Drupal\Tests\jsonapi\Functional;
 
 
/**
 
* General functional test class.
 
*
 
* @group jsonapi_links
 
*/
 
class JsonApiLinksFunctionalTest extends JsonApiFunctionalTestBase {
 
 
/**
 
* {@inheritdoc}
 
*/
 
protected static $modules = [
 
'basic_auth',
 
'jsonapi_links',
 
];
 
 
/**
 
* {@inheritdoc}
 
*/
 
protected $defaultTheme = 'stark';
 
 
/**
 
* The module config identifier.
 
*
 
* @var string
 
*/
 
protected string $configName = 'jsonapi_links.settings';
 
 
/**
 
* The name of the config for removing links.
 
*
 
* @var string
 
*/
 
protected string $configRemoveLinks = 'remove_links';
 
 
/**
 
* Tests the GET method.
 
*/
 
public function testRead(): void {
 
// First, do testRead() from core's JSON:API and ensure that the output is
 
// exactly the same as core.
 
// JSON:API Links does not remove anything by default.
 
$this->createDefaultContent(61, 5, TRUE, TRUE, static::IS_NOT_MULTILINGUAL, FALSE);
 
// Unpublish the last entity, so we can check access.
 
$this->nodes[60]->setUnpublished()->save();
 
 
$uuid = $this->nodes[0]->uuid();
 
 
// 0. HEAD request allows a client to verify that JSON:API is installed.
 
$this->httpClient->request('HEAD', $this->buildUrl('/jsonapi/node/article'));
 
$this->assertSession()->statusCodeEquals(200);
 
 
// Confirm the default behavior (no change from core).
 
$this->checkForLinksPresent($uuid, FALSE);
 
 
$this->drupalLogin($this->adminUser);
 
$this->drupalGet('/admin/config/services/jsonapi/links');
 
$form_values = [
 
'edit-remove-links' => 1,
 
];
 
$this->submitForm($form_values, t('Save configuration'));
 
 
// Verify that the configuration value is set.
 
$this->assertTrue($this->config($this->configName)->get($this->configRemoveLinks));
 
 
// Ensure links are removed as expected.
 
$this->checkForLinksPresent($uuid, TRUE);
 
 
// Disable link removal with JSON:API Links.
 
 
$this->drupalGet('/admin/config/services/jsonapi/links');
 
$form_values = [
 
'edit-remove-links' => 0,
 
];
 
$this->submitForm($form_values, t('Save configuration'));
 
 
// Verify that the configuration value is set.
 
$this->assertFalse($this->config($this->configName)->get($this->configRemoveLinks));
 
// Logout to refresh cache.
 
$this->drupalLogout();
 
 
// Ensure that the prior behavior has been restored.
 
$this->checkForLinksPresent($uuid, FALSE);
 
}
 
 
/**
 
* Confirms that link attributes are present or absent.
 
*
 
* @param string $uuid
 
* The uuid of the article.
 
* @param bool $links_removed
 
* TRUE if links should be removed; FALSE otherwise.
 
*/
 
private function checkForLinksPresent(string $uuid, bool $links_removed): void {
 
// 6. Single relationship item.
 
$drupal_response1 = $this->drupalGet('/jsonapi/node/article/' . $uuid);
 
$single_output = json_decode($drupal_response1, TRUE);
 
$this->assertSession()->statusCodeEquals(200);
 
$this->assertLinksRemoved($single_output, $links_removed);
 
// 11. Includes with relationships.
 
$drupal_response2 = $this->drupalGet('/jsonapi/node/article/' . $uuid . '/relationships/uid', [
 
'query' => ['include' => 'uid'],
 
]);
 
$output_with_relationships = json_decode($drupal_response2, TRUE);
 
$this->assertSession()->statusCodeEquals(200);
 
$this->assertLinksRemoved($output_with_relationships, $links_removed);
 
}
 
 
/**
 
* Asserts that links are removed or present depending on the module setting.
 
*
 
* @param array $drupal_jsonapi_response
 
* The Drupal JSON:API response to check.
 
* @param bool $links_should_be_removed
 
* TRUE if links attributes should be removed.
 
*/
 
private function assertLinksRemoved(array $drupal_jsonapi_response, bool $links_should_be_removed): void {
 
// Merge the includes into the response data because we want to make sure
 
// that the links attribute has also been removed from includes.
 
$response_content = $drupal_jsonapi_response['data'];
 
if (isset($drupal_jsonapi_response['included'])) {
 
$response_content = array_merge($response_content, $drupal_jsonapi_response['included']);
 
}
 
$first_item = json_encode($response_content);
 
if ($links_should_be_removed) {
 
// Links attribute should be removed from each item.
 
$this->assertDoesNotMatchRegularExpression('/links/', $first_item);
 
}
 
else {
 
$this->assertMatchesRegularExpression('/links/', $first_item);
 
}
 
// Links attribute of response should never be removed.
 
$this->assertArrayHasKey('links', $drupal_jsonapi_response);
 
}
 
 
}
Loading