Add coverage for `CLI::Feeds` command (#25319)
This commit is contained in:
parent
07933db788
commit
b5675e265e
|
@ -19,7 +19,7 @@ module Mastodon::CLI
|
||||||
LONG_DESC
|
LONG_DESC
|
||||||
def build(username = nil)
|
def build(username = nil)
|
||||||
if options[:all] || username.nil?
|
if options[:all] || username.nil?
|
||||||
processed, = parallelize_with_progress(Account.joins(:user).merge(User.active)) do |account|
|
processed, = parallelize_with_progress(active_user_accounts) do |account|
|
||||||
PrecomputeFeedService.new.call(account) unless dry_run?
|
PrecomputeFeedService.new.call(account) unless dry_run?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -47,5 +47,11 @@ module Mastodon::CLI
|
||||||
redis.del(keys)
|
redis.del(keys)
|
||||||
say('OK', :green)
|
say('OK', :green)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def active_user_accounts
|
||||||
|
Account.joins(:user).merge(User.active)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,9 +4,65 @@ require 'rails_helper'
|
||||||
require 'mastodon/cli/feeds'
|
require 'mastodon/cli/feeds'
|
||||||
|
|
||||||
describe Mastodon::CLI::Feeds do
|
describe Mastodon::CLI::Feeds do
|
||||||
|
let(:cli) { described_class.new }
|
||||||
|
|
||||||
describe '.exit_on_failure?' do
|
describe '.exit_on_failure?' do
|
||||||
it 'returns true' do
|
it 'returns true' do
|
||||||
expect(described_class.exit_on_failure?).to be true
|
expect(described_class.exit_on_failure?).to be true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#build' do
|
||||||
|
before { Fabricate(:account) }
|
||||||
|
|
||||||
|
context 'with --all option' do
|
||||||
|
let(:options) { { all: true } }
|
||||||
|
|
||||||
|
it 'regenerates feeds for all accounts' do
|
||||||
|
expect { cli.invoke(:build, [], options) }.to output(
|
||||||
|
a_string_including('Regenerated feeds')
|
||||||
|
).to_stdout
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with a username' do
|
||||||
|
before { Fabricate(:account, username: 'alice') }
|
||||||
|
|
||||||
|
let(:arguments) { ['alice'] }
|
||||||
|
|
||||||
|
it 'regenerates feeds for the account' do
|
||||||
|
expect { cli.invoke(:build, arguments) }.to output(
|
||||||
|
a_string_including('OK')
|
||||||
|
).to_stdout
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with invalid username' do
|
||||||
|
let(:arguments) { ['invalid-username'] }
|
||||||
|
|
||||||
|
it 'displays an error and exits' do
|
||||||
|
expect { cli.invoke(:build, arguments) }.to output(
|
||||||
|
a_string_including('No such account')
|
||||||
|
).to_stdout.and raise_error(SystemExit)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe '#clear' do
|
||||||
|
before do
|
||||||
|
allow(redis).to receive(:del).with(key_namespace)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'clears the redis `feed:*` namespace' do
|
||||||
|
expect { cli.invoke(:clear) }.to output(
|
||||||
|
a_string_including('OK')
|
||||||
|
).to_stdout
|
||||||
|
|
||||||
|
expect(redis).to have_received(:del).with(key_namespace).once
|
||||||
|
end
|
||||||
|
|
||||||
|
def key_namespace
|
||||||
|
redis.keys('feed:*')
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue