mirror of
https://github.com/discourse/discourse.git
synced 2024-12-01 13:09:33 -06:00
493d437e79
* Remove outdated option
04078317ba
* Use the non-globally exposed RSpec syntax
https://github.com/rspec/rspec-core/pull/2803
* Use the non-globally exposed RSpec syntax, cont
https://github.com/rspec/rspec-core/pull/2803
* Comply to strict predicate matchers
See:
- https://github.com/rspec/rspec-expectations/pull/1195
- https://github.com/rspec/rspec-expectations/pull/1196
- https://github.com/rspec/rspec-expectations/pull/1277
34 lines
1.1 KiB
Ruby
34 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe ComposerMessagesController do
|
|
fab!(:topic) { Fabricate(:topic, created_at: 10.years.ago, last_posted_at: 10.years.ago) }
|
|
fab!(:post) { Fabricate(:post, topic: topic, post_number: 1, created_at: 10.years.ago) }
|
|
|
|
describe '#index' do
|
|
it 'requires you to be logged in' do
|
|
get "/composer_messages.json"
|
|
expect(response.status).to eq(403)
|
|
end
|
|
|
|
context 'when logged in' do
|
|
let!(:user) { sign_in(Fabricate(:user)) }
|
|
let(:args) { { 'topic_id' => post.topic.id, 'post_id' => '333', 'composer_action' => 'reply' } }
|
|
|
|
it 'redirects to your user preferences' do
|
|
get "/composer_messages.json"
|
|
expect(response.status).to eq(200)
|
|
end
|
|
|
|
it 'delegates args to the finder' do
|
|
user.user_stat.update!(post_count: 10)
|
|
SiteSetting.disable_avatar_education_message = true
|
|
|
|
get "/composer_messages.json", params: args
|
|
expect(response.status).to eq(200)
|
|
json = response.parsed_body
|
|
expect(json["composer_messages"].first["id"]).to eq("reviving_old")
|
|
end
|
|
end
|
|
end
|
|
end
|