FIX: Regression where a topic rollback would not properly report errors to the client.
This commit is contained in:
parent
3ae72259a6
commit
1b5ec42173
|
@ -131,8 +131,15 @@ class PostCreator
|
||||||
def setup_topic
|
def setup_topic
|
||||||
if @opts[:topic_id].blank?
|
if @opts[:topic_id].blank?
|
||||||
topic_creator = TopicCreator.new(@user, guardian, @opts)
|
topic_creator = TopicCreator.new(@user, guardian, @opts)
|
||||||
topic = topic_creator.create
|
|
||||||
@errors = topic_creator.errors
|
begin
|
||||||
|
topic = topic_creator.create
|
||||||
|
@errors = topic_creator.errors
|
||||||
|
rescue ActiveRecord::Rollback => ex
|
||||||
|
# In the event of a rollback, grab the errors from the topic
|
||||||
|
@errors = topic_creator.errors
|
||||||
|
raise ex
|
||||||
|
end
|
||||||
|
|
||||||
@new_topic = true
|
@new_topic = true
|
||||||
else
|
else
|
||||||
|
|
|
@ -26,6 +26,18 @@ describe PostCreator do
|
||||||
lambda { creator.create }.should raise_error(Discourse::InvalidAccess)
|
lambda { creator.create }.should raise_error(Discourse::InvalidAccess)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
context "invalid title" do
|
||||||
|
|
||||||
|
let(:creator_invalid_title) { PostCreator.new(user, basic_topic_params.merge(title: 'a')) }
|
||||||
|
|
||||||
|
it "has errors" do
|
||||||
|
creator_invalid_title.create
|
||||||
|
expect(creator_invalid_title.errors).to be_present
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
context 'success' do
|
context 'success' do
|
||||||
|
|
||||||
it "doesn't return true for spam" do
|
it "doesn't return true for spam" do
|
||||||
|
|
Loading…
Reference in New Issue