View source
<?php
namespace Drupal\Tests\workbench_access\Functional;
use Drupal\taxonomy\Entity\Term;
use Drupal\Tests\BrowserTestBase;
use Drupal\workbench_access\WorkbenchAccessManagerInterface;
use Drupal\Tests\workbench_access\Traits\WorkbenchAccessTestTrait;
class AccessCacheTest extends BrowserTestBase {
use WorkbenchAccessTestTrait;
public static $modules = [
'workbench_access',
'node',
'taxonomy',
'options',
'user',
'system',
];
protected $defaultTheme = 'stable';
public function testNodeEdit() {
$node_type = $this
->createContentType([
'type' => 'page',
]);
$vocab = $this
->setUpVocabulary();
$field_name = WorkbenchAccessManagerInterface::FIELD_NAME;
$title = 'Section';
$cardinality = -1;
$field = $this
->setUpTaxonomyFieldForEntityType('node', $node_type
->id(), $vocab
->id(), $field_name, $title, $cardinality);
$this
->assertEqual($field
->getDefaultValueLiteral(), []);
$scheme = $this
->setUpTaxonomyScheme($node_type, $vocab);
$user_storage = \Drupal::service('workbench_access.user_section_storage');
$role_storage = \Drupal::service('workbench_access.role_section_storage');
$editor = $this
->setUpEditorUser();
$this
->drupalLogin($editor);
$staff_term = Term::create([
'vid' => $vocab
->id(),
'name' => 'Staff',
]);
$staff_term
->save();
$super_staff_term = Term::create([
'vid' => $vocab
->id(),
'name' => 'Super staff',
]);
$super_staff_term
->save();
$base_term = Term::create([
'vid' => $vocab
->id(),
'name' => 'Editor',
]);
$base_term
->save();
$user_storage
->addUser($scheme, $editor, [
$base_term
->id(),
]);
$expected = [
$editor
->id(),
];
$existing_users = $user_storage
->getEditors($scheme, $base_term
->id());
$this
->assertEquals($expected, array_keys($existing_users));
$node_values = [
'type' => 'page',
'title' => 'foo',
$field_name => [
$super_staff_term
->id(),
$staff_term
->id(),
],
];
$node = $this
->createNode($node_values);
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(403);
$user_storage
->addUser($scheme, $editor, [
$super_staff_term
->id(),
$base_term
->id(),
]);
$this
->assertEquals($expected, array_keys($existing_users));
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(200);
$user_storage
->removeUser($scheme, $editor, [
$super_staff_term
->id(),
]);
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(403);
$role_storage
->addRole($scheme, 'editor', [
$super_staff_term
->id(),
]);
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(200);
$role_storage
->removeRole($scheme, 'editor', [
$super_staff_term
->id(),
]);
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(403);
$user_storage
->addUser($scheme, $editor, [
$super_staff_term
->id(),
]);
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(200);
$super_staff_term
->delete();
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(403);
$node_values = [
'type' => 'page',
'title' => 'foo2',
$field_name => [
$base_term
->id(),
$staff_term
->id(),
],
];
$node2 = $this
->createNode($node_values);
$this
->drupalGet('node/' . $node2
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(200);
$user_storage
->removeUser($scheme, $editor, [
$base_term
->id(),
]);
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(403);
$scheme
->delete();
$this
->drupalGet('node/' . $node
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(200);
$this
->drupalGet('node/' . $node2
->id() . '/edit');
$this
->assertSession()
->statusCodeEquals(200);
}
}