diff --git a/modules/filter/filter.admin.inc b/modules/filter/filter.admin.inc index abd7acce294a080375dc41aab6ca0d6cf9f9b7ce..f0824838bd1c1969e0b099e813a241c15af7f12f 100644 --- a/modules/filter/filter.admin.inc +++ b/modules/filter/filter.admin.inc @@ -182,6 +182,7 @@ function filter_admin_format_form($form, &$form_state, $format) { '#default_value' => $filters[$name]->weight, '#parents' => array('filters', $name, 'weight'), ); + $form['filters']['order'][$name]['#weight'] = $filters[$name]->weight; } // Filter settings. diff --git a/modules/filter/filter.test b/modules/filter/filter.test index a15c2683840c8461298ded8bc15ed87c4bef0337..64d3cb51453c83092f97b888beb487f5afbd4bb9 100644 --- a/modules/filter/filter.test +++ b/modules/filter/filter.test @@ -231,6 +231,9 @@ class FilterAdminTestCase extends DrupalWebTestCase { $result = db_query('SELECT * FROM {cache_filter}')->fetchObject(); $this->assertFalse($result, t('Cache cleared.')); + $elements = $this->xpath('//select[@name="filters[' . $first_filter . '][weight]"]/following::select[@name="filters[' . $second_filter . '][weight]"]'); + $this->assertTrue(!empty($elements), t('Order confirmed in admin interface.')); + // Reorder filters. $edit = array(); $edit['filters[' . $second_filter . '][weight]'] = 1; @@ -239,6 +242,9 @@ class FilterAdminTestCase extends DrupalWebTestCase { $this->assertFieldByName('filters[' . $second_filter . '][weight]', 1, t('Order saved successfully.')); $this->assertFieldByName('filters[' . $first_filter . '][weight]', 2, t('Order saved successfully.')); + $elements = $this->xpath('//select[@name="filters[' . $second_filter . '][weight]"]/following::select[@name="filters[' . $first_filter . '][weight]"]'); + $this->assertTrue(!empty($elements), t('Reorder confirmed in admin interface.')); + $result = db_query('SELECT * FROM {filter} WHERE format = :format ORDER BY weight ASC', array(':format' => $filtered)); $filters = array(); foreach ($result as $filter) { @@ -246,7 +252,7 @@ class FilterAdminTestCase extends DrupalWebTestCase { $filters[] = $filter; } } - $this->assertTrue(($filters[0]->name == $second_filter && $filters[1]->name == $first_filter), t('Order confirmed.')); + $this->assertTrue(($filters[0]->name == $second_filter && $filters[1]->name == $first_filter), t('Order confirmed in database.')); // Add format. $edit = array();