backup_migrate-5.0.0-rc2/tests/src/Functional/AdminFunctionalityTest.php

tests/src/Functional/AdminFunctionalityTest.php
<?php

namespace Drupal\Tests\backup_migrate\Functional;

use Drupal\Core\File\FileSystemInterface;
use Drupal\Tests\BrowserTestBase;

/**
 * Checks if admin functionality works correctly.
 *
 * @group backup_migrate
 */
class AdminFunctionalityTest extends BrowserTestBase {

  /**
   * {@inheritdoc}
   */
  protected static $modules = ['backup_migrate', 'test_page_test'];

  /**
   * {@inheritdoc}
   */
  protected $strictConfigSchema = FALSE;

  /**
   * {@inheritdoc}
   */
  protected $defaultTheme = 'stark';

  /**
   * {@inheritdoc}
   */
  public function setUp(): void {
    parent::setUp();
    $this->container->get('router.builder')->rebuild();

    // Set test-page as front page:
    $this->config('system.site')->set('page.front', '/test-page')->save();

    // Ensure backup_migrate folder exists, the
    // `admin/config/development/backup_migrate/backups` path will fail without
    // this.
    $path = 'private://backup_migrate/';
    \Drupal::service('file_system')->prepareDirectory($path, FileSystemInterface::CREATE_DIRECTORY);

    // Log in an admin user.
    $account = $this->drupalCreateUser([
      'access backup files',
      'administer backup and migrate',
      'perform backup',
      'restore from backup',
      // Used to access the system cron page.
      'administer site configuration',
    ]);
    $this->drupalLogin($account);
  }

  /**
   * Tests each of the admin pages loads correctly.
   *
   * This is to be used until all of the admin functionality has separate.
   *
   * @param string $path
   *   The path to check.
   * @param string $string_on_page
   *   A string to look for on the page above..
   *
   * @dataProvider pagesListProvider
   */
  public function testPages($path, $string_on_page) {
    $this->drupalGet($path);
    $this->assertSession()->statusCodeEquals(200);
    $this->assertSession()->pageTextContains($string_on_page);
  }

  /**
   * A list of paths to check and a string that should be present on that page.
   *
   * @return array
   *   A list of paths with a string that should be present on that page.
   */
  public static function pagesListProvider(): array {
    return [
      ['admin/config/development/backup_migrate', 'Quick Backup'],
      ['admin/config/development/backup_migrate/advanced', 'Advanced Backup'],
      ['admin/config/development/backup_migrate/restore', 'Restore'],
      ['admin/config/development/backup_migrate/backups', 'Backups'],
      ['admin/config/development/backup_migrate/schedule', 'Schedule'],
      ['admin/config/development/backup_migrate/schedule/add', 'Add schedule'],
      ['admin/config/development/backup_migrate/settings', 'Settings'],
      [
        'admin/config/development/backup_migrate/settings/add',
        'Add settings profile',
      ],
      [
        'admin/config/development/backup_migrate/settings/destination',
        'Backup Destination',
      ],
      [
        'admin/config/development/backup_migrate/settings/destination/add',
        'Add destination',
      ],
      [
        'admin/config/development/backup_migrate/settings/source',
        'Backup sources',
      ],
      [
        'admin/config/development/backup_migrate/settings/source/add',
        'Add Backup Source',
      ],
    ];
  }

  /**
   * Make sure the 'destinations' system works correctly.
   */
  public function testDestinationsAdmin() {
    // Load the destination page.
    // @todo Confirm the table only has one record.
    $this->drupalGet('admin/config/development/backup_migrate/settings/destination');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Backup Destination');
    $session->pageTextContains('Private Files Directory');
    $session->pageTextContains('private_files');
    $session->pageTextContains('Server File Directory');

    // Load the destination-add form.
    $this->drupalGet('admin/config/development/backup_migrate/settings/destination/add');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Add destination');
    $session->fieldExists('label');
    $session->fieldExists('id');
    $session->fieldExists('type');
    $session->buttonExists('Save and edit');

    // Create a new destination.
    $edit = [
      'label' => 'Test destination',
      'id' => 'test_destination',
      'type' => 'Directory',
    ];
    $this->submitForm($edit, 'Save and edit');

    // This should load a new version of the form with the directory filled in.
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings/destination/edit/test_destination');
    $session->pageTextContains('Created Test destination.');
    $session->fieldExists('label');
    $session->fieldExists('config[directory]');
    $session->buttonExists('Save');
    $session->linkExists('Delete');

    // Fill in a path.
    $edit = [
      'config[directory]' => 'test_path',
    ];
    $this->submitForm($edit, 'Save');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings/destination');
    $session->pageTextContains('Saved Test destination.');
    $session->pageTextContains('Private Files Directory');
    $session->pageTextContains('private_files');
    $session->pageTextContains('Test destination');
    $session->pageTextContains('test_destination');
  }

