We were very inconsistent regarding these rules. Personally I prefer no empty lines around blocks, clases, etc... as recommended by the Ruby style guide [1], and they're the default values in rubocop, so those are the settings I'm applying. The exception is the `private` access modifier, since we were leaving empty lines around it most of the time. That's the default rubocop rule as well. Personally I don't have a strong preference about this one. [1] https://rubystyle.guide/#empty-lines-around-bodies
91 lines
2.3 KiB
Ruby
91 lines
2.3 KiB
Ruby
require "rails_helper"
|
|
|
|
describe DirectMessage do
|
|
let(:direct_message) { build(:direct_message) }
|
|
|
|
it "is valid" do
|
|
expect(direct_message).to be_valid
|
|
end
|
|
|
|
it "is not valid without a title" do
|
|
direct_message.title = nil
|
|
expect(direct_message).not_to be_valid
|
|
end
|
|
|
|
it "is not valid without a body" do
|
|
direct_message.body = nil
|
|
expect(direct_message).not_to be_valid
|
|
end
|
|
|
|
it "is not valid without an associated sender" do
|
|
direct_message.sender = nil
|
|
expect(direct_message).not_to be_valid
|
|
end
|
|
|
|
it "is not valid without an associated receiver" do
|
|
direct_message.receiver = nil
|
|
expect(direct_message).not_to be_valid
|
|
end
|
|
|
|
describe "maximum number of direct messages per day" do
|
|
context "when set" do
|
|
before do
|
|
Setting[:direct_message_max_per_day] = 3
|
|
end
|
|
|
|
it "is not valid if above maximum" do
|
|
sender = create(:user)
|
|
3.times { create(:direct_message, sender: sender) }
|
|
|
|
direct_message4 = build(:direct_message, sender: sender)
|
|
expect(direct_message4).not_to be_valid
|
|
end
|
|
|
|
it "is valid if below maximum" do
|
|
sender = create(:user)
|
|
2.times { create(:direct_message, sender: sender) }
|
|
|
|
direct_message3 = build(:direct_message, sender: sender)
|
|
expect(direct_message3).to be_valid
|
|
end
|
|
|
|
it "is valid if no direct_messages sent" do
|
|
direct_message = build(:direct_message)
|
|
|
|
expect(direct_message).to be_valid
|
|
end
|
|
end
|
|
|
|
context "when unset" do
|
|
before do
|
|
Setting[:direct_message_max_per_day] = nil
|
|
end
|
|
|
|
it "is valid" do
|
|
direct_message = build(:direct_message)
|
|
|
|
expect(direct_message).to be_valid
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "scopes" do
|
|
describe "today", :with_non_utc_time_zone do
|
|
it "returns direct messages created today" do
|
|
create(:direct_message, created_at: Date.current.beginning_of_day)
|
|
create(:direct_message, created_at: Time.current)
|
|
create(:direct_message, created_at: Date.current.end_of_day)
|
|
|
|
expect(DirectMessage.today.count).to eq 3
|
|
end
|
|
|
|
it "does not return direct messages created another day" do
|
|
create(:direct_message, created_at: 1.day.ago)
|
|
create(:direct_message, created_at: 1.day.from_now)
|
|
|
|
expect(DirectMessage.today.count).to eq 0
|
|
end
|
|
end
|
|
end
|
|
end
|