a bunch of tag and database changes

This commit is contained in:
John Bintz 2010-02-15 22:06:59 -05:00
parent e4651dfc5b
commit cd64fbf416
7 changed files with 174 additions and 35 deletions

View File

@ -31,7 +31,7 @@ class ComicPressComicPost {
/** /**
* Normalize the ordering of attachments in this post. * Normalize the ordering of attachments in this post.
* If images have beed added or removed, intelligently update the metadata. * If images have been added or removed, intelligently update the metadata.
* @param boolean $skip_checks If true, only return the post metadata, assuming that everything is correct. Do not use anywhere in the admin interface! * @param boolean $skip_checks If true, only return the post metadata, assuming that everything is correct. Do not use anywhere in the admin interface!
* @return array The normalized data, which is also written to the post's metadata if $skip_checks is false. * @return array The normalized data, which is also written to the post's metadata if $skip_checks is false.
*/ */

View File

@ -36,43 +36,55 @@ class ComicPressDBInterface {
$wp_query->in_the_loop = $this->in_the_loop; $wp_query->in_the_loop = $this->in_the_loop;
} }
function ensure_count($count) {
return max((int)$count, 1);
}
// @codeCoverageIgnoreStart // @codeCoverageIgnoreStart
/** /**
* Find the terminal post in a specific category. * Find the terminal post in a specific category.
*/ */
function get_terminal_post_in_categories($categories, $first = true) { function get_terminal_post_in_categories($categories, $first = true, $count = false) {
$this->_prepare_wp_query(); $this->_prepare_wp_query();
$count = $this->ensure_count($count);
if (!is_array($categories)) { $categories = array($categories); } if (!is_array($categories)) { $categories = array($categories); }
$sort_order = $first ? "asc" : "desc"; $sort_order = $first ? "asc" : "desc";
$terminal_comic_query = new WP_Query(); $terminal_comic_query = new WP_Query();
$terminal_comic_query->query(array( $terminal_comic_query->query(array(
'showposts' => 1, 'showposts' => $count,
'order' => $sort_order, 'order' => $sort_order,
'category__in' => $categories 'category__in' => $categories,
'post_status' => 'publish'
)); ));
$post = false; $result = false;
if ($terminal_comic_query->have_posts()) { if ($terminal_comic_query->have_posts()) {
$post = reset($terminal_comic_query->posts); if ($count == 1) {
$result = reset($terminal_comic_query->posts);
} else {
$result = $terminal_comic_query->posts;
}
} }
$this->_reset_wp_query(); $this->_reset_wp_query();
return $post; return $result;
} }
/** /**
* Get the first comic in a category. * Get the first comic in a category.
*/ */
function get_first_post($categories) { function get_first_post($categories, $reference_post = null, $count = false) {
return $this->get_terminal_post_in_categories($categories); return $this->get_terminal_post_in_categories($categories, true, $count);
} }
/** /**
* Get the last comic in a category. * Get the last comic in a category.
*/ */
function get_last_post($categories) { function get_last_post($categories, $reference_post = null, $count = false) {
return $this->get_terminal_post_in_categories($categories, false); return $this->get_terminal_post_in_categories($categories, false);
} }
@ -80,29 +92,61 @@ class ComicPressDBInterface {
* Get the comic post adjacent to the current comic. * Get the comic post adjacent to the current comic.
* Wrapper around get_adjacent_post(). Don't unit test this method. * Wrapper around get_adjacent_post(). Don't unit test this method.
*/ */
function get_adjacent_post($categories, $next = false, $override_post = null) { function get_adjacent_post($categories, $next = false, $override_post = null, $count = false) {
global $post; global $wpdb, $post;
$this->_prepare_wp_query(); $count = $this->ensure_count($count);
if (!is_null($override_post)) { $temp_post = $post; $post = $override_post; }
$result = get_adjacent_post(false, implode(" and ", $this->_get_categories_to_exclude($categories)), !$next); $post_to_use = (!is_null($override_post)) ? $override_post : $post;
$this->_reset_wp_query(); $op = ($next ? '>' : '<');
if (!is_null($override_post)) { $post = $temp_post; } $order = ($next ? 'ASC' : 'DESC');
return empty($result) ? false : $result; $query = $wpdb->prepare("SELECT p.* FROM $wpdb->posts AS p
INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id
INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id
WHERE p.post_date ${op} %s
AND p.post_type = 'post'
AND p.post_status = 'publish'
AND tt.taxonomy = 'category'
AND tt.term_id IN (%s)
ORDER BY p.post_date ${order} LIMIT %d",
$post_to_use->post_date,
implode(',', $categories),
$count);
$query_key = 'comicpress_adjacent_post_' . md5($query);
$result = wp_cache_get($query_key, 'counts');
if ($result !== false) {
return $result;
}
$result = $wpdb->get_results($query);
if (!empty($result)) {
if ($count == 1) { $result = $result[0]; }
wp_cache_set($query_key, $result, 'counts');
return $result;
} else {
return ($count == 1) ? false : array();
}
} }
/** /**
* Get the previous comic from the current one. * Get the previous comic from the current one.
*/ */
function get_previous_post($categories = null, $override_post = null) { return $this->get_adjacent_post($categories, false, $override_post); } function get_previous_post($categories = null, $override_post = null, $count = false) {
return $this->get_adjacent_post($categories, false, $override_post, $count);
}
/** /**
* Get the next comic from the current one. * Get the next comic from the current one.
*/ */
function get_next_post($categories = null, $override_post = null) { return $this->get_adjacent_post($categories, true, $override_post); } function get_next_post($categories = null, $override_post = null, $count = false) {
return $this->get_adjacent_post($categories, true, $override_post, $count);
}
function get_parent_child_category_ids() { function get_parent_child_category_ids() {
global $wpdb; global $wpdb;

View File

@ -558,6 +558,10 @@ class ComicPressStoryline {
return $this; return $this;
} }
function _find_all() {
return array_keys($this->_structure);
}
function _find_level_or_above($level = null) { function _find_level_or_above($level = null) {
$found = array(); $found = array();
foreach ($this->_structure as $category_id => $info) { foreach ($this->_structure as $category_id => $info) {

View File

@ -184,7 +184,22 @@ class ComicPressTagBuilder {
} }
return isset($arguments[0]) ? get_category($id) : $id; return isset($arguments[0]) ? get_category($id) : $id;
} else { } else {
$this->post = call_user_func(array($this->dbi, "get_${method}_post"), $this->storyline->build_from_restrictions($this->restrictions), $this->parent_post); if (empty($this->restrictions)) {
$this->restrictions = array(
array('from_post', $this->parent_post->ID)
);
}
$count = (isset($arguments[0])) ? (int)$arguments[0] : false;
if ($count < 2) {
$count = false;
}
$result = call_user_func(array($this->dbi, "get_${method}_post"), $this->storyline->build_from_restrictions($this->restrictions), $this->parent_post, $count);
if (is_array($result)) {
return $result;
} else {
$this->post = $result;
}
} }
$ok = true; $ok = true;
break; break;
@ -192,7 +207,12 @@ class ComicPressTagBuilder {
if (!isset($arguments[0])) { if (!isset($arguments[0])) {
throw new ComicPressException('Need to specify a category'); throw new ComicPressException('Need to specify a category');
} }
if ($arguments[0] == 'all') {
$this->restrictions[] = array('all', true);
} else {
$this->restrictions[] = array('child_of', $arguments[0]); $this->restrictions[] = array('child_of', $arguments[0]);
}
$ok = true; $ok = true;
break; break;
case 'id': case 'id':
@ -209,7 +229,16 @@ class ComicPressTagBuilder {
case 'permalink': case 'permalink':
return get_permalink($this->post->ID); return get_permalink($this->post->ID);
case 'post': case 'post':
if (isset($arguments[0])) {
if (!is_object($arguments[0]) && !is_array($arguments[0])) {
throw new ComicPressException('Provided post needs to be an array or object');
}
$this->post = $arguments[0];
$ok = true;
} else {
return $this->post; return $this->post;
}
break;
case 'media': case 'media':
if (isset($this->post)) { if (isset($this->post)) {
$comic_post = $this->_new_comicpresscomicpost($this->post); $comic_post = $this->_new_comicpresscomicpost($this->post);

View File

@ -110,6 +110,7 @@ class ComicPressBackendFilesystemFactory {
} }
$all_patterns = array_merge($all_patterns, $patterns); $all_patterns = array_merge($all_patterns, $patterns);
} }
if (($filename_pattern = $this->has_common_filename_pattern($all_patterns)) !== false) { if (($filename_pattern = $this->has_common_filename_pattern($all_patterns)) !== false) {
if (!empty($files)) { if (!empty($files)) {
$grouped_by_root = $this->group_by_root($filename_pattern, $files); $grouped_by_root = $this->group_by_root($filename_pattern, $files);

View File

@ -80,6 +80,22 @@ class ComicPressDBInterfaceTest extends PHPUnit_Framework_TestCase {
$this->assertTrue(false === $wp_query->is_single); $this->assertTrue(false === $wp_query->is_single);
$this->assertTrue(false === $wp_query->in_the_loop); $this->assertTrue(false === $wp_query->in_the_loop);
} }
function providerTestEnsureCount() {
return array(
array(0, 1),
array(1, 1),
array(2, 2),
array('test', 1),
array(false, 1)
);
}
/**
* @dataProvider providerTestEnsureCount
*/
function testEnsureCount($input, $expected_output) {
$this->assertEquals($expected_output, ComicPressDBInterface::ensure_count($input));
}
} }
?>

View File

@ -15,44 +15,46 @@ class ComicPressTagBuilderTest extends PHPUnit_Framework_TestCase {
} }
function providerTestBuilder() { function providerTestBuilder() {
$p = (object)array('ID' => 1);
return array( return array(
array( array(
array( array(
array('next') array('next')
), ),
array('get_next_post', array(1,2,3,4,5), 'current-post') array('get_next_post', array(1), $p)
), ),
array( array(
array( array(
array('previous'), array('previous'),
), ),
array('get_previous_post', array(1,2,3,4,5), 'current-post') array('get_previous_post', array(1), $p)
), ),
array( array(
array( array(
array('first'), array('first'),
), ),
array('get_first_post', array(1,2,3,4,5), 'current-post') array('get_first_post', array(1), $p)
), ),
array( array(
array( array(
array('last'), array('last'),
), ),
array('get_last_post', array(1,2,3,4,5), 'current-post') array('get_last_post', array(1), $p)
), ),
array( array(
array( array(
array('in', 'category-1'), array('in', 'category-2'),
array('last') array('last')
), ),
array('get_last_post', array(1), 'current-post') array('get_last_post', array(2,3,4), $p)
), ),
array( array(
array( array(
array('in', 2), array('in', 2),
array('first') array('first')
), ),
array('get_first_post', array(2,3,4), 'current-post') array('get_first_post', array(2,3,4), $p)
), ),
array( array(
array( array(
@ -60,7 +62,7 @@ class ComicPressTagBuilderTest extends PHPUnit_Framework_TestCase {
array('first'), array('first'),
array('setup') array('setup')
), ),
array('get_first_post', array(2,3,4), 'current-post'), array('get_first_post', array(2,3,4), $p),
true true
), ),
array( array(
@ -71,16 +73,32 @@ class ComicPressTagBuilderTest extends PHPUnit_Framework_TestCase {
), ),
array('get_first_post', array(2,3,4), (object)array('other-post' => 'post')), array('get_first_post', array(2,3,4), (object)array('other-post' => 'post')),
), ),
array(
array(
array('next', 3)
),
array('get_next_post', array(1), $p, 3),
false,
true
),
array(
array(
array('in', 'all'),
array('first')
),
array('get_first_post', array(1,2,3,4,5), $p)
),
); );
} }
/** /**
* @dataProvider providerTestBuilder * @dataProvider providerTestBuilder
*/ */
// TODO same_category function testStorylineBuilder($instructions, $expected_dbi_call, $expects_setup_postdata = false, $returns_array = false) {
function testStorylineBuilder($instructions, $expected_dbi_call, $expects_setup_postdata = false) {
global $post, $wp_test_expectations; global $post, $wp_test_expectations;
$post = 'current-post'; $post = (object)array('ID' => 1);
wp_set_post_categories(1, array(1));
$method = array_shift($expected_dbi_call); $method = array_shift($expected_dbi_call);
@ -92,6 +110,10 @@ class ComicPressTagBuilderTest extends PHPUnit_Framework_TestCase {
call_user_func(array($expectation, 'will'), $this->returnValue('new-post')); call_user_func(array($expectation, 'will'), $this->returnValue('new-post'));
} }
if ($returns_array) {
call_user_func(array($expectation, 'will'), $this->returnValue(array('new-post')));
}
$core = new ComicPressTagBuilderFactory($dbi); $core = new ComicPressTagBuilderFactory($dbi);
$storyline = new ComicPressStoryline(); $storyline = new ComicPressStoryline();
@ -675,4 +697,27 @@ class ComicPressTagBuilderTest extends PHPUnit_Framework_TestCase {
$comicpress = ComicPress::get_instance(true); $comicpress = ComicPress::get_instance(true);
} }
function providerTestSetPostExpectations() {
return array(
array('test'),
array(123)
);
}
/**
* @expectedException ComicPressException
* @dataProvider providerTestSetPostExpectations
*/
function testSetPostExceptions($input) {
$core = new ComicPressTagBuilderFactory();
$core->post($input);
}
function testSetPost() {
$core = new ComicPressTagBuilderFactory();
$core = $core->post((object)array('ID' => 1));
$this->assertEquals((object)array('ID' => 1), $core->post);
}
} }