about summary refs log tree commit diff
path: root/spec
diff options
context:
space:
mode:
authorTaras Gogol <taras2358@gmail.com>2020-05-08 21:17:16 +0300
committerGitHub <noreply@github.com>2020-05-08 20:17:16 +0200
commit6748a5acb1fc0e4652dde1ee6544d4ae2d6d4f26 (patch)
treed1e20db15b2af93bb6777907ddd69ac8c3c0491f /spec
parent1787dc2721d1095375ff27329376410593bddc10 (diff)
Fix followings list order | Issue #13538 (#13676)
Diffstat (limited to 'spec')
-rw-r--r--spec/models/relationship_filter_spec.rb37
1 files changed, 37 insertions, 0 deletions
diff --git a/spec/models/relationship_filter_spec.rb b/spec/models/relationship_filter_spec.rb
new file mode 100644
index 000000000..7c0f37a06
--- /dev/null
+++ b/spec/models/relationship_filter_spec.rb
@@ -0,0 +1,37 @@
+# frozen_string_literal: true
+
+require 'rails_helper'
+
+describe RelationshipFilter do
+  let(:account) { Fabricate(:account) }
+
+  describe '#results' do
+    context 'when default params are used' do
+      let(:subject) do
+        RelationshipFilter.new(account, 'order' => 'active').results
+      end
+
+      before do
+        add_following_account_with(last_status_at: 7.days.ago)
+        add_following_account_with(last_status_at: 1.day.ago)
+        add_following_account_with(last_status_at: 3.days.ago)
+      end
+
+      it 'returns followings ordered by last activity' do
+        expected_result = account.following.eager_load(:account_stat).reorder(nil).by_recent_status
+
+        expect(subject).to eq expected_result
+      end
+    end
+  end
+
+  def add_following_account_with(last_status_at:)
+    following_account = Fabricate(:account)
+    Fabricate(:account_stat, account: following_account,
+                             last_status_at: last_status_at,
+                             statuses_count: 1,
+                             following_count: 0,
+                             followers_count: 0)
+    Fabricate(:follow, account: account, target_account: following_account).account
+  end
+end