Skip to content
Snippets Groups Projects
Commit cd28e3b9 authored by Patrick Kenny's avatar Patrick Kenny
Browse files

Merge branch 'unit_test' into '1.1.x'

add unit test to confirm core functionality

See merge request !27
parents 15934104 cd235d50
No related branches found
No related tags found
No related merge requests found
Pipeline #388306 failed
......@@ -38,7 +38,7 @@ phpstan:
variables:
_CSPELL_WORDS: 'Kravchuk,ptmkenny,Taras,tarik'
OPT_IN_TEST_NEXT_MINOR: '1'
OPT_IN_TEST_PREV_MAJOR: '1'
OPT_IN_TEST_PREVIOUS_MAJOR: '1'
# SKIP_ESLINT: '1'
# OPT_IN_TEST_NEXT_MAJOR: '1'
# _CURL_TEMPLATES_REF: 'main'
<?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);
}
}
<?php
declare(strict_types=1);
namespace Drupal\Tests\jsonapi_links\Functional;
use Drupal\Core\Url;
use Drupal\Tests\BrowserTestBase;
use Drupal\user\UserInterface;
/**
* Simple test to ensure that main page loads with module enabled.
*
* @group jsonapi_links
*/
class LoadTest extends BrowserTestBase {
/**
* Modules to enable.
*
* @var array
*/
protected static $modules = ['jsonapi_links'];
/**
* The default theme when not relying on core markup.
*
* @var string
*/
protected $defaultTheme = 'stark';
/**
* A user with permission to administer site configuration.
*
* @var \Drupal\user\UserInterface
*/
protected UserInterface $user;
/**
* {@inheritdoc}
*/
#[\Override]
protected function setUp(): void {
parent::setUp();
$this->user = $this->drupalCreateUser(['administer site configuration']);
$this->drupalLogin($this->user);
}
/**
* Tests that the home page loads with a 200 response.
*/
public function testLoad(): void {
$this->drupalGet(Url::fromRoute('<front>'));
$this->assertSession()->statusCodeEquals(200);
}
}
......@@ -11,7 +11,7 @@ use Drupal\KernelTests\KernelTestBase;
*
* @group jsonapi_links
*/
class JsonapiLinksInstallTest extends KernelTestBase {
class JsonApiLinksInstallTest extends KernelTestBase {
private const string MODULE_NAME = 'jsonapi_links';
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment