Skip to content

Commit

Permalink
Revert "build: hack around GitHub upload API failure / flake (#16665)"
Browse files Browse the repository at this point in the history
This reverts commit 233d346.
  • Loading branch information
codebytere committed Feb 3, 2019
1 parent 050b866 commit 0f66918
Showing 1 changed file with 11 additions and 24 deletions.
35 changes: 11 additions & 24 deletions script/upload-to-github.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,28 +36,17 @@ const uploadUrl = `https://uploads.github.com/repos/electron/${targetRepo}/relea
let retry = 0

function uploadToGitHub () {
const fakeFileNamePrefix = `fake-${fileName}-fake-`
const fakeFileName = `${fakeFileNamePrefix}${Date.now()}`

octokit.repos.uploadReleaseAsset({
url: uploadUrl,
headers: getHeaders(filePath, fileName),
file: fs.createReadStream(filePath),
name: fakeFileName
}).then((uploadResponse) => {
console.log(`Successfully uploaded ${fileName} to GitHub as ${fakeFileName}. Going for the rename now.`)
return octokit.repos.updateReleaseAsset({
owner: 'electron',
repo: 'electron',
asset_id: uploadResponse.data.id,
name: fileName
}).then(() => {
console.log(`Successfully renamed ${fakeFileName} to ${fileName}. All done now.`)
process.exit(0)
})
name: fileName
}).then(() => {
console.log(`Successfully uploaded ${fileName} to GitHub.`)
process.exit()
}).catch((err) => {
if (retry < 4) {
console.log(`Error uploading ${fileName} as ${fakeFileName} to GitHub, will retry. Error was:`, err)
console.log(`Error uploading ${fileName} to GitHub, will retry. Error was:`, err)
retry++

octokit.repos.listAssetsForRelease({
Expand All @@ -67,17 +56,15 @@ function uploadToGitHub () {
}).then(assets => {
console.log('Got list of assets for existing release:')
console.log(JSON.stringify(assets.data, null, ' '))
const existingAssets = assets.data.filter(asset => asset.name.startsWith(fakeFileNamePrefix) || asset.name === fileName)
const existingAssets = assets.data.filter(asset => asset.name === fileName)

if (existingAssets.length > 0) {
console.log(`${fileName} already exists; will delete before retrying upload.`)
Promise.all(
existingAssets.map(existingAsset => octokit.repos.deleteReleaseAsset({
owner: 'electron',
repo: targetRepo,
asset_id: existingAsset.id
}))
).catch((deleteErr) => {
octokit.repos.deleteReleaseAsset({
owner: 'electron',
repo: targetRepo,
asset_id: existingAssets[0].id
}).catch((deleteErr) => {
console.log(`Failed to delete existing asset ${fileName}. Error was:`, deleteErr)
}).then(uploadToGitHub)
} else {
Expand Down

0 comments on commit 0f66918

Please sign in to comment.