mirror of
https://github.com/discourse/discourse.git
synced 2025-09-07 12:02:53 +08:00
PERF: Avoid hitting DB when fetching draft sequence of bot user.
This commit is contained in:
parent
39a2d90e0f
commit
d301af39bd
2 changed files with 17 additions and 3 deletions
|
@ -5,9 +5,16 @@ require 'rails_helper'
|
|||
describe DraftSequence do
|
||||
fab!(:user) { Fabricate(:user) }
|
||||
|
||||
it 'should produce next sequence for a key' do
|
||||
expect(DraftSequence.next!(user, 'test')).to eq 1
|
||||
expect(DraftSequence.next!(user, 'test')).to eq 2
|
||||
describe '.next' do
|
||||
it 'should produce next sequence for a key' do
|
||||
expect(DraftSequence.next!(user, 'test')).to eq 1
|
||||
expect(DraftSequence.next!(user, 'test')).to eq 2
|
||||
end
|
||||
|
||||
it 'should not produce next sequence for non-human user' do
|
||||
user.id = -99999
|
||||
2.times { expect(DraftSequence.next!(user, 'test')).to eq(0) }
|
||||
end
|
||||
end
|
||||
|
||||
describe '.current' do
|
||||
|
@ -15,6 +22,11 @@ describe DraftSequence do
|
|||
expect(DraftSequence.current(user, 'test')).to eq 0
|
||||
end
|
||||
|
||||
it 'should return nil for non-human user' do
|
||||
user.id = -99999
|
||||
expect(DraftSequence.current(user, 'test')).to eq(nil)
|
||||
end
|
||||
|
||||
it 'should return the right sequence' do
|
||||
expect(DraftSequence.next!(user, 'test')).to eq(1)
|
||||
expect(DraftSequence.current(user, 'test')).to eq(1)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue