| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | <?php/** * @file * Tests for color module. *//** * Tests the Color module functionality. */class ColorTestCase extends DrupalWebTestCase {  protected $big_user;  protected $themes;  protected $colorTests;  public static function getInfo() {    return array(      'name' => 'Color functionality',      'description' => 'Modify the Bartik and Garland theme colors and make sure the changes are reflected on the frontend',      'group' => 'Color',    );  }  function setUp() {    parent::setUp('color');    // Create users.    $this->big_user = $this->drupalCreateUser(array('administer themes'));    // This tests the color module in both Bartik and Garland.    $this->themes = array(      'bartik' => array(        'palette_input' => 'palette[bg]',        'scheme' => 'slate',        'scheme_color' => '#3b3b3b',      ),      'garland' => array(        'palette_input' => 'palette[link]',        'scheme' => 'greenbeam',        'scheme_color' => '#0c7a00',      ),    );    theme_enable(array_keys($this->themes));    // Array filled with valid and not valid color values    $this->colorTests = array(      '#000' => TRUE,      '#123456' => TRUE,      '#abcdef' => TRUE,      '#0' => FALSE,      '#00' => FALSE,      '#0000' => FALSE,      '#00000' => FALSE,      '123456' => FALSE,      '#00000g' => FALSE,    );  }  /**   * Tests the Color module functionality.   */  function testColor() {    foreach ($this->themes as $theme => $test_values) {      $this->_testColor($theme, $test_values);    }  }  /**   * Tests the Color module functionality using the given theme.   */  function _testColor($theme, $test_values) {    variable_set('theme_default', $theme);    $settings_path = 'admin/appearance/settings/' . $theme;    $this->drupalLogin($this->big_user);    $this->drupalGet($settings_path);    $this->assertResponse(200);    $edit['scheme'] = '';    $edit[$test_values['palette_input']] = '#123456';    $this->drupalPost($settings_path, $edit, t('Save configuration'));    $this->drupalGet('<front>');    $stylesheets = variable_get('color_' . $theme . '_stylesheets', array());    $this->assertPattern('|' . file_create_url($stylesheets[0]) . '|', 'Make sure the color stylesheet is included in the content. (' . $theme . ')');    $stylesheet_content = join("\n", file($stylesheets[0]));    $this->assertTrue(strpos($stylesheet_content, 'color: #123456') !== FALSE, 'Make sure the color we changed is in the color stylesheet. (' . $theme . ')');    $this->drupalGet($settings_path);    $this->assertResponse(200);    $edit['scheme'] = $test_values['scheme'];    $this->drupalPost($settings_path, $edit, t('Save configuration'));    $this->drupalGet('<front>');    $stylesheets = variable_get('color_' . $theme . '_stylesheets', array());    $stylesheet_content = join("\n", file($stylesheets[0]));    $this->assertTrue(strpos($stylesheet_content, 'color: ' . $test_values['scheme_color']) !== FALSE, 'Make sure the color we changed is in the color stylesheet. (' . $theme . ')');    // Test with aggregated CSS turned on.    variable_set('preprocess_css', 1);    $this->drupalGet('<front>');    $stylesheets = variable_get('drupal_css_cache_files', array());    $stylesheet_content = '';    foreach ($stylesheets as $key => $uri) {      $stylesheet_content .= join("\n", file(drupal_realpath($uri)));    }    $this->assertTrue(strpos($stylesheet_content, 'public://') === FALSE, 'Make sure the color paths have been translated to local paths. (' . $theme . ')');    variable_set('preprocess_css', 0);  }  /**   * Tests whether the provided color is valid.   */  function testValidColor() {    variable_set('theme_default', 'bartik');    $settings_path = 'admin/appearance/settings/bartik';    $this->drupalLogin($this->big_user);    $edit['scheme'] = '';    foreach ($this->colorTests as $color => $is_valid) {      $edit['palette[bg]'] = $color;      $this->drupalPost($settings_path, $edit, t('Save configuration'));      if($is_valid) {        $this->assertText('The configuration options have been saved.');      }      else {        $this->assertText('Main background must be a valid hexadecimal CSS color value.');      }    }  }}
 |