discourse/spec/jobs/update_gravatar_spec.rb
Daniel Waterworth 6e161d3e75
DEV: Allow fab! without block (#24314)
The most common thing that we do with fab! is:

    fab!(:thing) { Fabricate(:thing) }

This commit adds a shorthand for this which is just simply:

    fab!(:thing)

i.e. If you omit the block, then, by default, you'll get a `Fabricate`d object using the fabricator of the same name.
2023-11-09 16:47:59 -06:00

52 lines
1.4 KiB
Ruby

# frozen_string_literal: true
RSpec.describe Jobs::UpdateGravatar do
fab!(:user)
let(:temp) { Tempfile.new("test") }
fab!(:upload) { Fabricate(:upload, user: user) }
let(:avatar) { user.create_user_avatar! }
it "picks gravatar if system avatar is picked and gravatar was just downloaded" do
temp.binmode
# tiny valid png
temp.write(
Base64.decode64(
"iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAACklEQVR4nGMAAQAABQABDQottAAAAABJRU5ErkJggg==",
),
)
temp.rewind
FileHelper.expects(:download).returns(temp)
Jobs.run_immediately!
expect(user.uploaded_avatar_id).to eq(nil)
expect(user.user_avatar.gravatar_upload_id).to eq(nil)
SiteSetting.automatically_download_gravatars = true
user.refresh_avatar
user.reload
expect(user.uploaded_avatar_id).to_not eq(nil)
expect(user.uploaded_avatar_id).to eq(user.user_avatar.gravatar_upload_id)
temp.unlink
end
it "does not enqueue a job when user is missing their email" do
user.primary_email.destroy
user.reload
expect(user.uploaded_avatar_id).to eq(nil)
expect(user.user_avatar.gravatar_upload_id).to eq(nil)
SiteSetting.automatically_download_gravatars = true
expect { user.refresh_avatar }.not_to change { Jobs::UpdateGravatar.jobs.count }
user.reload
expect(user.uploaded_avatar_id).to eq(nil)
expect(user.user_avatar.gravatar_upload_id).to eq(nil)
end
end