mirror of
				https://github.com/mastodon/mastodon.git
				synced 2025-10-30 20:51:33 +00:00 
			
		
		
		
	Use URI.join even when S3 enabled (#4652)
This commit is contained in:
		
							parent
							
								
									6e9eda5331
								
							
						
					
					
						commit
						10e9a9a3f9
					
				|  | @ -12,6 +12,8 @@ module RoutingHelper | |||
|   end | ||||
| 
 | ||||
|   def full_asset_url(source, options = {}) | ||||
|     Rails.configuration.x.use_s3 ? source : URI.join(root_url, ActionController::Base.helpers.asset_url(source, options)).to_s | ||||
|     source = ActionController::Base.helpers.asset_url(source, options) unless Rails.configuration.x.use_s3 | ||||
| 
 | ||||
|     URI.join(root_url, source).to_s | ||||
|   end | ||||
| end | ||||
|  |  | |||
							
								
								
									
										43
									
								
								spec/helpers/routing_helper_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								spec/helpers/routing_helper_spec.rb
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,43 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| require 'rails_helper' | ||||
| 
 | ||||
| RSpec.describe RoutingHelper, type: :helper do | ||||
|   describe '.full_asset_url' do | ||||
|     around do |example| | ||||
|       use_s3 = Rails.configuration.x.use_s3 | ||||
|       example.run | ||||
|       Rails.configuration.x.use_s3 = use_s3 | ||||
|     end | ||||
| 
 | ||||
|     shared_examples 'returns full path URL' do | ||||
|       it 'with host' do | ||||
|         url = helper.full_asset_url('https://example.com/avatars/000/000/002/original/icon.png') | ||||
| 
 | ||||
|         expect(url).to eq 'https://example.com/avatars/000/000/002/original/icon.png' | ||||
|       end | ||||
| 
 | ||||
|       it 'without host' do | ||||
|         url = helper.full_asset_url('/avatars/original/missing.png', skip_pipeline: true) | ||||
| 
 | ||||
|         expect(url).to eq 'http://test.host/avatars/original/missing.png' | ||||
|       end | ||||
|     end | ||||
| 
 | ||||
|     context 'Do not use S3' do | ||||
|       before do | ||||
|         Rails.configuration.x.use_s3 = false | ||||
|       end | ||||
| 
 | ||||
|       it_behaves_like 'returns full path URL' | ||||
|     end | ||||
| 
 | ||||
|     context 'Use S3' do | ||||
|       before do | ||||
|         Rails.configuration.x.use_s3 = true | ||||
|       end | ||||
| 
 | ||||
|       it_behaves_like 'returns full path URL' | ||||
|     end | ||||
|   end | ||||
| end | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Yamagishi Kazutoshi
						Yamagishi Kazutoshi