  /**
   * Make sure the 'sources' system works correctly.
   */
  public function testSourcesAdmin() {
    // Load the source page.
    $this->drupalGet('admin/config/development/backup_migrate/settings/source');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Backup Source');
    $session->pageTextContains('Default Drupal Database');
    $session->pageTextContains('default_db');
    $session->pageTextContains('Default Database');

    $session->pageTextContains('entire_site');
    $session->pageTextContains('Entire Site');

    $session->pageTextContains('Private Files Directory');
    $session->pageTextContains('private_files');
    $session->pageTextContains('Public Files');

    // @todo Confirm the table has four records.
    // Load the add source form.
    $this->drupalGet('admin/config/development/backup_migrate/settings/source/add');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Add Backup Source');
    $session->fieldExists('label');
    $session->fieldExists('type');
    $session->buttonExists('Save and edit');

    // Create a new source of type File Directory.
    $edit = [
      'label' => 'Test FileDirectory source',
      'id' => 'test_filedirectory_source',
      'type' => 'FileDirectory',
    ];
    $this->submitForm($edit, 'Save and edit');

    // This should load a new version of the form with the directory filled in.
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings/source/edit/test_filedirectory_source');
    $session->pageTextContains('Created Test FileDirectory source.');
    $session->fieldExists('label');
    $session->fieldExists('config[directory]');
    $session->buttonExists('Save');
    $session->linkExists('Delete');

    // Fill in a path.
    $edit = [
      'config[directory]' => 'test_path',
    ];
    $this->submitForm($edit, 'Save');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings/source');
    $session->pageTextContains('Saved Test FileDirectory source.');
    $session->pageTextContains('Default Drupal Database');
    $session->pageTextContains('default_db');
    $session->pageTextContains('Entire Site');
    $session->pageTextContains('entire_site');
    $session->pageTextContains('Private Files Directory');
    $session->pageTextContains('private_files');
    $session->pageTextContains('Test FileDirectory source');
    $session->pageTextContains('test_filedirectory_source');
    $session->pageTextContains('File Directory');

    // Load the add source form.
    $this->drupalGet('admin/config/development/backup_migrate/settings/source/add');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Add Backup Source');
    $session->fieldExists('label');
    $session->fieldExists('type');
    $session->buttonExists('Save and edit');

    // Create a new source of type MySQL Database.
    $edit = [
      'label' => 'Test MySQL source',
      'id' => 'test_mysql_source',
      'type' => 'MySQL',
    ];
    $this->submitForm($edit, 'Save and edit');

    // This should load a new version of the form with the directory filled in.
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings/source/edit/test_mysql_source');
    $session->pageTextContains('Created Test MySQL source.');
    $session->fieldExists('label');
    $session->fieldExists('config[host]');
    $session->fieldExists('config[database]');
    $session->fieldExists('config[username]');
    $session->fieldExists('config[password]');
    $session->fieldExists('config[port]');
    $session->buttonExists('Save');
    $session->linkExists('Delete');

    // Fill in fields with test values.
    $edit = [
      'config[host]' => 'test_host',
      'config[database]' => 'test_dbname',
      'config[username]' => 'test_user',
      'config[password]' => 'test_pw',
      'config[port]' => '12345',
    ];
    $this->submitForm($edit, 'Save');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings/source');
    $session->pageTextContains('Saved Test MySQL source.');
    $session->pageTextContains('Default Drupal Database');
    $session->pageTextContains('default_db');
    $session->pageTextContains('Entire Site');
    $session->pageTextContains('entire_site');
    $session->pageTextContains('Private Files Directory');
    $session->pageTextContains('private_files');
    $session->pageTextContains('Test MySQL source');
    $session->pageTextContains('test_mysql_source');
    $session->pageTextContains('MySQL Database');
  }

