From 4d928001b85ddc864ac9f6cb4afd5c8a52b99fe5 Mon Sep 17 00:00:00 2001 From: Junegunn Choi Date: Sun, 22 Jan 2017 18:33:30 +0900 Subject: [PATCH] Update release script to upload assets in parallel --- src/update_assets.rb | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/update_assets.rb b/src/update_assets.rb index 2fd9edc2..b4aaba54 100755 --- a/src/update_assets.rb +++ b/src/update_assets.rb @@ -23,21 +23,23 @@ end # List assets assets = Hash[rel['assets'].map { |a| a.values_at *%w[name id] }] -files.select { |f| File.exists? f }.each do |file| - name = File.basename file +files.select { |f| File.exists? f }.map do |file| + Thread.new do + name = File.basename file - if asset_id = assets[name] - puts "#{name} found. Deleting asset id #{asset_id}." - RestClient.delete "#{base}/assets/#{asset_id}", - :authorization => "token #{token}" - else - puts "#{name} not found" + if asset_id = assets[name] + puts "#{name} found. Deleting asset id #{asset_id}." + RestClient.delete "#{base}/assets/#{asset_id}", + :authorization => "token #{token}" + else + puts "#{name} not found" + end + + puts "Uploading #{name}" + RestClient.post( + "#{base.sub 'api', 'uploads'}/#{rel['id']}/assets?name=#{name}", + File.read(file), + :authorization => "token #{token}", + :content_type => "application/octet-stream") end - - puts "Uploading #{name}" - RestClient.post( - "#{base.sub 'api', 'uploads'}/#{rel['id']}/assets?name=#{name}", - File.read(file), - :authorization => "token #{token}", - :content_type => "application/octet-stream") -end +end.each(&:join)