public function OptimizelyAddUpdateTest::testAddUpdateProject in Optimizely 8.0
Same name and namespace in other branches
- 8.3 src/Tests/OptimizelyAddUpdateTest.php \Drupal\optimizely\Tests\OptimizelyAddUpdateTest::testAddUpdateProject()
- 8 src/Tests/OptimizelyAddUpdateTest.php \Drupal\optimizely\Tests\OptimizelyAddUpdateTest::testAddUpdateProject()
File
- src/
Tests/ OptimizelyAddUpdateTest.php, line 69 - Contains \Drupal\optimizely\Tests\OptimizelyAddUpdateTest
Class
- OptimizelyAddUpdateTest
- Test adding a project with a path that is an alias.
Namespace
Drupal\optimizely\TestsCode
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 = array(
'type' => 'page',
'title' => $this
->randomMachineName(32),
'langcode' => \Drupal\Core\Language\LanguageInterface::LANGCODE_NOT_SPECIFIED,
'body' => array(
array(
'value' => $this
->randomMachineName(64),
'format' => filter_default_format(),
),
),
);
$node1 = $this
->drupalCreateNode($settings);
// Create the url alias
$edit_node1 = array();
$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 = array(
'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 = db_query('SELECT project_title FROM {optimizely} WHERE project_title = :optimizely_project_title', array(
':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 = array(
'type' => 'page',
'title' => $this
->randomMachineName(32),
'langcode' => \Drupal\Core\Language\LanguageInterface::LANGCODE_NOT_SPECIFIED,
'body' => array(
array(
'value' => $this
->randomMachineName(64),
'format' => filter_default_format(),
),
),
);
$node2 = $this
->drupalCreateNode($settings_2);
// Create another url alias
$edit_node2 = array();
$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 = array(
'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 = db_query('SELECT project_title FROM {optimizely} WHERE project_title = :optimizely_project_title', array(
':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');
}