Merge branch 'master' into glitch-soc/merge-upstream
This commit is contained in:
		
						commit
						04e2c67389
					
				
							
								
								
									
										2
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Gemfile
									
									
									
									
									
								
							@ -23,7 +23,7 @@ gem 'paperclip-av-transcoder', '~> 0.6'
 | 
				
			|||||||
gem 'streamio-ffmpeg', '~> 3.0'
 | 
					gem 'streamio-ffmpeg', '~> 3.0'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
gem 'active_model_serializers', '~> 0.10'
 | 
					gem 'active_model_serializers', '~> 0.10'
 | 
				
			||||||
gem 'addressable', '~> 2.5'
 | 
					gem 'addressable', '~> 2.6'
 | 
				
			||||||
gem 'bootsnap', '~> 1.3', require: false
 | 
					gem 'bootsnap', '~> 1.3', require: false
 | 
				
			||||||
gem 'browser'
 | 
					gem 'browser'
 | 
				
			||||||
gem 'charlock_holmes', '~> 0.7.6'
 | 
					gem 'charlock_holmes', '~> 0.7.6'
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										18
									
								
								Gemfile.lock
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								Gemfile.lock
									
									
									
									
									
								
							@ -62,7 +62,7 @@ GEM
 | 
				
			|||||||
      i18n (>= 0.7, < 2)
 | 
					      i18n (>= 0.7, < 2)
 | 
				
			||||||
      minitest (~> 5.1)
 | 
					      minitest (~> 5.1)
 | 
				
			||||||
      tzinfo (~> 1.1)
 | 
					      tzinfo (~> 1.1)
 | 
				
			||||||
    addressable (2.5.2)
 | 
					    addressable (2.6.0)
 | 
				
			||||||
      public_suffix (>= 2.0.2, < 4.0)
 | 
					      public_suffix (>= 2.0.2, < 4.0)
 | 
				
			||||||
    airbrussh (1.3.0)
 | 
					    airbrussh (1.3.0)
 | 
				
			||||||
      sshkit (>= 1.6.1, != 1.7.0)
 | 
					      sshkit (>= 1.6.1, != 1.7.0)
 | 
				
			||||||
@ -292,8 +292,8 @@ GEM
 | 
				
			|||||||
    json-ld (3.0.2)
 | 
					    json-ld (3.0.2)
 | 
				
			||||||
      multi_json (~> 1.12)
 | 
					      multi_json (~> 1.12)
 | 
				
			||||||
      rdf (>= 2.2.8, < 4.0)
 | 
					      rdf (>= 2.2.8, < 4.0)
 | 
				
			||||||
    json-ld-preloaded (3.0.0)
 | 
					    json-ld-preloaded (3.0.2)
 | 
				
			||||||
      json-ld (>= 2.2, < 4.0)
 | 
					      json-ld (~> 3.0)
 | 
				
			||||||
      multi_json (~> 1.12)
 | 
					      multi_json (~> 1.12)
 | 
				
			||||||
      rdf (~> 3.0)
 | 
					      rdf (~> 3.0)
 | 
				
			||||||
    jsonapi-renderer (0.2.0)
 | 
					    jsonapi-renderer (0.2.0)
 | 
				
			||||||
@ -365,7 +365,7 @@ GEM
 | 
				
			|||||||
      concurrent-ruby (~> 1.0, >= 1.0.2)
 | 
					      concurrent-ruby (~> 1.0, >= 1.0.2)
 | 
				
			||||||
      sidekiq (>= 3.5)
 | 
					      sidekiq (>= 3.5)
 | 
				
			||||||
      statsd-ruby (~> 1.4, >= 1.4.0)
 | 
					      statsd-ruby (~> 1.4, >= 1.4.0)
 | 
				
			||||||
    oj (3.7.7)
 | 
					    oj (3.7.8)
 | 
				
			||||||
    omniauth (1.9.0)
 | 
					    omniauth (1.9.0)
 | 
				
			||||||
      hashie (>= 3.4.6, < 3.7.0)
 | 
					      hashie (>= 3.4.6, < 3.7.0)
 | 
				
			||||||
      rack (>= 1.6.2, < 3)
 | 
					      rack (>= 1.6.2, < 3)
 | 
				
			||||||