  /**
   * Make sure the 'schedules' system works correctly.
   */
  public function testSchedulesAdmin() {
    // Load the schedule page.
    // @todo Confirm the table only has one record.
    $this->drupalGet('admin/config/development/backup_migrate/schedule');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Schedule Name');
    $session->pageTextContains('Enabled');
    $session->pageTextContains('Frequency');
    $session->pageTextContains('Last Run');
    $session->pageTextContains('Next Run');
    $session->pageTextContains('Keep');
    $session->pageTextContains('Daily Schedule');
    $session->pageTextContains('No');
    $session->pageTextContains('Every 0 weeks');
    $session->pageTextContains('Never');
    $session->pageTextContains('Disabled');
    $session->pageTextContains('All backups');

    // Edit an existing schedule - turn on the default schedule.
    $this->drupalGet('admin/config/development/backup_migrate/schedule/edit/daily_schedule');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->fieldExists('Schedule enabled');
    $edit = [
      'enabled' => TRUE,
      'period_number' => 1,
      'period_type' => 'days',
    ];
    $this->submitForm($edit, 'Save');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Saved the Daily Schedule Schedule.');
    $session->pageTextContains('Yes');
    $session->pageTextContains('Daily');
    $session->pageTextContains('Never');
    $session->pageTextContains('Next cron run');
    $session->pageTextNotContains('Disabled');

    // Load the schedule-add form.
    $this->drupalGet('admin/config/development/backup_migrate/schedule/add');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Add schedule');
    $session->fieldExists('label');
    $session->fieldExists('id');
    $session->fieldExists('enabled');
    $session->fieldExists('source_id');
    $session->fieldExists('destination_id');
    $session->fieldExists('period_number');
    $session->fieldExists('period_type');
    $session->fieldExists('keep');
    $session->buttonExists('Save');

    // Create a new schedule.
    $edit = [
      'label' => 'Test schedule',
      'id' => 'test_schedule',
      'enabled' => TRUE,
      'source_id' => 'default_db',
      'destination_id' => 'private_files',
      'period_number' => 14400,
      'period_type' => 'minutes',
      'keep' => 1000,
    ];
    $this->submitForm($edit, 'Save');

    // Make sure the form saved correctly.
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/schedule');
    $session->pageTextContains('Created the Test schedule Schedule.');
    $session->pageTextContains('Every 10 days');
    $session->pageTextContains('Last 1000 backups');
    $session->pageTextContains('Yes');
  }

  /**
   * Make sure the 'profiles' system works correctly.
   */
  public function testProfilesAdmin() {
    // Load the profiles page.
    // @todo Confirm the table has no records.
    $this->drupalGet('admin/config/development/backup_migrate/settings');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Settings');
    $session->pageTextContains('Profile Name');

    // Load the profile-add form.
    $this->drupalGet('admin/config/development/backup_migrate/settings/add');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Add settings profile');
    $session->fieldExists('label');
    $session->fieldExists('id');
    $session->fieldExists('config[namer][filename]');
    $session->fieldExists('config[namer][timestamp]');
    $session->fieldExists('config[namer][timestamp_format]');
    $session->fieldExists('config[compressor][compression]');
    $session->fieldExists('config[utils][site_offline]');
    $session->fieldExists('config[metadata][description]');
    $session->fieldExists('config[db_exclude][exclude_tables][]');
    $session->fieldExists('config[db_exclude][nodata_tables][]');
    $session->fieldExists('config[private_files_exclude][exclude_filepaths]');
    $session->fieldExists('config[public_files_exclude][exclude_filepaths]');
    $session->buttonExists('Save');

    // Create a new profile.
    $edit = [
      'label' => 'Test profile',
      'id' => 'test_profile',
      'config[namer][filename]' => 'test_backup',
      'config[namer][timestamp]' => 'Y-m-d\TH-i-s',
      'config[compressor][compression]' => 'none',
      'config[utils][site_offline]' => 1,
      'config[metadata][description]' => 'Test description text.',
      'config[db_exclude][exclude_tables][]' => [],
      'config[db_exclude][nodata_tables][]' => [],
      'config[private_files_exclude][exclude_filepaths]' => 'test_private_exclude',
      'config[public_files_exclude][exclude_filepaths]' => 'test_public_exclude',
    ];
    $this->submitForm($edit, 'Save');

    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/config/development/backup_migrate/settings');
    $session->pageTextContains('Created the Test profile Settings Profile.');
    $session->pageTextContains('Profile Name');
    $session->pageTextContains('Machine name');
    $session->pageTextContains('Compression');
    $session->pageTextContains('Take site offline');
    $session->pageTextContains('Description');
    $session->pageTextContains('Test profile');
    $session->pageTextContains('test_profile');
    $session->pageTextContains('none');
    $session->pageTextContains('1');
    $session->pageTextContains('Test description text.');
  }

