Make all the tests happy.

This commit is contained in:
Parker Moore 2015-01-17 13:59:52 -08:00
parent c1da91cf5c
commit 9d547f74cc
11 changed files with 51 additions and 80 deletions

View File

@ -26,6 +26,10 @@ STDERR.reopen(test(?e, '/dev/null') ? '/dev/null' : 'NUL:')
class Test::Unit::TestCase
include RR::Adapters::TestUnit
def fixture_site(overrides = {})
Jekyll::Site.new(site_configuration(overrides))
end
def build_configs(overrides, base_hash = Jekyll::Configuration::DEFAULTS)
Utils.deep_merge_hashes(base_hash, overrides)
end

View File

@ -3,6 +3,6 @@ layout: default
title: Foo Bar
---
h1. {{ page.title }}
# {{ page.title }}
Best *post* ever
Best **post** ever

View File

@ -5,4 +5,4 @@ title: Include
{% include sig.markdown %}
This _is_ cool
This _is_ cool

View File

@ -9,11 +9,7 @@ class TestCleaner < Test::Unit::TestCase
FileUtils.touch(File.join(dest_dir('to_keep'), 'index.html'))
FileUtils.touch(File.join(dest_dir('to_keep/child_dir'), 'index.html'))
@site = Site.new(Jekyll.configuration({
"skip_config_files" => true,
"source" => source_dir,
"destination" => dest_dir
}))
@site = fixture_site
@site.keep_files = ['to_keep/child_dir']
@cleaner = Site::Cleaner.new(@site)
@ -48,11 +44,7 @@ class TestCleaner < Test::Unit::TestCase
FileUtils.mkdir_p(source_dir('no_files_inside/child_dir'))
FileUtils.touch(File.join(source_dir('no_files_inside/child_dir'), 'index.html'))
@site = Site.new(Jekyll.configuration({
"skip_config_files" => true,
"source" => source_dir,
"destination" => dest_dir
}))
@site = fixture_site
@site.process
@cleaner = Site::Cleaner.new(@site)

View File

@ -3,10 +3,7 @@ require 'helper'
class TestCoffeeScript < Test::Unit::TestCase
context "converting CoffeeScript" do
setup do
@site = Jekyll::Site.new(Jekyll.configuration({
"source" => source_dir,
"destination" => dest_dir
}))
@site = fixture_site
@site.process
@test_coffeescript_file = dest_dir("js/coffeescript.js")
@js_output = <<-JS

View File

@ -1,16 +1,6 @@
require 'helper'
class TestCollections < Test::Unit::TestCase
def fixture_site(overrides = {})
Jekyll::Site.new(Jekyll.configuration(
overrides.merge({
"source" => source_dir,
"destination" => dest_dir
})
))
end
context "an evil collection" do
setup do
@collection = Jekyll::Collection.new(fixture_site, "../../etc/password")

View File

