Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/diaspora/diaspora.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/workers/remove_old_user_spec.rb')
-rw-r--r--spec/workers/remove_old_user_spec.rb52
1 files changed, 52 insertions, 0 deletions
diff --git a/spec/workers/remove_old_user_spec.rb b/spec/workers/remove_old_user_spec.rb
new file mode 100644
index 000000000..12e0fad57
--- /dev/null
+++ b/spec/workers/remove_old_user_spec.rb
@@ -0,0 +1,52 @@
+require 'spec_helper'
+
+describe Workers::RemoveOldUser do
+ describe 'remove_old_users is active' do
+ before do
+ AppConfig.settings.maintenance.remove_old_users.enable = true
+ end
+
+ it '#removes user whose remove_after timestamp has passed' do
+ user = double(id: 1, remove_after: 1.day.ago, last_seen: 1000.days.ago)
+ allow(User).to receive(:find).with(user.id).and_return(user)
+ expect(user).to receive(:close_account!)
+ Workers::RemoveOldUser.new.perform(user.id)
+ end
+
+ it '#doesnt remove user whose remove_after timestamp hasnt passed' do
+ user = double(id: 1, remove_after: 1.day.from_now, last_seen: 1000.days.ago)
+ allow(User).to receive(:find).with(user.id).and_return(user)
+ expect(user).to_not receive(:close_account!)
+ Workers::RemoveOldUser.new.perform(user.id)
+ end
+
+ it '#doesnt remove user whose remove_after timestamp has passed but last_seen is recent' do
+ user = double(id: 1, remove_after: 1.day.ago, last_seen: 1.day.ago)
+ allow(User).to receive(:find).with(user.id).and_return(user)
+ expect(user).to_not receive(:close_account!)
+ Workers::RemoveOldUser.new.perform(user.id)
+ end
+
+ end
+
+ describe 'remove_old_users is inactive' do
+ before do
+ AppConfig.settings.maintenance.remove_old_users.enable = false
+ end
+
+ it '#doesnt remove user whose remove_after timestamp has passed' do
+ user = double(id: 1, remove_after: 1.day.ago, last_seen: 1000.days.ago)
+ allow(User).to receive(:find).with(user.id).and_return(user)
+ expect(user).to_not receive(:close_account!)
+ Workers::RemoveOldUser.new.perform(user.id)
+ end
+
+ it '#doesnt remove user whose remove_after timestamp hasnt passed' do
+ user = double(id: 1, remove_after: 1.day.from_now, last_seen: 1000.days.ago)
+ allow(User).to receive(:find).with(user.id).and_return(user)
+ expect(user).to_not receive(:close_account!)
+ Workers::RemoveOldUser.new.perform(user.id)
+ end
+
+ end
+end