forked from treehouse/mastodon
Only re-download avatar if URL changed (fix #19)
parent
921f40c187
commit
02e4fb2e06
|
@ -5,7 +5,6 @@ class Account < ActiveRecord::Base
|
||||||
validates :username, uniqueness: { scope: :domain, case_sensitive: true }, unless: 'local?'
|
validates :username, uniqueness: { scope: :domain, case_sensitive: true }, unless: 'local?'
|
||||||
|
|
||||||
# Avatar upload
|
# Avatar upload
|
||||||
attr_reader :avatar_remote_url
|
|
||||||
has_attached_file :avatar, styles: { large: '300x300#', medium: '96x96#', small: '48x48#' }, default_url: 'avatars/missing.png'
|
has_attached_file :avatar, styles: { large: '300x300#', medium: '96x96#', small: '48x48#' }, default_url: 'avatars/missing.png'
|
||||||
validates_attachment_content_type :avatar, content_type: /\Aimage\/.*\Z/
|
validates_attachment_content_type :avatar, content_type: /\Aimage\/.*\Z/
|
||||||
|
|
||||||
|
@ -91,8 +90,11 @@ class Account < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
|
|
||||||
def avatar_remote_url=(url)
|
def avatar_remote_url=(url)
|
||||||
|
unless self[:avatar_remote_url] == url
|
||||||
self.avatar = URI.parse(url)
|
self.avatar = URI.parse(url)
|
||||||
@avatar_remote_url = url
|
end
|
||||||
|
|
||||||
|
self[:avatar_remote_url] = url
|
||||||
end
|
end
|
||||||
|
|
||||||
def to_param
|
def to_param
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
class AddAvatarRemoteUrlToAccounts < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
add_column :accounts, :avatar_remote_url, :string, null: true, default: nil
|
||||||
|
end
|
||||||
|
end
|
|
@ -11,7 +11,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(version: 20160316103650) do
|
ActiveRecord::Schema.define(version: 20160322193748) do
|
||||||
|
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "plpgsql"
|
enable_extension "plpgsql"
|
||||||
|
@ -40,6 +40,7 @@ ActiveRecord::Schema.define(version: 20160316103650) do
|
||||||
t.string "header_content_type"
|
t.string "header_content_type"
|
||||||
t.integer "header_file_size"
|
t.integer "header_file_size"
|
||||||
t.datetime "header_updated_at"
|
t.datetime "header_updated_at"
|
||||||
|
t.string "avatar_remote_url"
|
||||||
end
|
end
|
||||||
|
|
||||||
add_index "accounts", ["username", "domain"], name: "index_accounts_on_username_and_domain", unique: true, using: :btree
|
add_index "accounts", ["username", "domain"], name: "index_accounts_on_username_and_domain", unique: true, using: :btree
|
||||||
|
|
|
@ -1,5 +1,59 @@
|
||||||
require 'rails_helper'
|
require 'rails_helper'
|
||||||
|
|
||||||
RSpec.describe UpdateRemoteProfileService do
|
RSpec.describe UpdateRemoteProfileService do
|
||||||
|
let(:xml) { Nokogiri::XML(File.read(File.join(Rails.root, 'spec', 'fixtures', 'push', 'feed.atom'))).at_xpath('//xmlns:author') }
|
||||||
|
|
||||||
subject { UpdateRemoteProfileService.new }
|
subject { UpdateRemoteProfileService.new }
|
||||||
|
|
||||||
|
before do
|
||||||
|
stub_request(:get, 'https://quitter.no/avatar/7477-300-20160211190340.png').to_return(request_fixture('avatar.txt'))
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with updated details' do
|
||||||
|
let(:remote_account) { Fabricate(:account, username: 'bob', domain: 'example.com') }
|
||||||
|
|
||||||
|
before do
|
||||||
|
subject.(xml, remote_account)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'downloads new avatar' do
|
||||||
|
expect(a_request(:get, 'https://quitter.no/avatar/7477-300-20160211190340.png')).to have_been_made
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets the avatar remote url' do
|
||||||
|
expect(remote_account.reload.avatar_remote_url).to eq 'https://quitter.no/avatar/7477-300-20160211190340.png'
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets display name' do
|
||||||
|
expect(remote_account.reload.display_name).to eq 'DIGITAL CAT'
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets note' do
|
||||||
|
expect(remote_account.reload.note).to eq 'Software engineer, free time musician and DIGITAL SPORTS enthusiast. Likes cats. Warning: May contain memes'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with unchanged details' do
|
||||||
|
let(:remote_account) { Fabricate(:account, username: 'bob', domain: 'example.com',display_name: 'DIGITAL CAT', note: 'Software engineer, free time musician and DIGITAL SPORTS enthusiast. Likes cats. Warning: May contain memes', avatar_remote_url: 'https://quitter.no/avatar/7477-300-20160211190340.png') }
|
||||||
|
|
||||||
|
before do
|
||||||
|
subject.(xml, remote_account)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'does not re-download avatar' do
|
||||||
|
expect(a_request(:get, 'https://quitter.no/avatar/7477-300-20160211190340.png')).to have_been_made.once
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets the avatar remote url' do
|
||||||
|
expect(remote_account.reload.avatar_remote_url).to eq 'https://quitter.no/avatar/7477-300-20160211190340.png'
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets display name' do
|
||||||
|
expect(remote_account.reload.display_name).to eq 'DIGITAL CAT'
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets note' do
|
||||||
|
expect(remote_account.reload.note).to eq 'Software engineer, free time musician and DIGITAL SPORTS enthusiast. Likes cats. Warning: May contain memes'
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue