-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
* [#408] Fix team lists cache errors. * [#408] Fix team lists cache errors - updated cache tags. * [#408] Fix team lists cache errors - updates and test. * [#408] Fix team lists cache errors - updates and test. * [#408] Fix team lists cache errors - fixing phpcs. * [#408] Fix tests. * [#408] Fix tests.
- Loading branch information
1 parent
6e17213
commit f62b71f
Showing
8 changed files
with
344 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
238 changes: 238 additions & 0 deletions
238
modules/apigee_edge_teams/tests/src/Functional/TeamListBuilderTest.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,238 @@ | ||
<?php | ||
|
||
/** | ||
* Copyright 2020 Google Inc. | ||
* | ||
* This program is free software; you can redistribute it and/or modify it under | ||
* the terms of the GNU General Public License version 2 as published by the | ||
* Free Software Foundation. | ||
* | ||
* This program is distributed in the hope that it will be useful, but WITHOUT | ||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY | ||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public | ||
* License for more details. | ||
* | ||
* You should have received a copy of the GNU General Public License along | ||
* with this program; if not, write to the Free Software Foundation, Inc., 51 | ||
* Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||
*/ | ||
|
||
namespace Drupal\Tests\apigee_edge_teams\Functional; | ||
|
||
use Drupal\apigee_edge\Entity\Developer; | ||
use Drupal\Core\Url; | ||
use Symfony\Component\HttpFoundation\Response; | ||
|
||
/** | ||
* Apigee Edge Teams list builder tests. | ||
* | ||
* @group apigee_edge | ||
* @group apigee_edge_teams | ||
*/ | ||
class TeamListBuilderTest extends ApigeeEdgeTeamsFunctionalTestBase { | ||
|
||
/** | ||
* Indicates this test class is mock API client ready. | ||
* | ||
* @var bool | ||
*/ | ||
protected static $mock_api_client_ready = TRUE; | ||
|
||
/** | ||
* {@inheritdoc} | ||
*/ | ||
protected static $modules = [ | ||
'system', | ||
'user', | ||
'options', | ||
'key', | ||
'apigee_edge', | ||
'apigee_edge_teams', | ||
'apigee_mock_api_client', | ||
]; | ||
|
||
/** | ||
* The team entity storage. | ||
* | ||
* @var \Drupal\apigee_edge_teams\Entity\Storage\TeamStorageInterface | ||
*/ | ||
protected $teamStorage; | ||
|
||
/** | ||
* The user 1 account. | ||
* | ||
* @var \Drupal\user\UserInterface | ||
*/ | ||
protected $account; | ||
|
||
/** | ||
* Drupal user who is a member team A. | ||
* | ||
* @var \Drupal\user\UserInterface | ||
*/ | ||
protected $aMemberAccount; | ||
|
||
/** | ||
* Drupal user who is a member team B. | ||
* | ||
* @var \Drupal\user\UserInterface | ||
*/ | ||
protected $bMemberAccount; | ||
|
||
/** | ||
* Drupal user who is an admin. | ||
* | ||
* @var \Drupal\user\UserInterface | ||
*/ | ||
protected $cMemberAccount; | ||
|
||
/** | ||
* Team A entity to test. | ||
* | ||
* @var \Drupal\apigee_edge_teams\Entity\TeamInterface | ||
*/ | ||
protected $teamA; | ||
|
||
/** | ||
* Team B entity to test. | ||
* | ||
* @var \Drupal\apigee_edge_teams\Entity\TeamInterface | ||
*/ | ||
protected $teamB; | ||
|
||
/** | ||
* A role. | ||
* | ||
* @var \Drupal\user\Entity\Role | ||
*/ | ||
protected $customRole; | ||
|
||
/** | ||
* {@inheritdoc} | ||
*/ | ||
protected function setUp() { | ||
parent::setUp(); | ||
|
||
$this->addOrganizationMatchedResponse(); | ||
|
||
$this->teamStorage = $this->entityTypeManager->getStorage('team'); | ||
|
||
$config_factory = \Drupal::configFactory(); | ||
$config = $config_factory->getEditable('apigee_edge_teams.team_settings'); | ||
$config->set('cache_expiration', 300); | ||
$config->save(TRUE); | ||
|
||
// Create accounts: user 1, for members of two teams, and an extra one. | ||
$this->account = $this->rootUser; | ||
$this->aMemberAccount = $this->createNewAccount(); | ||
$this->bMemberAccount = $this->createNewAccount(); | ||
$this->cMemberAccount = $this->createNewAccount(); | ||
|
||
$this->customRole = $this->drupalCreateRole(['view any team']); | ||
|
||
// Create teams. | ||
$this->teamA = $this->createTeam(); | ||
$this->teamB = $this->createTeam(); | ||
|
||
// Add accounts to teams. | ||
$this->addUserToTeam($this->teamA, $this->aMemberAccount); | ||
$this->addUserToTeam($this->teamB, $this->bMemberAccount); | ||
} | ||
|
||
/** | ||
* {@inheritdoc} | ||
*/ | ||
protected function tearDown() { | ||
try { | ||
$this->teamStorage->delete([$this->teamA, $this->teamB]); | ||
$this->account->delete(); | ||
$this->aMemberAccount->delete(); | ||
$this->bMemberAccount->delete(); | ||
$this->cMemberAccount->delete(); | ||
} | ||
catch (\Error $error) { | ||
// Do nothing. | ||
} | ||
catch (\Exception $exception) { | ||
// Do nothing. | ||
} | ||
} | ||
|
||
/** | ||
* Tests team list cache. | ||
*/ | ||
public function testTeamListCache() { | ||
$companies = [ | ||
$this->teamA->decorated(), | ||
$this->teamB->decorated(), | ||
]; | ||
|
||
// aMemberAccount should only see teamA. | ||
$this->drupalLogin($this->aMemberAccount); | ||
$this->queueCompaniesResponse($companies); | ||
$this->queueDeveloperResponse($this->aMemberAccount, 200, ['companies' => [$this->teamA->id()]]); | ||
$this->drupalGet(Url::fromRoute('entity.team.collection')); | ||
$assert = $this->assertSession(); | ||
$assert->pageTextContains($this->teamA->label()); | ||
$assert->pageTextNotContains($this->teamB->label()); | ||
$this->drupalLogout(); | ||
|
||
// bMemberAccount should only see teamB. | ||
$this->drupalLogin($this->bMemberAccount); | ||
$this->queueCompaniesResponse($companies); | ||
$this->queueDeveloperResponse($this->bMemberAccount, 200, ['companies' => [$this->teamB->id()]]); | ||
$this->drupalGet(Url::fromUserInput('/teams')); | ||
$assert = $this->assertSession(); | ||
$assert->pageTextNotContains($this->teamA->label()); | ||
$assert->pageTextContains($this->teamB->label()); | ||
$this->drupalLogout(); | ||
|
||
// cMemberAccount should not see any teams. | ||
$this->drupalLogin($this->cMemberAccount); | ||
$this->queueCompaniesResponse($companies); | ||
$this->queueDeveloperResponse($this->cMemberAccount); | ||
$this->queueDeveloperResponse($this->cMemberAccount); | ||
$this->drupalGet(Url::fromUserInput('/teams')); | ||
$assert = $this->assertSession(); | ||
$assert->pageTextNotContains($this->teamA->label()); | ||
$assert->pageTextNotContains($this->teamB->label()); | ||
|
||
// Give cMemberAccount permission to view all teams. | ||
$this->cMemberAccount->addRole($this->customRole); | ||
$this->cMemberAccount->save(); | ||
|
||
// cMemberAccount should see both teams now. | ||
$this->queueCompaniesResponse($companies); | ||
$this->drupalGet(Url::fromUserInput('/teams')); | ||
$assert = $this->assertSession(); | ||
$assert->pageTextContains($this->teamA->label()); | ||
$assert->pageTextContains($this->teamB->label()); | ||
} | ||
|
||
/** | ||
* Helper function to create a random user account. | ||
* | ||
* @return \Drupal\Core\Entity\EntityInterface | ||
* The user account. | ||
*/ | ||
protected function createNewAccount() { | ||
$this->disableUserPresave(); | ||
$account = $this->createAccount(); | ||
|
||
$fields = [ | ||
'email' => $account->getEmail(), | ||
'userName' => $account->getAccountName(), | ||
'firstName' => $this->getRandomGenerator()->word(8), | ||
'lastName' => $this->getRandomGenerator()->word(8), | ||
]; | ||
|
||
// Stack developer responses for "created" and "set active". | ||
$this->queueDeveloperResponse($account, Response::HTTP_CREATED); | ||
$this->stack->queueMockResponse('no_content'); | ||
$developer = Developer::create($fields); | ||
$developer->save(); | ||
|
||
return $account; | ||
} | ||
|
||
} |
19 changes: 19 additions & 0 deletions
19
tests/modules/apigee_mock_api_client/tests/response-templates/companies.json.twig
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
{# | ||
/** | ||
* @file | ||
* Companies | ||
* | ||
* Usage: | ||
* @code {% include 'companies.json.twig' %} @endcode | ||
* | ||
* Variables: | ||
* - companies: an array of company objects. | ||
*/ | ||
#} | ||
{ | ||
"company" : [ | ||
{% for company in companies %} | ||
{% include 'company.json.twig' with {'company': company} %}{{ loop.last ? '' : ',' }} | ||
{% endfor %} | ||
] | ||
} |
Oops, something went wrong.