@ -15,18 +15,17 @@ class TestPost < Test::Unit::TestCase
context "A Post" do
setup do
clear_dest
@site = Site.new(Jekyll.configuration({
"skip_config_files" => true,
"source" => source_dir,
"destination" => dest_dir
}))
@site = fixture_site
end
should "ensure valid posts are valid" do
assert Post.valid?("2008-09-09-foo-bar.textile")
assert Post.valid?("foo/bar/2008-09-09-foo-bar.textile")
assert Post.valid?("2008-09-09-foo-bar.markdown")
assert Post.valid?("foo/bar/2008-09-09-foo-bar.markdown")
assert !Post.valid?("lol2008-09-09-foo-bar.textile")
assert !Post.valid?("lol2008-09-09-foo-bar.markdown")
assert !Post.valid?("blah")
end
@ -63,8 +62,8 @@ class TestPost < Test::Unit::TestCase
@post = Post.allocate
@post.site = @site
@real_file = "2008-10-18-foo-bar.textile"
@fake_file = "2008-09-09-foo-bar.textile"
@real_file = "2008-10-18-foo-bar.markdown"
@fake_file = "2008-09-09-foo-bar.markdown"
@source = source_dir('_posts')
end
@ -74,7 +73,7 @@ class TestPost < Test::Unit::TestCase
assert_equal Time.parse("2008-09-09"), @post.date
assert_equal "foo-bar", @post.slug
assert_equal ".textile", @post.ext
assert_equal ".markdown", @post.ext
assert_equal "/2008/09/09", @post.dir
assert_equal "/2008/09/09/foo-bar", @post.id
end
@ -367,13 +366,13 @@ class TestPost < Test::Unit::TestCase
@post.read_yaml(@source, @real_file)
assert_equal({"title" => "Foo Bar", "layout" => "default"}, @post.data)
assert_equal "h1. {{ page.title }}\n\nBest *post* ever", @post.content
assert_equal "# {{ page.title }}\n\nBest **post** ever", @post.content
end
should "transform textile" do
@post.process(@real_file)
@post.read_yaml(@source, @real_file)
assert_equal "<h1>{{ page.title }}</h1>\n<p>Best <strong>post</strong> ever</p>", @post.transform
assert_equal "<h1 id=\"pagetitle-\">{{ page.title }}</h1>\n\n<p>Best <strong>post</strong> ever</p>", @post.transform.strip
end
context "#excerpt" do
@ -461,8 +460,7 @@ class TestPost < Test::Unit::TestCase
context "when in a site" do
setup do
clear_dest
stub(Jekyll).configuration { Jekyll::Configuration::DEFAULTS }
@site = Site.new(Jekyll.configuration)
@site = fixture_site
@site.posts = [setup_post('2008-02-02-published.textile'),
setup_post('2009-01-27-categories.textile')]
end
@ -486,30 +484,30 @@ class TestPost < Test::Unit::TestCase
context "initializing posts" do
should "recognize date in yaml" do
post = setup_post("2010-01-09-date-override.textile")
post = setup_post("2010-01-09-date-override.markdown")
do_render(post)
assert_equal Time, post.date.class
assert_equal Time, post.to_liquid["date"].class
assert_equal "/2010/01/10/date-override.html", post.url
assert_equal "<p>Post with a front matter date</p>\n<p>10 Jan 2010</p>", post.output
assert_equal "<p>Post with a front matter date</p>\n\n<p>10 Jan 2010</p>", post.output.strip
end
should "recognize time in yaml" do
post = setup_post("2010-01-09-time-override.textile")
post = setup_post("2010-01-09-time-override.markdown")
do_render(post)
assert_equal Time, post.date.class
assert_equal Time, post.to_liquid["date"].class
assert_equal "/2010/01/10/time-override.html", post.url
assert_equal "<p>Post with a front matter time</p>\n<p>10 Jan 2010</p>", post.output
assert_equal "<p>Post with a front matter time</p>\n\n<p>10 Jan 2010</p>", post.output.strip
end
should "recognize time with timezone in yaml" do
post = setup_post("2010-01-09-timezone-override.textile")
post = setup_post("2010-01-09-timezone-override.markdown")
do_render(post)
assert_equal Time, post.date.class
assert_equal Time, post.to_liquid["date"].class
assert_equal "/2010/01/10/timezone-override.html", post.url
assert_equal "<p>Post with a front matter time with timezone</p>\n<p>10 Jan 2010</p>", post.output
assert_equal "<p>Post with a front matter time with timezone</p>\n\n<p>10 Jan 2010</p>", post.output.strip
end
should "to_liquid prioritizes post attributes over data" do
@ -603,13 +601,13 @@ class TestPost < Test::Unit::TestCase
end
should "render properly" do
post = setup_post("2008-10-18-foo-bar.textile")
post = setup_post("2008-10-18-foo-bar.markdown")
do_render(post)
assert_equal "<<< <h1>Foo Bar</h1>\n<p>Best <strong>post</strong> ever</p> >>>", post.output
assert_equal "<<< <h1 id=\"foo-bar\">Foo Bar</h1>\n\n<p>Best <strong>post</strong> ever</p>\n >>>", post.output
end
should "write properly" do
post = setup_post("2008-10-18-foo-bar.textile")
post = setup_post("2008-10-18-foo-bar.markdown")
do_render(post)
post.write(dest_dir)
@ -652,7 +650,7 @@ class TestPost < Test::Unit::TestCase
end
should "write properly without html extension" do
post = setup_post("2008-10-18-foo-bar.textile")
post = setup_post("2008-10-18-foo-bar.markdown")
post.site.permalink_style = ":title/"
do_render(post)
post.write(dest_dir)
@ -662,32 +660,31 @@ class TestPost < Test::Unit::TestCase
end
should "insert data" do
post = setup_post("2008-11-21-complex.textile")
post = setup_post("2008-11-21-complex.markdown")
do_render(post)
assert_equal "<<< <p>url: /2008/11/21/complex.html<br />\ndate: #{Time.parse("2008-11-21")}<br />\nid: /2008/11/21/complex</p> >>>", post.output
assert_equal "<<< <p>url: /2008/11/21/complex.html\ndate: #{Time.parse("2008-11-21")}\nid: /2008/11/21/complex</p>\n >>>", post.output
end
should "include templates" do
post = setup_post("2008-12-13-include.markdown")
post.site.instance_variable_set(:@source, File.join(File.dirname(__FILE__), 'source'))
do_render(post)
assert_equal "<<< <hr />\n<p>Tom Preston-Werner\ngithub.com/mojombo</p>\n\n<p>This <em>is</em> cool</p>\n >>>", post.output
end
should "render date specified in front matter properly" do
post = setup_post("2010-01-09-date-override.textile")
post = setup_post("2010-01-09-date-override.markdown")
do_render(post)
assert_equal "<p>Post with a front matter date</p>\n<p>10 Jan 2010</p>", post.output
assert_equal "<p>Post with a front matter date</p>\n\n<p>10 Jan 2010</p>", post.output.strip
end
should "render time specified in front matter properly" do
post = setup_post("2010-01-09-time-override.textile")
post = setup_post("2010-01-09-time-override.markdown")
do_render(post)
assert_equal "<p>Post with a front matter time</p>\n<p>10 Jan 2010</p>", post.output
assert_equal "<p>Post with a front matter time</p>\n\n<p>10 Jan 2010</p>", post.output.strip
end
end
@ -701,8 +698,7 @@ class TestPost < Test::Unit::TestCase
context "converter file extension settings" do
setup do
stub(Jekyll).configuration { Jekyll::Configuration::DEFAULTS }
@site = Site.new(Jekyll.configuration)
@site = fixture_site
end
should "process .md as markdown under default configuration" do
@ -750,17 +746,13 @@ class TestPost < Test::Unit::TestCase
context "site config with category" do
setup do
config = site_configuration({
'defaults' => [
'scope' => {
'path' => ''
},
'values' => {
'category' => 'article'
}
]
})
@site = Site.new(config)
front_matter_defaults = {
'defaults' => [{
'scope' => { 'path' => '' },
'values' => { 'category' => 'article' }
}]
}
@site = fixture_site(front_matter_defaults)
end
should "return category if post does not specify category" do
@ -777,17 +769,13 @@ class TestPost < Test::Unit::TestCase
context "site config with categories" do
setup do
config = site_configuration({
'defaults' => [
'scope' => {
'path' => ''
},
'values' => {
'categories' => ['article']
}
]
})
@site = Site.new(config)
front_matter_defaults = {
'defaults' => [{
'scope' => { 'path' => '' },
'values' => { 'categories' => ['article'] }
}]
}
@site = fixture_site(front_matter_defaults)
end
should "return categories if post does not specify categories" do