diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-10-13 11:00:11 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-13 11:00:11 +0200 |
commit | 3283868e28794d7abe217c525aadf5e7b9e2fa66 (patch) | |
tree | a78887821d2ebf0d3f294703078d4c9e4e5772d3 | |
parent | dc91fd482a65cca24ae6f66f92e8e924124fce43 (diff) |
Improve spec of Feed and UserTrackingConcern (#5367)
-rw-r--r-- | spec/controllers/concerns/user_tracking_concern_spec.rb | 2 | ||||
-rw-r--r-- | spec/models/feed_spec.rb | 40 |
2 files changed, 34 insertions, 8 deletions
diff --git a/spec/controllers/concerns/user_tracking_concern_spec.rb b/spec/controllers/concerns/user_tracking_concern_spec.rb index 6bd29f887..168d44ba6 100644 --- a/spec/controllers/concerns/user_tracking_concern_spec.rb +++ b/spec/controllers/concerns/user_tracking_concern_spec.rb @@ -5,6 +5,7 @@ require 'rails_helper' describe ApplicationController, type: :controller do controller do include UserTrackingConcern + def show render plain: 'show' end @@ -49,6 +50,7 @@ describe ApplicationController, type: :controller do get :show expect_updated_sign_in_at(user) + expect(Redis.current.get("account:#{user.account_id}:regeneration")).to eq 'true' expect(RegenerationWorker).to have_received(:perform_async) end diff --git a/spec/models/feed_spec.rb b/spec/models/feed_spec.rb index 5433f44bd..8719369db 100644 --- a/spec/models/feed_spec.rb +++ b/spec/models/feed_spec.rb @@ -1,21 +1,45 @@ require 'rails_helper' RSpec.describe Feed, type: :model do + let(:account) { Fabricate(:account) } + + subject { described_class.new(:home, account) } + describe '#get' do - it 'gets statuses with ids in the range' do - account = Fabricate(:account) + before do Fabricate(:status, account: account, id: 1) Fabricate(:status, account: account, id: 2) Fabricate(:status, account: account, id: 3) Fabricate(:status, account: account, id: 10) - Redis.current.zadd(FeedManager.instance.key(:home, account.id), - [[4, 4], [3, 3], [2, 2], [1, 1]]) + end + + context 'when feed is generated' do + before do + Redis.current.zadd( + FeedManager.instance.key(:home, account.id), + [[4, 4], [3, 3], [2, 2], [1, 1]] + ) + end + + it 'gets statuses with ids in the range from redis' do + results = subject.get(3) + + expect(results.map(&:id)).to eq [3, 2] + expect(results.first.attributes.keys).to eq %w(id updated_at) + end + end + + context 'when feed is being generated' do + before do + Redis.current.set("account:#{account.id}:regeneration", true) + end - feed = Feed.new(:home, account) - results = feed.get(3) + it 'gets statuses with ids in the range from database' do + results = subject.get(3) - expect(results.map(&:id)).to eq [3, 2] - expect(results.first.attributes.keys).to eq %w(id updated_at) + expect(results.map(&:id)).to eq [10, 3, 2] + expect(results.first.attributes.keys).to include('id', 'updated_at') + end end end end |