require 'spec_helper'
module Refinery
module Blog
describe Post, type: :model do
let(:post) { FactoryGirl.create(:blog_post) }
describe "validations" do
it "requires title" do
expect(FactoryGirl.build(:blog_post, :title => "")).not_to be_valid
end
it "won't allow duplicate titles" do
expect(FactoryGirl.build(:blog_post, :title => post.title)).not_to be_valid
end
it "requires body" do
expect(FactoryGirl.build(:blog_post, :body => nil)).not_to be_valid
end
end
describe "comments association" do
it "have a comments attribute" do
expect(post).to respond_to(:comments)
end
it "destroys associated comments" do
FactoryGirl.create(:blog_comment, :blog_post_id => post.id)
post.destroy
expect(Blog::Comment.where(:blog_post_id => post.id)).to be_empty
end
end
describe "categories association" do
it "have categories attribute" do
expect(post).to respond_to(:categories)
end
end
describe "tags" do
it "acts as taggable" do
expect(post).to respond_to(:tag_list)
post.tag_list = "refinery, cms"
post.save!
expect(post.tag_list).to include("refinery")
end
end
describe "authors" do
it "are authored" do
expect(described_class.instance_methods.map(&:to_sym)).to include(:author)
end
end
describe "by_month" do
before do
@post1 = FactoryGirl.create(:blog_post, :published_at => Date.new(2011, 3, 11))
@post2 = FactoryGirl.create(:blog_post, :published_at => Date.new(2011, 3, 12))
#2 months before
FactoryGirl.create(:blog_post, :published_at => Date.new(2011, 1, 10))
end
it "returns all posts from specified month" do
#check for this month
date = "03/2011"
expect(described_class.by_month(Time.parse(date)).count).to eq(2)
expect(described_class.by_month(Time.parse(date))).to eq([@post2, @post1])
end
end
describe ".published_dates_older_than" do
before do
@post1 = FactoryGirl.create(:blog_post, :published_at => Time.utc(2012, 05, 01, 15, 20))
@post2 = FactoryGirl.create(:blog_post, :published_at => Time.utc(2012, 05, 01, 15, 30))
FactoryGirl.create(:blog_post, :published_at => Time.now)
end
it "returns all published dates older than the argument" do
expected = [@post2.published_at, @post1.published_at]
expect(described_class.published_dates_older_than(5.minutes.ago)).to eq(expected)
end
end
describe "live" do
before do
@post1 = FactoryGirl.create(:blog_post, :published_at => Time.now.advance(:minutes => -2))
@post2 = FactoryGirl.create(:blog_post, :published_at => Time.now.advance(:minutes => -1))
FactoryGirl.create(:blog_post, :draft => true)
FactoryGirl.create(:blog_post, :published_at => Time.now + 1.minute)
end
it "returns all posts which aren't in draft and pub date isn't in future" do
live_posts = described_class.live
expect(live_posts.count).to eq(2)
expect(live_posts).to include(@post2)
expect(live_posts).to include(@post1)
end
end
describe "uncategorized" do
before do
@uncategorized_post = FactoryGirl.create(:blog_post)
@categorized_post = FactoryGirl.create(:blog_post)
@categorized_post.categories << FactoryGirl.create(:blog_category)
end
it "returns uncategorized posts if they exist" do
expect(described_class.uncategorized).to include @uncategorized_post
expect(described_class.uncategorized).not_to include @categorized_post
end
end
describe "#live?" do
it "returns true if post is not in draft and it's published" do
expect(FactoryGirl.build(:blog_post)).to be_live
end
it "returns false if post is in draft" do
expect(FactoryGirl.build(:blog_post, :draft => true)).not_to be_live
end
it "returns false if post pub date is in future" do
expect(FactoryGirl.build(:blog_post, :published_at => Time.now.advance(:minutes => 1))).not_to be_live
end
end
describe "#next" do
before do
FactoryGirl.create(:blog_post, :published_at => Time.now.advance(:days => -1))
@post = FactoryGirl.create(:blog_post)
end
it "returns next article when called on current article" do
expect(described_class.newest_first.last.next).to eq(@post)
end
end
describe "#prev" do
before do
FactoryGirl.create(:blog_post)
@post = FactoryGirl.create(:blog_post, :published_at => Time.now.advance(:days => -1))
end
it "returns previous article when called on current article" do
expect(described_class.first.prev).to eq(@post)
end
end
describe ".comments_allowed?" do
context "with Refinery::Setting comments_allowed set to true" do
before do
Refinery::Setting.set(:comments_allowed, { :scoping => 'blog', :value => true })
end
it "should be true" do
expect(described_class.comments_allowed?).to be_truthy
end
end
context "with Refinery::Setting comments_allowed set to false" do
before do
Refinery::Setting.set(:comments_allowed, { :scoping => 'blog', :value => false })
end
it "should be false" do
expect(described_class.comments_allowed?).to be_falsey
end
end
end
describe "custom teasers" do
it "should allow a custom teaser" do
expect(FactoryGirl.create(:blog_post, :custom_teaser => 'This is some custom content')).to be_valid
end
end
describe ".teasers_enabled?" do
context "with Refinery::Setting teasers_enabled set to true" do
before do
Refinery::Setting.set(:teasers_enabled, { :scoping => 'blog', :value => true })
end
it "should be true" do
expect(described_class.teasers_enabled?).to be_truthy
end
end
context "with Refinery::Setting teasers_enabled set to false" do
before do
Refinery::Setting.set(:teasers_enabled, { :scoping => 'blog', :value => false })
end
it "should be false" do
expect(described_class.teasers_enabled?).to be_falsey
end
end
end
describe "source url" do
it "should allow a source url and title" do
p = FactoryGirl.create(:blog_post, :source_url => 'google.com', :source_url_title => 'author')
expect(p).to be_valid
expect(p.source_url).to include('google')
expect(p.source_url_title).to include('author')
end
end
describe ".validate_source_url?" do
context "with Refinery::Blog.validate_source_url set to true" do
before do
Refinery::Blog.validate_source_url = true
end
it "should have canonical url" do
expect_any_instance_of(UrlValidator).to receive(:resolve_redirects_verify_url).
and_return('http://www.google.com')
p = FactoryGirl.create(:blog_post, :source_url => 'google.com', :source_url_title => 'google')
expect(p.source_url).to include('www')
end
end
context "with Refinery::Blog.validate_source_url set to false" do
before do
Refinery::Blog.validate_source_url = false
end
it "should have original url" do
p = FactoryGirl.create(:blog_post, :source_url => 'google.com', :source_url_title => 'google')
expect(p.source_url).not_to include('www')
end
end
end
describe "#should_generate_new_friendly_id?" do
context "when custom_url changes" do
it "regenerates slug upon save" do
post = FactoryGirl.create(:blog_post, :custom_url => "Test Url")
post.custom_url = "Test Url 2"
post.save!
expect(post.slug).to eq("test-url-2")
end
end
context "when title changes" do
it "regenerates slug upon save" do
post = FactoryGirl.create(:blog_post, :title => "Test Title")
post.title = "Test Title 2"
post.save!
expect(post.slug).to eq("test-title-2")
end
end
end
end
end
end