| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 | 
							- <?php
 
- /**
 
-  * @file
 
-  * Tests for dashboard.module.
 
-  */
 
- /**
 
-  * Tests the Dashboard module blocks.
 
-  */
 
- class DashboardBlocksTestCase extends DrupalWebTestCase {
 
-   public static function getInfo() {
 
-     return array(
 
-       'name' => 'Dashboard blocks',
 
-       'description' => 'Test blocks as used by the dashboard.',
 
-       'group' => 'Dashboard',
 
-     );
 
-   }
 
-   function setUp() {
 
-     parent::setUp();
 
-     // Create and log in an administrative user having access to the dashboard.
 
-     $admin_user = $this->drupalCreateUser(array('access dashboard', 'administer blocks', 'access administration pages', 'administer modules'));
 
-     $this->drupalLogin($admin_user);
 
-     // Make sure that the dashboard is using the same theme as the rest of the
 
-     // site (and in particular, the same theme used on 403 pages). This forces
 
-     // the dashboard blocks to be the same for an administrator as for a
 
-     // regular user, and therefore lets us test that the dashboard blocks
 
-     // themselves are specifically removed for a user who does not have access
 
-     // to the dashboard page.
 
-     theme_enable(array('stark'));
 
-     variable_set('theme_default', 'stark');
 
-     variable_set('admin_theme', 'stark');
 
-   }
 
-   /**
 
-    * Tests adding a block to the dashboard and checking access to it.
 
-    */
 
-   function testDashboardAccess() {
 
-     // Add a new custom block to a dashboard region.
 
-     $custom_block = array();
 
-     $custom_block['info'] = $this->randomName(8);
 
-     $custom_block['title'] = $this->randomName(8);
 
-     $custom_block['body[value]'] = $this->randomName(32);
 
-     $custom_block['regions[stark]'] = 'dashboard_main';
 
-     $this->drupalPost('admin/structure/block/add', $custom_block, t('Save block'));
 
-     // Ensure admin access.
 
-     $this->drupalGet('admin/dashboard');
 
-     $this->assertResponse(200, 'Admin has access to the dashboard.');
 
-     $this->assertRaw($custom_block['title'], 'Admin has access to a dashboard block.');
 
-     // Ensure non-admin access is denied.
 
-     $normal_user = $this->drupalCreateUser();
 
-     $this->drupalLogin($normal_user);
 
-     $this->drupalGet('admin/dashboard');
 
-     $this->assertResponse(403, 'Non-admin has no access to the dashboard.');
 
-     $this->assertNoText($custom_block['title'], 'Non-admin has no access to a dashboard block.');
 
-   }
 
-   /**
 
-    * Tests that dashboard regions are displayed or hidden properly.
 
-    */
 
-   function testDashboardRegions() {
 
-     $dashboard_regions = dashboard_region_descriptions();
 
-     // Ensure blocks can be placed in dashboard regions.
 
-     $this->drupalGet('admin/dashboard/configure');
 
-     foreach ($dashboard_regions as $region => $description) {
 
-       $elements = $this->xpath('//option[@value=:region]', array(':region' => $region));
 
-       $this->assertTrue(!empty($elements), format_string('%region is an available choice on the dashboard block configuration page.', array('%region' => $region)));
 
-     }
 
-     // Ensure blocks cannot be placed in dashboard regions on the standard
 
-     // blocks configuration page.
 
-     $this->drupalGet('admin/structure/block');
 
-     foreach ($dashboard_regions as $region => $description) {
 
-       $elements = $this->xpath('//option[@value=:region]', array(':region' => $region));
 
-       $this->assertTrue(empty($elements), format_string('%region is not an available choice on the block configuration page.', array('%region' => $region)));
 
-     }
 
-   }
 
-   /**
 
-    * Tests that the dashboard module can be re-enabled, retaining its blocks.
 
-    */
 
-   function testDisableEnable() {
 
-     // Add a new custom block to a dashboard region.
 
-     $custom_block = array();
 
-     $custom_block['info'] = $this->randomName(8);
 
-     $custom_block['title'] = $this->randomName(8);
 
-     $custom_block['body[value]'] = $this->randomName(32);
 
-     $custom_block['regions[stark]'] = 'dashboard_main';
 
-     $this->drupalPost('admin/structure/block/add', $custom_block, t('Save block'));
 
-     $this->drupalGet('admin/dashboard');
 
-     $this->assertRaw($custom_block['title'], 'Block appears on the dashboard.');
 
-     $edit = array();
 
-     $edit['modules[Core][dashboard][enable]'] = FALSE;
 
-     $this->drupalPost('admin/modules', $edit, t('Save configuration'));
 
-     $this->assertText(t('The configuration options have been saved.'), 'Modules status has been updated.');
 
-     $this->assertNoRaw('assigned to the invalid region', 'Dashboard blocks gracefully disabled.');
 
-     module_list(TRUE);
 
-     $this->assertFalse(module_exists('dashboard'), 'Dashboard disabled.');
 
-     $edit['modules[Core][dashboard][enable]'] = 'dashboard';
 
-     $this->drupalPost('admin/modules', $edit, t('Save configuration'));
 
-     $this->assertText(t('The configuration options have been saved.'), 'Modules status has been updated.');
 
-     module_list(TRUE);
 
-     $this->assertTrue(module_exists('dashboard'), 'Dashboard enabled.');
 
-     $this->drupalGet('admin/dashboard');
 
-     $this->assertRaw($custom_block['title'], 'Block still appears on the dashboard.');
 
-   }
 
-   /**
 
-    * Tests that administrative blocks are available for the dashboard.
 
-    */
 
-   function testBlockAvailability() {
 
-     // Test "Recent comments", which should be available (defined as
 
-     // "administrative") but not enabled.
 
-     $this->drupalGet('admin/dashboard');
 
-     $this->assertNoText(t('Recent comments'), '"Recent comments" not on dashboard.');
 
-     $this->drupalGet('admin/dashboard/drawer');
 
-     $this->assertText(t('Recent comments'), 'Drawer of disabled blocks includes a block defined as "administrative".');
 
-     $this->assertNoText(t('Syndicate'), 'Drawer of disabled blocks excludes a block not defined as "administrative".');
 
-     $this->drupalGet('admin/dashboard/configure');
 
-     $elements = $this->xpath('//select[@id=:id]//option[@selected="selected"]', array(':id' => 'edit-blocks-comment-recent-region'));
 
-     $this->assertTrue($elements[0]['value'] == 'dashboard_inactive', 'A block defined as "administrative" defaults to dashboard_inactive.');
 
-     // Now enable the block on the dashboard.
 
-     $values = array();
 
-     $values['blocks[comment_recent][region]'] = 'dashboard_main';
 
-     $this->drupalPost('admin/dashboard/configure', $values, t('Save blocks'));
 
-     $this->drupalGet('admin/dashboard');
 
-     $this->assertText(t('Recent comments'), '"Recent comments" was placed on dashboard.');
 
-     $this->drupalGet('admin/dashboard/drawer');
 
-     $this->assertNoText(t('Recent comments'), 'Drawer of disabled blocks excludes enabled blocks.');
 
-   }
 
- }
 
 
  |