aboutsummaryrefslogtreecommitdiffstats
path: root/spec/features/refinery/blog/posts_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/features/refinery/blog/posts_spec.rb')
-rw-r--r--spec/features/refinery/blog/posts_spec.rb254
1 files changed, 128 insertions, 126 deletions
diff --git a/spec/features/refinery/blog/posts_spec.rb b/spec/features/refinery/blog/posts_spec.rb
index 3382398..816e11c 100644
--- a/spec/features/refinery/blog/posts_spec.rb
+++ b/spec/features/refinery/blog/posts_spec.rb
@@ -1,180 +1,182 @@
require "spec_helper"
module Refinery
- describe "Blog::Posts", type: :feature do
- refinery_login_with :refinery_user
+ module Blog
+ describe Post, type: :feature do
+ refinery_login_with_devise :authentication_devise_refinery_user
- context "when has blog posts" do
- let!(:blog_post) do
- Globalize.with_locale(:en) { FactoryGirl.create(:blog_post, :title => "Refinery CMS blog post") }
- end
+ context "when has blog posts" do
+ let!(:blog_post) do
+ Globalize.with_locale(:en) { FactoryGirl.create(:blog_post, :title => "Refinery CMS blog post") }
+ end
- it "should display blog post" do
- visit refinery.blog_post_path(blog_post)
+ it "should display blog post" do
+ visit refinery.blog_post_path(blog_post)
- expect(page).to have_content(blog_post.title)
- end
+ expect(page).to have_content(blog_post.title)
+ end
- describe "visit blog" do
+ describe "visit blog" do
- before do
- FactoryGirl.create(:page, :link_url => "/")
- FactoryGirl.create(:page, :link_url => "/blog", :title => "Blog")
- end
+ before do
+ FactoryGirl.create(:page, :link_url => "/")
+ FactoryGirl.create(:page, :link_url => "/blog", :title => "Blog")
+ end
- it "shows blog link in menu" do
- visit "/"
- within "#menu" do
- expect(page).to have_content("Blog")
- expect(page).to have_selector("a[href='/blog']")
+ it "shows blog link in menu" do
+ visit "/"
+ within "#menu" do
+ expect(page).to have_content("Blog")
+ expect(page).to have_selector("a[href='/blog']")
+ end
+ end
+
+ it "shows blog posts" do
+ visit refinery.blog_root_path
+ expect(page).to have_content blog_post.title
end
- end
- it "shows blog posts" do
- visit refinery.blog_root_path
- expect(page).to have_content blog_post.title
end
end
- end
-
- describe "list tagged posts" do
- context "when has tagged blog posts" do
- let!(:tag_name) { "chicago" }
- let!(:post) {
- FactoryGirl.create(:blog_post,
- :title => "I Love my city",
- :tag_list => tag_name
- )
- }
- let!(:tag) { ::Refinery::Blog::Post.tag_counts_on(:tags).first }
-
- it "should have one tagged post" do
- visit refinery.blog_tagged_posts_path(tag.id, tag_name.parameterize)
-
- expect(page).to have_content(tag_name)
- expect(page).to have_content(post.title)
+ describe "list tagged posts" do
+ context "when has tagged blog posts" do
+ let!(:tag_name) { "chicago" }
+ let!(:post) {
+ FactoryGirl.create(:blog_post,
+ :title => "I Love my city",
+ :tag_list => tag_name
+ )
+ }
+ let!(:tag) { ::Refinery::Blog::Post.tag_counts_on(:tags).first }
+
+ it "should have one tagged post" do
+ visit refinery.blog_tagged_posts_path(tag.id, tag_name.parameterize)
+
+ expect(page).to have_content(tag_name)
+ expect(page).to have_content(post.title)
+ end
end
end
- end
- describe "#show" do
- context "when has no comments" do
- let!(:blog_post) { FactoryGirl.create(:blog_post) }
+ describe "#show" do
+ context "when has no comments" do
+ let!(:blog_post) { FactoryGirl.create(:blog_post) }
- it "should display the blog post" do
- visit refinery.blog_post_path(blog_post)
- expect(page).to have_content(blog_post.title)
- expect(page).to have_content(blog_post.body)
+ it "should display the blog post" do
+ visit refinery.blog_post_path(blog_post)
+ expect(page).to have_content(blog_post.title)
+ expect(page).to have_content(blog_post.body)
+ end
end
- end
- context "when has approved comments" do
- let!(:approved_comment) { FactoryGirl.create(:approved_comment) }
+ context "when has approved comments" do
+ let!(:approved_comment) { FactoryGirl.create(:approved_comment) }
- it "should display the comments" do
- visit refinery.blog_post_path(approved_comment.post)
+ it "should display the comments" do
+ visit refinery.blog_post_path(approved_comment.post)
- expect(page).to have_content(approved_comment.body)
- expect(page).to have_content("Posted by #{approved_comment.name}")
+ expect(page).to have_content(approved_comment.body)
+ expect(page).to have_content("Posted by #{approved_comment.name}")
+ end
end
- end
- context "when has rejected comments" do
- let!(:rejected_comment) { FactoryGirl.create(:rejected_comment) }
+ context "when has rejected comments" do
+ let!(:rejected_comment) { FactoryGirl.create(:rejected_comment) }
- it "should not display the comments" do
- visit refinery.blog_post_path(rejected_comment.post)
+ it "should not display the comments" do
+ visit refinery.blog_post_path(rejected_comment.post)
- expect(page).not_to have_content(rejected_comment.body)
+ expect(page).not_to have_content(rejected_comment.body)
+ end
end
- end
- context "when has new comments" do
- let!(:blog_comment) { FactoryGirl.create(:blog_comment) }
+ context "when has new comments" do
+ let!(:blog_comment) { FactoryGirl.create(:blog_comment) }
- it "should not display the comments" do
- visit refinery.blog_post_path(blog_comment.post)
+ it "should not display the comments" do
+ visit refinery.blog_post_path(blog_comment.post)
- expect(page).not_to have_content(blog_comment.body)
+ expect(page).not_to have_content(blog_comment.body)
+ end
end
- end
- context "when posting comments" do
- let!(:blog_post) { FactoryGirl.create(:blog_post) }
- let(:name) { "pete" }
- let(:email) { "pete@mcawesome.com" }
- let(:body) { "Witty comment." }
+ context "when posting comments" do
+ let!(:blog_post) { FactoryGirl.create(:blog_post) }
+ let(:name) { "pete" }
+ let(:email) { "pete@mcawesome.com" }
+ let(:body) { "Witty comment." }
- before do
- visit refinery.blog_post_path(blog_post)
+ before do
+ visit refinery.blog_post_path(blog_post)
- fill_in "Name", :with => name
- fill_in "Email", :with => email
- fill_in "Message", :with => body
- click_button "Send comment"
- end
+ fill_in "Name", :with => name
+ fill_in "Email", :with => email
+ fill_in "Message", :with => body
+ click_button "Send comment"
+ end
- it "creates the comment" do
- comment = blog_post.reload.comments.last
+ it "creates the comment" do
+ comment = blog_post.reload.comments.last
- expect(comment.name).to eq(name)
- expect(comment.email).to eq(email)
- expect(comment.body).to eq(body)
+ expect(comment.name).to eq(name)
+ expect(comment.email).to eq(email)
+ expect(comment.body).to eq(body)
+ end
end
- end
- context "post popular" do
- let!(:blog_post) { FactoryGirl.create(:blog_post) }
- let!(:blog_post2) { FactoryGirl.create(:blog_post) }
+ context "post popular" do
+ let!(:blog_post) { FactoryGirl.create(:blog_post) }
+ let!(:blog_post2) { FactoryGirl.create(:blog_post) }
- before do
- visit refinery.blog_post_path(blog_post)
- end
+ before do
+ visit refinery.blog_post_path(blog_post)
+ end
- it "should increment access count" do
- expect(blog_post.reload.access_count).to eq(1)
- visit refinery.blog_post_path(blog_post)
- expect(blog_post.reload.access_count).to eq(2)
- end
+ it "should increment access count" do
+ expect(blog_post.reload.access_count).to eq(1)
+ visit refinery.blog_post_path(blog_post)
+ expect(blog_post.reload.access_count).to eq(2)
+ end
- it "should be most popular" do
- expect(Refinery::Blog::Post.popular(2).first).to eq(blog_post)
+ it "should be most popular" do
+ expect(Refinery::Blog::Post.popular(2).first).to eq(blog_post)
+ end
end
- end
- context "post recent" do
- let!(:blog_post) { FactoryGirl.create(:blog_post, :published_at => Time.now - 5.minutes) }
- let!(:blog_post2) { FactoryGirl.create(:blog_post, :published_at => Time.now - 2.minutes) }
+ context "post recent" do
+ let!(:blog_post) { FactoryGirl.create(:blog_post, :published_at => Time.now - 5.minutes) }
+ let!(:blog_post2) { FactoryGirl.create(:blog_post, :published_at => Time.now - 2.minutes) }
- it "should be the most recent" do
- expect(Refinery::Blog::Post.recent(2).first.id).to eq(blog_post2.id)
+ it "should be the most recent" do
+ expect(Refinery::Blog::Post.recent(2).first.id).to eq(blog_post2.id)
+ end
end
- end
- end
+ end
- describe "#show draft preview" do
- let!(:blog_post) { FactoryGirl.create(:blog_post_draft) }
+ describe "#show draft preview" do
+ let!(:blog_post) { FactoryGirl.create(:blog_post_draft) }
- context "when logged in as admin" do
- it "should display the draft notification" do
- visit refinery.blog_post_path(blog_post)
+ context "when logged in as admin" do
+ it "should display the draft notification" do
+ visit refinery.blog_post_path(blog_post)
- expect(page).to have_content('This page is NOT live for public viewing.')
+ expect(page).to have_content('This page is NOT live for public viewing.')
+ end
end
- end
- context "when not logged in as an admin" do
- before do
- # TODO: remove Refinery::Pages::Engine.load_seed dependency.
- # It's here to temporary fix the issue with 404 after visiting logout path.
- Refinery::Pages::Engine.load_seed
- visit refinery.logout_path
- end
+ context "when not logged in as an admin" do
+ before do
+ # TODO: remove Refinery::Pages::Engine.load_seed dependency.
+ # It's here to temporary fix the issue with 404 after visiting logout path.
+ Refinery::Pages::Engine.load_seed
+ visit refinery.logout_path
+ end
- it "should not display the blog post" do
- visit refinery.blog_post_path(blog_post)
+ it "should not display the blog post" do
+ visit refinery.blog_post_path(blog_post)
- expect(page).to have_content("The page you requested was not found.")
+ expect(page).to have_content("The page you requested was not found.")
+ end
end
end
end