  /**
   * Run the system cron.
   */
  public function testCron() {
    // Turn on the default schedule.
    $this->drupalGet('admin/config/development/backup_migrate/schedule/edit/daily_schedule');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->fieldExists('Schedule enabled');
    $edit = [
      'enabled' => TRUE,
      'period_number' => 1,
      'period_type' => 'days',
    ];
    $this->submitForm($edit, 'Save');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('Saved the Daily Schedule Schedule.');
    $session->pageTextContains('Never');
    $session->pageTextContains('Next cron run');

    // Confirm the backup destination is empty.
    $this->drupalGet('admin/config/development/backup_migrate/settings/destination/backups/private_files');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextContains('There are no backups in this destination.');

    // Trigger cron.
    $this->drupalGet('admin/reports/status');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->linkExists('Run cron');
    $this->clickLink('Run cron');

    // Make sure that cron ran correctly.
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->addressEquals('admin/reports/status');
    $session->pageTextContains('Cron ran successfully.');

    // Check that the schedule is enabled.
    $this->drupalGet('admin/config/development/backup_migrate/schedule/edit/daily_schedule');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);

    // Confirm a backup was created.
    $this->drupalGet('admin/config/development/backup_migrate/settings/destination/backups/private_files');
    $session = $this->assertSession();
    $session->statusCodeEquals(200);
    $session->pageTextNotContains('There are no backups in this destination.');
  }

  /**
   * Tests the advanced backup.
   *
   * Tests the advanced backup using the "Take site offline" setting and
   * setting the Backup Destination to "Download".
   */
  public function testAdvancedBackupWithMaintenanceModeEnabledDestinationDownload() {
    $session = $this->assertSession();
    $page = $this->getSession()->getPage();
    // Got to the advance backup site and create a backup with taking the site
    // offline:
    $this->drupalGet('/admin/config/development/backup_migrate/advanced');
    $session->statusCodeEquals(200);
    $page->checkField('edit-utils-site-offline');
    $page->selectFieldOption('edit-destination-id', 'download');
    $page->pressButton('edit-submit');
    // Setting both the site offline and the destination to download should
    // not be allowed:
    $session->statusCodeEquals(200);
    $session->pageTextContains('The Backup Destination "Download" does not support taking the site offline during backup.');
    // Uncheck taking the site offline:
    $page->uncheckField('edit-utils-site-offline');
    $page->pressButton('edit-submit');
    // Check if the backup is downloaded now:
    $session->statusCodeEquals(200);
    $session->responseHeaderContains('Content-Disposition', 'attachment');
    // Check if the front page is still reachable after the backup:
    $this->drupalGet('<front>');
    $session->statusCodeEquals(200);
  }

  /**
   * Tests the advanced backup.
   *
   * Tests the advanced backup using the "Take site offline" setting and
   * setting the Backup Destination to "Private Files Directory".
   */
  public function testAdvancedBackupWithMaintenanceModeEnabledDestinationPrivate() {
    $session = $this->assertSession();
    $page = $this->getSession()->getPage();
    // Check if maintenance mode is currently disabled, note that as we have not
    // changed it yet, it will be NULL as it is uninitialized:
    $this->assertEmpty(\Drupal::state()->get('system.maintenance_mode'));
    // Got to the advance backup site and create a backup with taking the site
    // offline:
    $this->drupalGet('/admin/config/development/backup_migrate/advanced');
    $session->statusCodeEquals(200);
    $page->checkField('edit-utils-site-offline');
    $page->selectFieldOption('edit-destination-id', 'private_files');
    $page->pressButton('edit-submit');
    // Check if the backup was completed:
    $session->statusCodeEquals(200);
    $session->pageTextContains('Backup Complete.');
    // Maintenance mode should be disabled now, check the front page:
    $this->drupalGet('<front>');
    $session->statusCodeEquals(200);
    // It should be FALSE now, as it was enabled and then disabled:
    $this->assertFalse(\Drupal::state()->get('system.maintenance_mode'));
  }

}

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

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