aboutsummaryrefslogtreecommitdiffstats
path: root/spec/requests/refinery
diff options
context:
space:
mode:
Diffstat (limited to 'spec/requests/refinery')
-rw-r--r--spec/requests/refinery/admin/blog/comments_spec.rb124
-rw-r--r--spec/requests/refinery/admin/blog/posts_spec.rb171
-rw-r--r--spec/requests/refinery/blog/admin/comments_spec.rb128
-rw-r--r--spec/requests/refinery/blog/admin/menu_spec.rb (renamed from spec/requests/refinery/admin/menu_spec.rb)0
-rw-r--r--spec/requests/refinery/blog/admin/posts_spec.rb175
5 files changed, 303 insertions, 295 deletions
diff --git a/spec/requests/refinery/admin/blog/comments_spec.rb b/spec/requests/refinery/admin/blog/comments_spec.rb
deleted file mode 100644
index a7367e3..0000000
--- a/spec/requests/refinery/admin/blog/comments_spec.rb
+++ /dev/null
@@ -1,124 +0,0 @@
-require "spec_helper"
-
-module Refinery
- describe "AdminBlog::Comments" do
- login_refinery_user
-
- describe "#index" do
- context "when has no new unapproved comments" do
- before(:each) do
- Blog::Comment.delete_all
- visit refinery_admin_blog_comments_path
- end
-
- it "should list no comments" do
- visit refinery_admin_blog_comments_path
-
- page.should have_content('there are no new comments')
- end
- end
-
- context "when has new unapproved comments" do
- let!(:blog_comment) { FactoryGirl.create(:blog_comment) }
- before(:each) { visit refinery_admin_blog_comments_path }
-
- it "should list comments" do
- page.should have_content(blog_comment.body)
- page.should have_content(blog_comment.name)
- end
-
- it "should allow me to approve a comment" do
- click_link "Approve this comment"
-
- page.should have_content("has been approved")
- end
-
- it "should allow me to reject a comment" do
- click_link "Reject this comment"
-
- page.should have_content("has been rejected")
- end
- end
- end
-
- describe "#approved" do
- context "when has no approved comments" do
- before(:each) do
- Blog::Comment.delete_all
- visit approved_refinery_admin_blog_comments_path
- end
-
- it "should list no comments" do
- page.should have_content('there are no approved comments')
- end
- end
-
- context "when has approved comments" do
- let!(:blog_comment) do
- FactoryGirl.create(:blog_comment,
- :state => 'approved')
- end
- before(:each) { visit approved_refinery_admin_blog_comments_path }
-
- it "should list comments" do
- page.should have_content(blog_comment.body)
- page.should have_content(blog_comment.name)
- end
-
- it "should allow me to reject a comment" do
- click_link "Reject this comment"
-
- page.should have_content("has been rejected")
- end
- end
- end
-
- describe "#rejected" do
- context "when has no rejected comments" do
- before(:each) do
- Blog::Comment.delete_all
- visit rejected_refinery_admin_blog_comments_path
- end
-
- it "should list no comments" do
- page.should have_content('there are no rejected comments')
- end
- end
-
- context "when has rejected comments" do
- let!(:blog_comment) do
- FactoryGirl.create(:blog_comment,
- :state => 'rejected')
- end
- before(:each) { visit rejected_refinery_admin_blog_comments_path }
-
- it "should list comments" do
- page.should have_content(blog_comment.body)
- page.should have_content(blog_comment.name)
- end
-
- it "should allow me to approve a comment" do
- click_link "Approve this comment"
-
- page.should have_content("has been approved")
- end
- end
- end
-
- describe "#show" do
- let!(:blog_comment) { FactoryGirl.create(:blog_comment) }
- before(:each) { visit refinery_admin_blog_comment_path(blog_comment) }
-
- it "should display the comment" do
- page.should have_content(blog_comment.body)
- page.should have_content(blog_comment.name)
- end
-
- it "should allow me to approve the comment" do
- click_link "Approve this comment"
-
- page.should have_content("has been approved")
- end
- end
- end
-end
diff --git a/spec/requests/refinery/admin/blog/posts_spec.rb b/spec/requests/refinery/admin/blog/posts_spec.rb
deleted file mode 100644
index 53372b1..0000000
--- a/spec/requests/refinery/admin/blog/posts_spec.rb
+++ /dev/null
@@ -1,171 +0,0 @@
-require "spec_helper"
-
-module Refinery
- describe "AdminBlog::Posts" do
- login_refinery_user
-
- let!(:blog_category) { FactoryGirl.create(:blog_category, :title => "Video Games") }
-
- context "when no blog posts" do
- before(:each) { Refinery::Blog::Post.destroy_all }
-
- describe "blog post listing" do
- before(:each) { visit refinery_admin_blog_posts_path }
-
- it "invites to create new post" do
- page.should have_content("There are no Blog Posts yet. Click \"Create new post\" to add your first blog post.")
- end
- end
-
- describe "new blog post form" do
- before(:each) do
- visit refinery_admin_blog_posts_path
- click_link "Create new post"
- end
-
- it "should have Tags" do
- page.should have_content("Tags")
- end
-
- it "should have Video Games" do
- page.should have_content(blog_category.title)
- end
-
- describe "create blog post" do
- before(:each) do
- fill_in "Title", :with => "This is my blog post"
- fill_in "blog_post_body", :with => "And I love it"
- check blog_category.title
- click_button "Save"
- end
-
- it "should succeed" do
- page.should have_content("was successfully added.")
- end
-
- it "should be the only blog post" do
- ::Refinery::Blog::Post.all.size.should eq(1)
- end
-
- it "should belong to me" do
- ::Refinery::Blog::Post.first.author.should eq(::Refinery::User.last)
- end
-
- it "should save categories" do
- ::Refinery::Blog::Post.last.categories.count.should eq(1)
- ::Refinery::Blog::Post.last.categories.first.title.should eq(blog_category.title)
- end
- end
-
- describe "create blog post with tags" do
- before(:each) do
- @tag_list = "chicago, bikes, beers, babes"
- fill_in "Title", :with => "This is a tagged blog post"
- fill_in "blog_post_body", :with => "And I also love it"
- fill_in "Tags", :with => @tag_list
- click_button "Save"
- end
-
- it "should succeed" do
- page.should have_content("was successfully added.")
- end
-
- it "should be the only blog post" do
- ::Refinery::Blog::Post.all.size.should eq(1)
- end
-
- it "should have the specified tags" do
- ::Refinery::Blog::Post.last.tag_list.should eq(@tag_list.split(', '))
- end
- end
- end
- end
-
- context "when has blog posts" do
- let!(:blog_post) { FactoryGirl.create(:blog_post) }
-
- describe "blog post listing" do
- before(:each) { visit refinery_admin_blog_posts_path }
-
- describe "edit blog post" do
- it "should succeed" do
- page.should have_content(blog_post.title)
-
- click_link("Edit this blog post")
- current_path.should == edit_refinery_admin_blog_post_path(blog_post)
-
- fill_in "Title", :with => "hax0r"
- click_button "Save"
-
- page.should_not have_content(blog_post.title)
- page.should have_content("'hax0r' was successfully updated.")
- end
- end
-
- describe "deleting blog post" do
- it "should succeed" do
- page.should have_content(blog_post.title)
-
- click_link "Remove this blog post forever"
-
- page.should have_content("'#{blog_post.title}' was successfully removed.")
- end
- end
-
- describe "view live" do
- it "redirects to blog post in the frontend" do
- click_link "View this blog post live"
-
- current_path.should == blog_post_path(blog_post)
- page.should have_content(blog_post.title)
- end
- end
- end
-
- context "when uncategorized post" do
- it "shows up in the list" do
- visit uncategorized_refinery_admin_blog_posts_path
- page.should have_content(blog_post.title)
- end
- end
-
- context "when categorized post" do
- it "won't show up in the list" do
- blog_post.categories << blog_category
- blog_post.save!
-
- visit uncategorized_refinery_admin_blog_posts_path
- page.should_not have_content(blog_post.title)
- end
- end
- end
-
- context "with multiple users" do
- let!(:other_guy) { Factory(:refinery_user, :username => "Other Guy") }
-
- describe "create blog post with alternate author" do
- before(:each) do
- visit refinery_admin_blog_posts_path
- click_link "Create new post"
-
- fill_in "Title", :with => "This is some other guy's blog post"
- fill_in "blog_post_body", :with => "I totally didn't write it."
-
- click_link "Advanced Options"
-
- select other_guy.username, :from => "Author"
-
- click_button "Save"
- end
-
- it "should succeed" do
- page.should have_content("was successfully added.")
- end
-
- it "belongs to another user" do
- ::Refinery::Blog::Post.last.author.should eq(other_guy)
- end
- end
- end
- end
-end
diff --git a/spec/requests/refinery/blog/admin/comments_spec.rb b/spec/requests/refinery/blog/admin/comments_spec.rb
new file mode 100644
index 0000000..b1a5afe
--- /dev/null
+++ b/spec/requests/refinery/blog/admin/comments_spec.rb
@@ -0,0 +1,128 @@
+require "spec_helper"
+
+module Refinery
+ module Blog
+ module Admin
+ describe Comment do
+ login_refinery_user
+
+ describe "#index" do
+ context "when has no new unapproved comments" do
+ before(:each) do
+ subject.class.delete_all
+ visit refinery_blog_admin_comments_path
+ end
+
+ it "should list no comments" do
+ visit refinery_blog_admin_comments_path
+
+ page.should have_content('there are no new comments')
+ end
+ end
+
+ context "when has new unapproved comments" do
+ let!(:blog_comment) { FactoryGirl.create(:blog_comment) }
+ before(:each) { visit refinery_blog_admin_comments_path }
+
+ it "should list comments" do
+ page.should have_content(blog_comment.body)
+ page.should have_content(blog_comment.name)
+ end
+
+ it "should allow me to approve a comment" do
+ click_link "Approve this comment"
+
+ page.should have_content("has been approved")
+ end
+
+ it "should allow me to reject a comment" do
+ click_link "Reject this comment"
+
+ page.should have_content("has been rejected")
+ end
+ end
+ end
+
+ describe "#approved" do
+ context "when has no approved comments" do
+ before(:each) do
+ subject.class.delete_all
+ visit approved_refinery_blog_admin_comments_path
+ end
+
+ it "should list no comments" do
+ page.should have_content('there are no approved comments')
+ end
+ end
+
+ context "when has approved comments" do
+ let!(:blog_comment) do
+ FactoryGirl.create(:blog_comment,
+ :state => 'approved')
+ end
+ before(:each) { visit approved_refinery_blog_admin_comments_path }
+
+ it "should list comments" do
+ page.should have_content(blog_comment.body)
+ page.should have_content(blog_comment.name)
+ end
+
+ it "should allow me to reject a comment" do
+ click_link "Reject this comment"
+
+ page.should have_content("has been rejected")
+ end
+ end
+ end
+
+ describe "#rejected" do
+ context "when has no rejected comments" do
+ before(:each) do
+ subject.class.delete_all
+ visit rejected_refinery_blog_admin_comments_path
+ end
+
+ it "should list no comments" do
+ page.should have_content('there are no rejected comments')
+ end
+ end
+
+ context "when has rejected comments" do
+ let!(:blog_comment) do
+ FactoryGirl.create(:blog_comment,
+ :state => 'rejected')
+ end
+ before(:each) { visit rejected_refinery_blog_admin_comments_path }
+
+ it "should list comments" do
+ page.should have_content(blog_comment.body)
+ page.should have_content(blog_comment.name)
+ end
+
+ it "should allow me to approve a comment" do
+ click_link "Approve this comment"
+
+ page.should have_content("has been approved")
+ end
+ end
+ end
+
+ describe "#show" do
+ let!(:blog_comment) { FactoryGirl.create(:blog_comment) }
+ before(:each) { visit refinery_blog_admin_comment_path(blog_comment) }
+
+ it "should display the comment" do
+ page.should have_content(blog_comment.body)
+ page.should have_content(blog_comment.name)
+ end
+
+ it "should allow me to approve the comment" do
+ click_link "Approve this comment"
+
+ page.should have_content("has been approved")
+ end
+ end
+ end
+ end
+ end
+end \ No newline at end of file
diff --git a/spec/requests/refinery/admin/menu_spec.rb b/spec/requests/refinery/blog/admin/menu_spec.rb
index b02a473..b02a473 100644
--- a/spec/requests/refinery/admin/menu_spec.rb
+++ b/spec/requests/refinery/blog/admin/menu_spec.rb
diff --git a/spec/requests/refinery/blog/admin/posts_spec.rb b/spec/requests/refinery/blog/admin/posts_spec.rb
new file mode 100644
index 0000000..6c50c37
--- /dev/null
+++ b/spec/requests/refinery/blog/admin/posts_spec.rb
@@ -0,0 +1,175 @@
+require "spec_helper"
+
+module Refinery
+ module Blog
+ module Admin
+ describe Post do
+ login_refinery_user
+
+ let!(:blog_category) { FactoryGirl.create(:blog_category, :title => "Video Games") }
+
+ context "when no blog posts" do
+ before(:each) { subject.class.destroy_all }
+
+ describe "blog post listing" do
+ before(:each) { visit refinery_blog_admin_posts_path }
+
+ it "invites to create new post" do
+ page.should have_content("There are no Blog Posts yet. Click \"Create new post\" to add your first blog post.")
+ end
+ end
+
+ describe "new blog post form" do
+ before(:each) do
+ visit refinery_blog_admin_posts_path
+ click_link "Create new post"
+ end
+
+ it "should have Tags" do
+ page.should have_content("Tags")
+ end
+
+ it "should have Video Games" do
+ page.should have_content(blog_category.title)
+ end
+
+ describe "create blog post" do
+ before(:each) do
+ fill_in "Title", :with => "This is my blog post"
+ fill_in "blog_post_body", :with => "And I love it"
+ check blog_category.title
+ click_button "Save"
+ end
+
+ it "should succeed" do
+ page.should have_content("was successfully added.")
+ end
+
+ it "should be the only blog post" do
+ subject.class.all.size.should eq(1)
+ end
+
+ it "should belong to me" do
+ subject.class.first.author.should eq(::Refinery::User.last)
+ end
+
+ it "should save categories" do
+ subject.class.last.categories.count.should eq(1)
+ subject.class.last.categories.first.title.should eq(blog_category.title)
+ end
+ end
+
+ describe "create blog post with tags" do
+ before(:each) do
+ @tag_list = "chicago, bikes, beers, babes"
+ fill_in "Title", :with => "This is a tagged blog post"
+ fill_in "blog_post_body", :with => "And I also love it"
+ fill_in "Tags", :with => @tag_list
+ click_button "Save"
+ end
+
+ it "should succeed" do
+ page.should have_content("was successfully added.")
+ end
+
+ it "should be the only blog post" do
+ subject.class.all.size.should eq(1)
+ end
+
+ it "should have the specified tags" do
+ subject.class.last.tag_list.should eq(@tag_list.split(', '))
+ end
+ end
+ end
+ end
+
+ context "when has blog posts" do
+ let!(:blog_post) { FactoryGirl.create(:blog_post) }
+
+ describe "blog post listing" do
+ before(:each) { visit refinery_blog_admin_posts_path }
+
+ describe "edit blog post" do
+ it "should succeed" do
+ page.should have_content(blog_post.title)
+
+ click_link("Edit this blog post")
+ current_path.should == edit_refinery_blog_admin_post_path(blog_post)
+
+ fill_in "Title", :with => "hax0r"
+ click_button "Save"
+
+ page.should_not have_content(blog_post.title)
+ page.should have_content("'hax0r' was successfully updated.")
+ end
+ end
+
+ describe "deleting blog post" do
+ it "should succeed" do
+ page.should have_content(blog_post.title)
+
+ click_link "Remove this blog post forever"
+
+ page.should have_content("'#{blog_post.title}' was successfully removed.")
+ end
+ end
+
+ describe "view live" do
+ it "redirects to blog post in the frontend" do
+ click_link "View this blog post live"
+
+ current_path.should == blog_post_path(blog_post)
+ page.should have_content(blog_post.title)
+ end
+ end
+ end
+
+ context "when uncategorized post" do
+ it "shows up in the list" do
+ visit uncategorized_refinery_blog_admin_posts_path
+ page.should have_content(blog_post.title)
+ end
+ end
+
+ context "when categorized post" do
+ it "won't show up in the list" do
+ blog_post.categories << blog_category
+ blog_post.save!
+
+ visit uncategorized_refinery_blog_admin_posts_path
+ page.should_not have_content(blog_post.title)
+ end
+ end
+ end
+
+ context "with multiple users" do
+ let!(:other_guy) { Factory(:refinery_user, :username => "Other Guy") }
+
+ describe "create blog post with alternate author" do
+ before(:each) do
+ visit refinery_blog_admin_posts_path
+ click_link "Create new post"
+
+ fill_in "Title", :with => "This is some other guy's blog post"
+ fill_in "blog_post_body", :with => "I totally didn't write it."
+
+ click_link "Advanced Options"
+
+ select other_guy.username, :from => "Author"
+
+ click_button "Save"
+ end
+
+ it "should succeed" do
+ page.should have_content("was successfully added.")
+ end
+
+ it "belongs to another user" do
+ subject.class.last.author.should eq(other_guy)
+ end
+ end
+ end
+ end
+ end
+ end
+end \ No newline at end of file