From ea6242d53dc0d1be887714a8740d4a9e93d574fc Mon Sep 17 00:00:00 2001 From: Angie Byron <webchick@24967.no-reply.drupal.org> Date: Fri, 17 Dec 2010 19:28:14 +0000 Subject: [PATCH] #993026 by bblake, agentrickard: Fixed Default sort on admin/content incorrect --- includes/tablesort.inc | 2 +- modules/node/node.test | 15 +++++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/includes/tablesort.inc b/includes/tablesort.inc index afa5a6979915..b2b122f9041f 100644 --- a/includes/tablesort.inc +++ b/includes/tablesort.inc @@ -80,7 +80,7 @@ protected function getSort() { // User has not specified a sort. Use default if specified; otherwise use "asc". else { foreach ($this->header as $header) { - if (isset($header['sort'])) { + if (is_array($header) && isset($header['sort'])) { return $header['sort']; } } diff --git a/modules/node/node.test b/modules/node/node.test index dd73e2413aae..3e0db8615d56 100644 --- a/modules/node/node.test +++ b/modules/node/node.test @@ -1409,6 +1409,20 @@ class NodeAdminTestCase extends DrupalWebTestCase { $this->drupalCreateNode(array('title' => $prefix . $this->randomName(6))); } + // Test that the default sort by node.changed DESC actually fires properly. + $nodes_query = db_select('node', 'n') + ->fields('n', array('nid')) + ->orderBy('changed', 'DESC') + ->execute() + ->fetchCol(); + + $nodes_form = array(); + $this->drupalGet('admin/content'); + foreach ($this->xpath('//table/tbody/tr/td/div/input/@value') as $input) { + $nodes_form[] = $input; + } + $this->assertEqual($nodes_query, $nodes_form, 'Nodes are sorted in the form according to the default query.'); + // Compare the rendered HTML node list to a query for the nodes ordered by // title to account for possible database-dependent sort order. $nodes_query = db_select('node', 'n') @@ -1417,6 +1431,7 @@ class NodeAdminTestCase extends DrupalWebTestCase { ->execute() ->fetchCol(); + $nodes_form = array(); $this->drupalGet('admin/content', array('query' => array('sort' => 'asc', 'order' => 'Title'))); foreach ($this->xpath('//table/tbody/tr/td/div/input/@value') as $input) { $nodes_form[] = $input; -- GitLab