support-2.0.x-dev/modules/support_ticket/tests/Tests/SupportTicketAccessTest.php

modules/support_ticket/tests/Tests/SupportTicketAccessTest.php
<?php

namespace Drupal\support_ticket\Tests;

use Drupal\user\RoleInterface;

/**
 * Tests basic support_ticket_access functionality.
 *
 * Note that hook_support_ticket_access_records() is covered in another
 * test class.
 *
 * @group support
 * @todo Cover hook_support_ticket_access in a separate test class.
 */
class SupportTicketAccessTest extends SupportTicketTestBase {

  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    // Clear permissions for authenticated users.
    $this->config('user.role.' . RoleInterface::AUTHENTICATED_ID)->set('permissions', [])->save();
  }

  /**
   * Runs basic tests for support_ticket_access function.
   */
  public function testSupportTicketAccess() {
    // Ensures user without 'access ticket' permission can do nothing.
    $web_user1 = $this->drupalCreateUser(
      ['create ticket ticket',
        'edit any ticket ticket',
        'delete any ticket ticket',
      ]
    );
    $support_ticket1 = $this->drupalCreateSupportTicket(['type' => 'ticket']);
    $this->assertSupportTicketCreateAccess($support_ticket1->bundle(), FALSE, $web_user1);
    $this->assertSupportTicketAccess(
      [
        'view' => FALSE,
        'update' => FALSE,
        'delete' => FALSE,
      ],
      $support_ticket1, $web_user1);

    // Ensures user with 'bypass support_ticket access' permission can do
    // everything.
    $web_user2 = $this->drupalCreateUser(['bypass support_ticket access']);
    $support_ticket2 = $this->drupalCreateSupportTicket(['type' => 'ticket']);
    $this->assertSupportTicketCreateAccess($support_ticket2->bundle(), TRUE, $web_user2);
    $this->assertSupportTicketAccess(
      [
        'view' => TRUE,
        'update' => TRUE,
        'delete' => TRUE,
      ],
      $support_ticket2, $web_user2);

    // User cannot 'view own unpublished ticket'.
    $web_user3 = $this->drupalCreateUser(['access support tickets']);
    $support_ticket3 = $this->drupalCreateSupportTicket(
      ['status' => 0, 'uid' => $web_user3->id()]);
    $this->assertSupportTicketAccess(
      ['view' => FALSE], $support_ticket3, $web_user3);

    // User cannot create ticket without permission.
    $this->assertSupportTicketCreateAccess($support_ticket3->bundle(), FALSE, $web_user3);

    // User can 'view own unpublished ticket', but another user cannot.
    $web_user4 = $this->drupalCreateUser(
      [
        'access support tickets',
        'view own unpublished support tickets',
      ]
    );
    $web_user5 = $this->drupalCreateUser(
      [
        'access support tickets',
        'view own unpublished support tickets',
      ]
    );
    $support_ticket4 = $this->drupalCreateSupportTicket(
      ['status' => 0, 'uid' => $web_user4->id()]);
    $this->assertSupportTicketAccess(
      ['view' => TRUE, 'update' => FALSE],
      $support_ticket4, $web_user4);
    $this->assertSupportTicketAccess(
      ['view' => FALSE],
      $support_ticket4, $web_user5);

    // Tests the default access provided for a published support_ticket.
    $support_ticket5 = $this->drupalCreateSupportTicket();
    $this->assertSupportTicketAccess(
      ['view' => TRUE, 'update' => FALSE, 'delete' => FALSE],
      $support_ticket5, $web_user3);

    // Tests the "edit any BUNDLE" and "delete any BUNDLE" permissions.
    $web_user6 = $this->drupalCreateUser(
      [
        'access support tickets',
        'edit any ticket ticket',
        'delete any ticket ticket',
      ]
    );
    $support_ticket6 = $this->drupalCreateSupportTicket(['type' => 'ticket']);
    $this->assertSupportTicketAccess(
      ['view' => TRUE, 'update' => TRUE, 'delete' => TRUE],
      $support_ticket6, $web_user6);

    // Tests the "edit own BUNDLE" and "delete own BUNDLE" permission.
    $web_user7 = $this->drupalCreateUser(
      [
        'access support tickets',
        'edit own ticket ticket',
        'delete own ticket ticket',
      ]
    );
    // User should not be able to edit or delete support_tickets
    // they do not own.
    $this->assertSupportTicketAccess(
      ['view' => TRUE, 'update' => FALSE, 'delete' => FALSE],
      $support_ticket6, $web_user7);

    // User should be able to edit or delete support_tickets they own.
    $support_ticket7 = $this->drupalCreateSupportTicket(
      ['type' => 'ticket', 'uid' => $web_user7->id()]);
    $this->assertSupportTicketAccess(
      ['view' => TRUE, 'update' => TRUE, 'delete' => TRUE],
      $support_ticket7, $web_user7);
  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc