mirror of
https://github.com/actions/upload-artifact.git
synced 2025-03-14 10:07:01 +00:00
94 lines
3.1 KiB
TypeScript
94 lines
3.1 KiB
TypeScript
import * as core from '@actions/core'
|
|
import * as github from '@actions/github'
|
|
import artifact, {
|
|
UploadArtifactOptions,
|
|
ArtifactNotFoundError
|
|
} from '@actions/artifact'
|
|
import {findFilesToUpload} from './search'
|
|
import {getInputs} from './input-helper'
|
|
import {NoFileOptions} from './constants'
|
|
|
|
async function deleteArtifactIfExists(artifactName: string): Promise<void> {
|
|
try {
|
|
await artifact.deleteArtifact(artifactName)
|
|
} catch (error) {
|
|
if (error instanceof ArtifactNotFoundError) {
|
|
core.debug(`Skipping deletion of '${artifactName}', it does not exist`)
|
|
return
|
|
}
|
|
|
|
// Best effort, we don't want to fail the action if this fails
|
|
core.debug(`Unable to delete artifact: ${(error as Error).message}`)
|
|
}
|
|
}
|
|
|
|
async function run(): Promise<void> {
|
|
try {
|
|
const inputs = getInputs()
|
|
const searchResult = await findFilesToUpload(inputs.searchPath)
|
|
if (searchResult.filesToUpload.length === 0) {
|
|
// No files were found, different use cases warrant different types of behavior if nothing is found
|
|
switch (inputs.ifNoFilesFound) {
|
|
case NoFileOptions.warn: {
|
|
core.warning(
|
|
`No files were found with the provided path: ${inputs.searchPath}. No artifacts will be uploaded.`
|
|
)
|
|
break
|
|
}
|
|
case NoFileOptions.error: {
|
|
core.setFailed(
|
|
`No files were found with the provided path: ${inputs.searchPath}. No artifacts will be uploaded.`
|
|
)
|
|
break
|
|
}
|
|
case NoFileOptions.ignore: {
|
|
core.info(
|
|
`No files were found with the provided path: ${inputs.searchPath}. No artifacts will be uploaded.`
|
|
)
|
|
break
|
|
}
|
|
}
|
|
} else {
|
|
const s = searchResult.filesToUpload.length === 1 ? '' : 's'
|
|
core.info(
|
|
`With the provided path, there will be ${searchResult.filesToUpload.length} file${s} uploaded`
|
|
)
|
|
core.debug(`Root artifact directory is ${searchResult.rootDirectory}`)
|
|
|
|
if (inputs.overwrite) {
|
|
await deleteArtifactIfExists(inputs.artifactName)
|
|
}
|
|
|
|
const options: UploadArtifactOptions = {}
|
|
if (inputs.retentionDays) {
|
|
options.retentionDays = inputs.retentionDays
|
|
}
|
|
|
|
if (typeof inputs.compressionLevel !== 'undefined') {
|
|
options.compressionLevel = inputs.compressionLevel
|
|
}
|
|
|
|
const uploadResponse = await artifact.uploadArtifact(
|
|
inputs.artifactName,
|
|
searchResult.filesToUpload,
|
|
searchResult.rootDirectory,
|
|
options
|
|
)
|
|
|
|
core.info(
|
|
`Artifact ${inputs.artifactName} has been successfully uploaded! Final size is ${uploadResponse.size} bytes. Artifact ID is ${uploadResponse.id}`
|
|
)
|
|
core.setOutput('artifact-id', uploadResponse.id)
|
|
|
|
const repository = github.context.repo
|
|
const artifactURL = `${github.context.serverUrl}/${repository.owner}/${repository.repo}/actions/runs/${github.context.runId}/artifacts/${uploadResponse.id}`
|
|
|
|
core.info(`Artifact download URL: ${artifactURL}`)
|
|
core.setOutput('artifact-url', artifactURL)
|
|
}
|
|
} catch (error) {
|
|
core.setFailed((error as Error).message)
|
|
}
|
|
}
|
|
|
|
run()
|