@ -391,7 +391,7 @@ GEM
 | 
				
			|||||||
    paperclip-av-transcoder (0.6.4)
 | 
					    paperclip-av-transcoder (0.6.4)
 | 
				
			||||||
      av (~> 0.9.0)
 | 
					      av (~> 0.9.0)
 | 
				
			||||||
      paperclip (>= 2.5.2)
 | 
					      paperclip (>= 2.5.2)
 | 
				
			||||||
    parallel (1.12.1)
 | 
					    parallel (1.13.0)
 | 
				
			||||||
    parallel_tests (2.27.1)
 | 
					    parallel_tests (2.27.1)
 | 
				
			||||||
      parallel
 | 
					      parallel
 | 
				
			||||||
    parser (2.6.0.0)
 | 
					    parser (2.6.0.0)
 | 
				
			||||||
@ -422,7 +422,7 @@ GEM
 | 
				
			|||||||
      pry (>= 0.10.4)
 | 
					      pry (>= 0.10.4)
 | 
				
			||||||
    public_suffix (3.0.3)
 | 
					    public_suffix (3.0.3)
 | 
				
			||||||
    puma (3.12.0)
 | 
					    puma (3.12.0)
 | 
				
			||||||
    pundit (2.0.0)
 | 
					    pundit (2.0.1)
 | 
				
			||||||
      activesupport (>= 3.0.0)
 | 
					      activesupport (>= 3.0.0)
 | 
				
			||||||
    raabro (1.1.6)
 | 
					    raabro (1.1.6)
 | 
				
			||||||
    rack (2.0.6)
 | 
					    rack (2.0.6)
 | 
				
			||||||
@ -515,7 +515,7 @@ GEM
 | 
				
			|||||||
    rspec-mocks (3.8.0)
 | 
					    rspec-mocks (3.8.0)
 | 
				
			||||||
      diff-lcs (>= 1.2.0, < 2.0)
 | 
					      diff-lcs (>= 1.2.0, < 2.0)
 | 
				
			||||||
      rspec-support (~> 3.8.0)
 | 
					      rspec-support (~> 3.8.0)
 | 
				
			||||||
    rspec-rails (3.8.1)
 | 
					    rspec-rails (3.8.2)
 | 
				
			||||||
      actionpack (>= 3.0)
 | 
					      actionpack (>= 3.0)
 | 
				
			||||||
      activesupport (>= 3.0)
 | 
					      activesupport (>= 3.0)
 | 
				
			||||||
      railties (>= 3.0)
 | 
					      railties (>= 3.0)
 | 
				
			||||||
@ -527,7 +527,7 @@ GEM
 | 
				
			|||||||
      rspec-core (~> 3.0, >= 3.0.0)
 | 
					      rspec-core (~> 3.0, >= 3.0.0)
 | 
				
			||||||
      sidekiq (>= 2.4.0)
 | 
					      sidekiq (>= 2.4.0)
 | 
				
			||||||
    rspec-support (3.8.0)
 | 
					    rspec-support (3.8.0)
 | 
				
			||||||
    rubocop (0.63.0)
 | 
					    rubocop (0.63.1)
 | 
				
			||||||
      jaro_winkler (~> 1.5.1)
 | 
					      jaro_winkler (~> 1.5.1)
 | 
				
			||||||
      parallel (~> 1.10)
 | 
					      parallel (~> 1.10)
 | 
				
			||||||
      parser (>= 2.5, != 2.5.1.1)
 | 
					      parser (>= 2.5, != 2.5.1.1)
 | 
				
			||||||
@ -657,7 +657,7 @@ PLATFORMS
 | 
				
			|||||||
DEPENDENCIES
 | 
					DEPENDENCIES
 | 
				
			||||||
  active_model_serializers (~> 0.10)
 | 
					  active_model_serializers (~> 0.10)
 | 
				
			||||||
  active_record_query_trace (~> 1.5)
 | 
					  active_record_query_trace (~> 1.5)
 | 
				
			||||||
  addressable (~> 2.5)
 | 
					  addressable (~> 2.6)
 | 
				
			||||||
  annotate (~> 2.7)
 | 
					  annotate (~> 2.7)
 | 
				
			||||||
  aws-sdk-s3 (~> 1.30)
 | 
					  aws-sdk-s3 (~> 1.30)
 | 
				
			||||||
  better_errors (~> 2.5)
 | 
					  better_errors (~> 2.5)
 | 
				
			||||||
 | 
				
			|||||||
