You are here

public function OptimizelyAddUpdateTest::testAddUpdateProject in Optimizely 8.3

Same name and namespace in other branches
  1. 8 src/Tests/OptimizelyAddUpdateTest.php \Drupal\optimizely\Tests\OptimizelyAddUpdateTest::testAddUpdateProject()
  2. 8.0 src/Tests/OptimizelyAddUpdateTest.php \Drupal\optimizely\Tests\OptimizelyAddUpdateTest::testAddUpdateProject()

Test adding and updating a project.

File

src/Tests/OptimizelyAddUpdateTest.php, line 67

Class

OptimizelyAddUpdateTest
Test adding a project with a path that is an alias.

Namespace

Drupal\optimizely\Tests

Code

public function testAddUpdateProject() {
  $this
    ->drupalLogin($this->privilegedUser);

  // N.B. Do NOT use randomString() to generate string values because the
  // resulting strings may contain special chars that break the SQL
  // statements as well as possibly causing other problems.
  // Use randomMachineName() instead since it generates letters and
  // numbers only.
  //
  // ----- create page.
  $settings = [
    'type' => 'page',
    'title' => $this
      ->randomMachineName(32),
    'langcode' => LanguageInterface::LANGCODE_NOT_SPECIFIED,
    'body' => [
      [
        'value' => $this
          ->randomMachineName(64),
        'format' => filter_default_format(),
      ],
    ],
  ];
  $node1 = $this
    ->drupalCreateNode($settings);

  // Create the url alias.
  $edit_node1 = [];
  $edit_node1['source'] = '/node/' . $node1
    ->id();
  $edit_node1['alias'] = '/' . $this
    ->randomMachineName(10);
  $this
    ->drupalPostForm($this->addAliasPage, $edit_node1, t('Save'));

  // Add a project with a path to the alias.
  $edit = [
    'optimizely_project_title' => $this
      ->randomMachineName(8),
    'optimizely_project_code' => rand(0, 10000),
    'optimizely_path' => $edit_node1['alias'],
    'optimizely_enabled' => rand(0, 1),
  ];
  $this
    ->drupalPostForm($this->addUpdatePage, $edit, t('Add'));
  $project_title = \Drupal::database()
    ->query('SELECT project_title FROM {optimizely} WHERE project_title = :optimizely_project_title', [
    ':optimizely_project_title' => $edit['optimizely_project_title'],
  ])
    ->fetchField();
  $this
    ->assertEqual($project_title, $edit['optimizely_project_title'], t('<strong>The project was added to the database.</strong>'), 'Optimizely');

  // ----- create page.
  $settings_2 = [
    'type' => 'page',
    'title' => $this
      ->randomMachineName(32),
    'langcode' => LanguageInterface::LANGCODE_NOT_SPECIFIED,
    'body' => [
      [
        'value' => $this
          ->randomMachineName(64),
        'format' => filter_default_format(),
      ],
    ],
  ];
  $node2 = $this
    ->drupalCreateNode($settings_2);

  // Create another url alias.
  $edit_node2 = [];
  $edit_node2['source'] = '/node/' . $node2
    ->id();
  $edit_node2['alias'] = '/' . $this
    ->randomMachineName(10);
  $this
    ->drupalPostForm($this->addAliasPage, $edit_node2, t('Save'));

  // Update the existing project with the other alias.
  $edit_2 = [
    'optimizely_project_title' => $this
      ->randomMachineName(8),
    'optimizely_project_code' => rand(0, 10000),
    'optimizely_path' => $edit_node2['alias'],
    'optimizely_enabled' => rand(0, 1),
  ];
  $this
    ->drupalPostForm($this->update2Page, $edit_2, t('Update'));

  // Test if database was updated.
  $project_title = \Drupal::database()
    ->query('SELECT project_title FROM {optimizely} WHERE project_title = :optimizely_project_title', [
    ':optimizely_project_title' => $edit_2['optimizely_project_title'],
  ])
    ->fetchField();
  $this
    ->assertEqual($project_title, $edit_2['optimizely_project_title'], t('<strong>The project was updated in the database.</strong>'), 'Optimizely');
}