diff options
Diffstat (limited to 'spec/features/refinery/blog/posts_spec.rb')
-rw-r--r-- | spec/features/refinery/blog/posts_spec.rb | 254 |
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 |