@ -845,6 +845,18 @@ $small-breakpoint: 960px;
 | 
				
			|||||||
      margin-bottom: 0;
 | 
					      margin-bottom: 0;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    strong {
 | 
				
			||||||
 | 
					      display: inline;
 | 
				
			||||||
 | 
					      margin: 0;
 | 
				
			||||||
 | 
					      padding: 0;
 | 
				
			||||||
 | 
					      font-weight: 700;
 | 
				
			||||||
 | 
					      background: transparent;
 | 
				
			||||||
 | 
					      font-family: inherit;
 | 
				
			||||||
 | 
					      font-size: inherit;
 | 
				
			||||||
 | 
					      line-height: inherit;
 | 
				
			||||||
 | 
					      color: lighten($darker-text-color, 10%);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    .account {
 | 
					    .account {
 | 
				
			||||||
      border-bottom: 0;
 | 
					      border-bottom: 0;
 | 
				
			||||||
      padding: 0;
 | 
					      padding: 0;
 | 
				
			||||||
 | 
				
			|||||||
@ -54,7 +54,7 @@ table {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
html {
 | 
					html {
 | 
				
			||||||
  scrollbar-color: lighten($ui-base-color, 4%) transparent;
 | 
					  scrollbar-color: lighten($ui-base-color, 4%) rgba($base-overlay-background, 0.1);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
::-webkit-scrollbar {
 | 
					::-webkit-scrollbar {
 | 
				
			||||||
 | 
				
			|||||||
@ -69,7 +69,10 @@ class PostStatusService < BaseService
 | 
				
			|||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  def schedule_status!
 | 
					  def schedule_status!
 | 
				
			||||||
    if @account.statuses.build(status_attributes).valid?
 | 
					    status_for_validation = @account.statuses.build(status_attributes)
 | 
				
			||||||
 | 
					    if status_for_validation.valid?
 | 
				
			||||||
 | 
					      status_for_validation.destroy
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      # The following transaction block is needed to wrap the UPDATEs to
 | 
					      # The following transaction block is needed to wrap the UPDATEs to
 | 
				
			||||||
      # the media attachments when the scheduled status is created
 | 
					      # the media attachments when the scheduled status is created
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -10,7 +10,7 @@ class VerifyLinkService < BaseService
 | 
				
			|||||||
    return unless link_back_present?
 | 
					    return unless link_back_present?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    field.mark_verified!
 | 
					    field.mark_verified!
 | 
				
			||||||
  rescue HTTP::Error, Addressable::URI::InvalidURIError, Mastodon::HostValidationError, Mastodon::LengthValidationError => e
 | 
					  rescue OpenSSL::SSL::SSLError, HTTP::Error, Addressable::URI::InvalidURIError, Mastodon::HostValidationError, Mastodon::LengthValidationError => e
 | 
				
			||||||
    Rails.logger.debug "Error fetching link #{@url}: #{e}"
 | 
					    Rails.logger.debug "Error fetching link #{@url}: #{e}"
 | 
				
			||||||
    nil
 | 
					    nil
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
				
			|||||||
@ -36,6 +36,20 @@ RSpec.describe PostStatusService, type: :service do
 | 
				
			|||||||
    expect(status.params['text']).to eq 'Hi future!'
 | 
					    expect(status.params['text']).to eq 'Hi future!'
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it 'does not immediately create a status when scheduling a status' do
 | 
				
			||||||
 | 
					    account = Fabricate(:account)
 | 
				
			||||||
 | 
					    media = Fabricate(:media_attachment)
 | 
				
			||||||
 | 
					    future  = Time.now.utc + 2.hours
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    status = subject.call(account, text: 'Hi future!', media_ids: [media.id], scheduled_at: future)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    expect(status).to be_a ScheduledStatus
 | 
				
			||||||
 | 
					    expect(status.scheduled_at).to eq future
 | 
				
			||||||
 | 
					    expect(status.params['text']).to eq 'Hi future!'
 | 
				
			||||||
 | 
					    expect(media.reload.status).to be_nil
 | 
				
			||||||
 | 
					    expect(Status.where(text: 'Hi future!').exists?).to be_falsey
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  it 'creates response to the original status of boost' do
 | 
					  it 'creates response to the original status of boost' do
 | 
				
			||||||
    boosted_status = Fabricate(:status)
 | 
					    boosted_status = Fabricate(:status)
 | 
				
			||||||
    in_reply_to_status = Fabricate(:status, reblog: boosted_status)
 | 
					    in_reply_to_status = Fabricate(:status, reblog: boosted_status)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user