2013-02-06 03:16:51 +08:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe ListController do
|
|
|
|
|
2013-02-26 00:42:20 +08:00
|
|
|
# we need some data
|
|
|
|
before do
|
2013-02-06 03:16:51 +08:00
|
|
|
@user = Fabricate(:coding_horror)
|
2013-03-23 23:02:59 +08:00
|
|
|
@post = Fabricate(:post, user: @user)
|
2013-06-22 04:31:40 +08:00
|
|
|
|
|
|
|
# forces tests down some code paths
|
|
|
|
SiteSetting.stubs(:top_menu).returns('latest,-video|new|unread|favorited|categories|category/beer')
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
|
2013-03-28 21:01:13 +08:00
|
|
|
describe 'indexes' do
|
|
|
|
|
|
|
|
[:latest, :hot].each do |filter|
|
2013-06-22 04:31:40 +08:00
|
|
|
context "#{filter}" do
|
2013-03-28 21:01:13 +08:00
|
|
|
before { xhr :get, filter }
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
[:favorited, :read, :posted, :unread, :new].each do |filter|
|
2013-06-22 04:31:40 +08:00
|
|
|
context "#{filter}" do
|
2013-03-28 21:01:13 +08:00
|
|
|
it { expect { xhr :get, filter }.to raise_error(Discourse::NotLoggedIn) }
|
|
|
|
end
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
|
2013-05-28 15:52:52 +08:00
|
|
|
it 'allows users to filter on a set of topic ids' do
|
2013-10-24 07:05:51 +08:00
|
|
|
p = create_post
|
|
|
|
|
2013-05-28 15:52:52 +08:00
|
|
|
xhr :get, :latest, format: :json, topic_ids: "#{p.topic_id}"
|
|
|
|
response.should be_success
|
|
|
|
parsed = JSON.parse(response.body)
|
|
|
|
parsed["topic_list"]["topics"].length.should == 1
|
|
|
|
end
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
|
2013-10-12 00:35:12 +08:00
|
|
|
describe 'RSS feeds' do
|
|
|
|
|
|
|
|
[:latest, :hot].each do |filter|
|
|
|
|
|
|
|
|
it 'renders RSS' do
|
|
|
|
get "#{filter}_feed", format: :rss
|
|
|
|
response.should be_success
|
|
|
|
response.content_type.should == 'application/rss+xml'
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
context 'category' do
|
|
|
|
|
|
|
|
context 'in a category' do
|
|
|
|
let(:category) { Fabricate(:category) }
|
|
|
|
|
|
|
|
it "raises an invalid access error when the user can't see the category" do
|
|
|
|
Guardian.any_instance.expects(:can_see?).with(category).returns(false)
|
|
|
|
xhr :get, :category, category: category.slug
|
|
|
|
response.should be_forbidden
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with access to see the category' do
|
|
|
|
before do
|
|
|
|
xhr :get, :category, category: category.slug
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
2013-02-15 05:51:48 +08:00
|
|
|
|
|
|
|
context 'with a link that includes an id' do
|
|
|
|
before do
|
2013-02-15 06:13:03 +08:00
|
|
|
xhr :get, :category, category: "#{category.id}-#{category.slug}"
|
2013-02-15 05:51:48 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
2013-08-23 03:46:17 +08:00
|
|
|
context 'another category exists with a number at the beginning of its name' do
|
|
|
|
# One category has another category's id at the beginning of its name
|
|
|
|
let!(:other_category) { Fabricate(:category, name: "#{category.id} name") }
|
|
|
|
|
|
|
|
before do
|
|
|
|
xhr :get, :category, category: other_category.slug
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
|
|
|
|
it 'uses the correct category' do
|
|
|
|
assigns(:category).should == other_category
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-10-24 02:40:39 +08:00
|
|
|
context 'a child category' do
|
|
|
|
let(:sub_category) { Fabricate(:category, parent_category_id: category.id) }
|
|
|
|
|
|
|
|
context 'when parent and child are requested' do
|
|
|
|
before do
|
|
|
|
xhr :get, :category, parent_category: category.slug, category: sub_category.slug
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when child is requested with the wrong parent' do
|
|
|
|
before do
|
|
|
|
xhr :get, :category, parent_category: 'not_the_right_slug', category: sub_category.slug
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should_not respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when child is requested without a parent' do
|
|
|
|
before do
|
|
|
|
xhr :get, :category, category: sub_category.slug
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should_not respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2013-02-28 11:36:12 +08:00
|
|
|
describe 'feed' do
|
|
|
|
it 'renders RSS' do
|
|
|
|
get :category_feed, category: category.slug, format: :rss
|
|
|
|
response.should be_success
|
|
|
|
response.content_type.should == 'application/rss+xml'
|
|
|
|
end
|
|
|
|
end
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-10-19 21:21:17 +08:00
|
|
|
describe "topics_by" do
|
|
|
|
let!(:user) { log_in }
|
|
|
|
|
|
|
|
it "should respond with a list" do
|
|
|
|
xhr :get, :topics_by, username: @user.username
|
|
|
|
response.should be_success
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-10-01 02:35:11 +08:00
|
|
|
context "private_messages" do
|
|
|
|
let!(:user) { log_in }
|
|
|
|
|
|
|
|
it "raises an error when can_see_private_messages? is false " do
|
|
|
|
Guardian.any_instance.expects(:can_see_private_messages?).returns(false)
|
|
|
|
xhr :get, :private_messages, username: @user.username
|
|
|
|
response.should be_forbidden
|
|
|
|
end
|
|
|
|
|
|
|
|
it "succeeds when can_see_private_messages? is false " do
|
|
|
|
Guardian.any_instance.expects(:can_see_private_messages?).returns(true)
|
|
|
|
xhr :get, :private_messages, username: @user.username
|
|
|
|
response.should be_success
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "private_messages_sent" do
|
|
|
|
let!(:user) { log_in }
|
|
|
|
|
|
|
|
it "raises an error when can_see_private_messages? is false " do
|
|
|
|
Guardian.any_instance.expects(:can_see_private_messages?).returns(false)
|
|
|
|
xhr :get, :private_messages_sent, username: @user.username
|
|
|
|
response.should be_forbidden
|
|
|
|
end
|
|
|
|
|
|
|
|
it "succeeds when can_see_private_messages? is false " do
|
|
|
|
Guardian.any_instance.expects(:can_see_private_messages?).returns(true)
|
|
|
|
xhr :get, :private_messages_sent, username: @user.username
|
|
|
|
response.should be_success
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "private_messages_unread" do
|
|
|
|
let!(:user) { log_in }
|
|
|
|
|
|
|
|
it "raises an error when can_see_private_messages? is false " do
|
|
|
|
Guardian.any_instance.expects(:can_see_private_messages?).returns(false)
|
|
|
|
xhr :get, :private_messages_unread, username: @user.username
|
|
|
|
response.should be_forbidden
|
|
|
|
end
|
|
|
|
|
|
|
|
it "succeeds when can_see_private_messages? is false " do
|
|
|
|
Guardian.any_instance.expects(:can_see_private_messages?).returns(true)
|
|
|
|
xhr :get, :private_messages_unread, username: @user.username
|
|
|
|
response.should be_success
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-28 04:17:49 +08:00
|
|
|
context 'hot' do
|
|
|
|
before do
|
|
|
|
xhr :get, :hot
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
context 'favorited' do
|
|
|
|
it 'raises an error when not logged in' do
|
|
|
|
lambda { xhr :get, :favorited }.should raise_error(Discourse::NotLoggedIn)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when logged in' do
|
|
|
|
before do
|
|
|
|
log_in_user(@user)
|
|
|
|
xhr :get, :favorited
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-28 04:17:49 +08:00
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
context 'read' do
|
|
|
|
it 'raises an error when not logged in' do
|
|
|
|
lambda { xhr :get, :read }.should raise_error(Discourse::NotLoggedIn)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when logged in' do
|
|
|
|
before do
|
|
|
|
log_in_user(@user)
|
|
|
|
xhr :get, :read
|
|
|
|
end
|
|
|
|
|
|
|
|
it { should respond_with(:success) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|