Skip to main content

Comandos de flujo de trabajo para Acciones de

Tool navigation

Nota:

Actualmente los ejecutores hospedados por no se admiten en Enterprise Server. Puede ver más información sobre la compatibilidad futura planeada en public roadmap.

Las acciones pueden comunicarse con la máquina del ejecutor para establecer variables de entorno, valores de salida utilizados por otras acciones, agregar mensajes de depuración a los registros de salida y otras tareas.

La mayoría de los comandos de flujo de trabajo usan el comando echo en un formato específico, mientras que otros se pueden invocar escribiendo en un archivo. Para más información, vea Archivos de entorno.

Bash
echo "::workflow-command parameter1={data},parameter2={data}::{command value}"
PowerShell
Write-Output "::workflow-command parameter1={data},parameter2={data}::{command value}"

Nota:

Los nombres de parámetros y comandos de flujo de trabajo no distinguen mayúsculas de minúsculas.

Advertencia

Si utilizas el símbolo del sistema, omite los caracteres de comillas dobles (") al usar comandos de flujo de trabajo.

En actions/toolkit se incluye una serie de funciones que se pueden ejecutar como comandos de flujo de trabajo. Use la sintaxis :: para ejecutar los comandos de flujo de trabajo dentro del archivo YAML; estos comandos se envían al ejecutor por medio de stdout.

Por ejemplo, en lugar de usar código para crear una anotación de error, como se muestra a continuación:

JavaScript
core.error('Missing semicolon', {file: 'app.js', startLine: 1})

Puedes usar el comando error en tu flujo de trabajo para crear la misma anotación de error:

YAML
      - name: Create annotation for build error
        run: echo "::error file=app.js,line=1::Missing semicolon"
YAML
      - name: Create annotation for build error
        run: Write-Output "::error file=app.js,line=1::Missing semicolon"

La siguiente tabla muestra qué funciones del toolkit se encuentran disponibles dentro de un flujo de trabajo:

Funcion del ToolkitComando equivalente del flujo de trabajo
core.addPathAccesible mediante el archivo de entorno _PATH
core.debugdebug
core.noticenotice
core.errorerror
core.endGroupendgroup
core.exportVariableAccesible mediante el archivo de entorno _ENV
core.getInputAccesible mediante la variable de entorno INPUT_{NAME}
core.getStateAccesible mediante la variable de entorno STATE_{NAME}
core.isDebugAccesible mediante la variable de entorno RUNNER_DEBUG
core.summaryAccesible mediante el archivo de entorno _STEP_SUMMARY
core.saveStateAccesible mediante el archivo de entorno _STATE
core.setCommandEchoecho
core.setFailedSe usa como acceso directo para ::error y exit 1
core.setOutputAccesible mediante el archivo de entorno _OUTPUT
core.setSecretadd-mask
core.startGroupgroup
core.warningwarning

Imprime un mensaje de depuración en el registro. Debe crear un secreto denominado ACTIONS_STEP_DEBUG con el valor true para ver los mensajes de depuración establecidos por este comando en el registro. Para más información, consulta Habilitación del registro de depuración.

Text
::debug::{message}

Bash
echo "::debug::Set the Octocat variable"
PowerShell
Write-Output "::debug::Set the Octocat variable"

Crea un mensaje de aviso e imprime el mensaje en la bitácora. Este mensaje creará una anotación, la cual puede asociar el mensaje con un archivo particular de tu repositorio. Opcionalmente, tu mensaje puede especificar una posición dentro del archivo.

Text
::notice file={name},line={line},endLine={endLine},title={title}::{message}
ParámetroValorObligatorioValor predeterminado
titleTítulo personalizadoNoNinguno
fileNombre de archivoNo.
colNúmero de columna, a partir de 1NoNinguno
endColumnNúmero de columna finalNoNinguno
lineNúmero de línea, a partir de 1No1
endLineNúmero de línea finalNo1

Bash
echo "::notice file=app.js,line=1,col=5,endColumn=7::Missing semicolon"
PowerShell
Write-Output "::notice file=app.js,line=1,col=5,endColumn=7,title=YOUR-TITLE::Missing semicolon"

Crea un mensaje de advertencia e imprime el mensaje en el registro. Este mensaje creará una anotación, la cual puede asociar el mensaje con un archivo particular de tu repositorio. Opcionalmente, tu mensaje puede especificar una posición dentro del archivo.

Text
::warning file={name},line={line},endLine={endLine},title={title}::{message}
ParámetroValorObligatorioValor predeterminado
titleTítulo personalizadoNoNinguno
fileNombre de archivoNo.
colNúmero de columna, a partir de 1NoNinguno
endColumnNúmero de columna finalNoNinguno
lineNúmero de línea, a partir de 1No1
endLineNúmero de línea finalNo1

Bash
echo "::warning file=app.js,line=1,col=5,endColumn=7,title=YOUR-TITLE::Missing semicolon"
PowerShell
Write-Output "::warning file=app.js,line=1,col=5,endColumn=7,title=YOUR-TITLE::Missing semicolon"

Crea un mensaje de error e imprime el mensaje en el registro. Este mensaje creará una anotación, la cual puede asociar el mensaje con un archivo particular de tu repositorio. Opcionalmente, tu mensaje puede especificar una posición dentro del archivo.

Text
::error file={name},line={line},endLine={endLine},title={title}::{message}
ParámetroValorObligatorioValor predeterminado
titleTítulo personalizadoNoNinguno
fileNombre de archivoNo.
colNúmero de columna, a partir de 1NoNinguno
endColumnNúmero de columna finalNoNinguno
lineNúmero de línea, a partir de 1No1
endLineNúmero de línea finalNo1

Bash
echo "::error file=app.js,line=1,col=5,endColumn=7,title=YOUR-TITLE::Missing semicolon"
PowerShell
Write-Output "::error file=app.js,line=1,col=5,endColumn=7,title=YOUR-TITLE::Missing semicolon"

Crea un grupo expansible en la bitácora. Para crear un grupo, use el comando group y especifique title. Todo lo que imprima en el registro entre los comandos group y endgroup se anida dentro de una entrada expandible en el registro.

Text
::group::{title}
::endgroup::

YAML
jobs:
  bash-example:
    runs-on: ubuntu-latest
    steps:
      - name: Group of log lines
        run: |
            echo "::group::My title"
            echo "Inside group"
            echo "::endgroup::"
YAML
jobs:
  powershell-example:
    runs-on: windows-latest
    steps:
      - name: Group of log lines
        run: |
            Write-Output "::group::My title"
            Write-Output "Inside group"
            Write-Output "::endgroup::"

Captura de pantalla del registro del paso de flujo de trabajo. La segunda línea, "Mi título", es un grupo expandido. La siguiente línea, "Inside group", tiene sangría aplicada abajo.

Text
::add-mask::{value}

El enmascaramiento de un valor impide que una cadena o variable se imprima en el registro. Cada palabra enmascarada separada por un espacio en blanco se reemplaza con el carácter *. Puede usar una variable de entorno o una cadena para el valor value de la máscara. Al enmascarar un valor, se trata como un secreto y se oculta en el ejecutor. Por ejemplo, después de enmascarar un valor, no podrá establecerlo como salida.

Al imprimir "Mona The Octocat" en el registro, verá "***".

Bash
echo "::add-mask::Mona The Octocat"
PowerShell
Write-Output "::add-mask::Mona The Octocat"

Advertencia

Asegúrate de registrar el secreto con "add-mask" antes de generarlo en los registros de compilación o usarlo en cualquier otro comando de flujo de trabajo.

Al imprimir la variable MY_NAME o el valor "Mona The Octocat" en el registro, verá "***" en lugar de "Mona The Octocat".

YAML
jobs:
  bash-example:
    runs-on: ubuntu-latest
    env:
      MY_NAME: "Mona The Octocat"
    steps:
      - name: bash-version
        run: echo "::add-mask::$MY_NAME"
YAML
jobs:
  powershell-example:
    runs-on: windows-latest
    env:
      MY_NAME: "Mona The Octocat"
    steps:
      - name: powershell-version
        run: Write-Output "::add-mask::$env:MY_NAME"

Si no necesitas pasar el secreto de un trabajo a otro, puedes hacer lo siguiente:

  1. Generar el secreto (sin producir una salida).
  2. Enmascararlo con add-mask.
  3. Usar _OUTPUT para que el secreto esté disponible para otros pasos dentro del trabajo.
YAML
on: push
jobs:
  generate-a-secret-output:
    runs-on: ubuntu-latest
    steps:
      - id: sets-a-secret
        name: Generate, mask, and output a secret
        run: |
          the_secret=$((RANDOM))
          echo "::add-mask::$the_secret"
          echo "secret-number=$the_secret" >> "$_OUTPUT"
      - name: Use that secret output (protected by a mask)
        run: |
          echo "the secret number is ${{ steps.sets-a-secret.outputs.secret-number }}"
YAML
on: push
jobs:
  generate-a-secret-output:
    runs-on: ubuntu-latest
    steps:
      - id: sets-a-secret
        name: Generate, mask, and output a secret
        shell: pwsh
        run: |
          Set-Variable -Name TheSecret -Value (Get-Random)
          Write-Output "::add-mask::$TheSecret"
          "secret-number=$TheSecret" >> $env:_OUTPUT
      - name: Use that secret output (protected by a mask)
        shell: pwsh
        run: |
          Write-Output "the secret number is ${{ steps.sets-a-secret.outputs.secret-number }}"

Si quieres pasar un secreto enmascarado entre trabajos o flujos de trabajo, debes almacenar el secreto en un almacén y, luego, recuperarlo en el trabajo o flujo de trabajo subsiguiente.

  1. Configura un almacén de secretos para almacenar el secreto que generarás durante el flujo de trabajo. Por ejemplo, Vault.
  2. Genera una clave para leer y escribir en ese almacén de secretos. Almacena la clave como secreto de repositorio. En el siguiente flujo de trabajo de ejemplo, el nombre del secreto es SECRET_STORE_CREDENTIALS. Para más información, consulta Uso de secretos en Acciones de .

Nota:

Este flujo de trabajo usa un almacén de secretos imaginario, secret-store, que tiene los comandos imaginarios store-secret y retrieve-secret. some/secret-store@ 27b31702a0e7fc50959f5ad993c78deac1bdfc29 es una acción imaginaria que instala la aplicación secret-store y la configura para conectarse a un objeto instance con credentials.

YAML
on: push

jobs:
  secret-generator:
    runs-on: ubuntu-latest
    outputs:
      handle: ${{ steps.generate-secret.outputs.handle }}
    steps:
    - uses: some/secret-store@27b31702a0e7fc50959f5ad993c78deac1bdfc29
      with:
        credentials: ${{ secrets.SECRET_STORE_CREDENTIALS }}
        instance: ${{ secrets.SECRET_STORE_INSTANCE }}
    - name: generate secret
      id: generate-secret
      shell: bash
      run: |
        GENERATED_SECRET=$((RANDOM))
        echo "::add-mask::$GENERATED_SECRET"
        SECRET_HANDLE=$(secret-store store-secret "$GENERATED_SECRET")
        echo "handle=$SECRET_HANDLE" >> "$_OUTPUT"
  secret-consumer:
    runs-on: macos-latest
    needs: secret-generator
    steps:
    - uses: some/secret-store@27b31702a0e7fc50959f5ad993c78deac1bdfc29
      with:
        credentials: ${{ secrets.SECRET_STORE_CREDENTIALS }}
        instance: ${{ secrets.SECRET_STORE_INSTANCE }}
    - name: use secret
      shell: bash
      run: |
        SECRET_HANDLE="${{ needs.secret-generator.outputs.handle }}"
        RETRIEVED_SECRET=$(secret-store retrieve-secret "$SECRET_HANDLE")
        echo "::add-mask::$RETRIEVED_SECRET"
        echo "We retrieved our masked secret: $RETRIEVED_SECRET"
YAML
on: push

jobs:
  secret-generator:
    runs-on: ubuntu-latest
    steps:
    - uses: some/secret-store@27b31702a0e7fc50959f5ad993c78deac1bdfc29
      with:
        credentials: ${{ secrets.SECRET_STORE_CREDENTIALS }}
        instance: ${{ secrets.SECRET_STORE_INSTANCE }}
    - name: generate secret
      shell: pwsh
      run: |
        Set-Variable -Name Generated_Secret -Value (Get-Random)
        Write-Output "::add-mask::$Generated_Secret"
        Set-Variable -Name Secret_Handle -Value (Store-Secret "$Generated_Secret")
        "handle=$Secret_Handle" >> $env:_OUTPUT
  secret-consumer:
    runs-on: macos-latest
    needs: secret-generator
    steps:
    - uses: some/secret-store@27b31702a0e7fc50959f5ad993c78deac1bdfc29
      with:
        credentials: ${{ secrets.SECRET_STORE_CREDENTIALS }}
        instance: ${{ secrets.SECRET_STORE_INSTANCE }}
    - name: use secret
      shell: pwsh
      run: |
        Set-Variable -Name Secret_Handle -Value "${{ needs.secret-generator.outputs.handle }}"
        Set-Variable -Name Retrieved_Secret -Value (Retrieve-Secret "$Secret_Handle")
        echo "::add-mask::$Retrieved_Secret"
        echo "We retrieved our masked secret: $Retrieved_Secret"

Deja de procesar cualquier comando de flujo de trabajo. Este comando especial te permite registrar lo que sea sin ejecutar accidentalmente un comando de flujo de trabajo. Por ejemplo, podrías dejar de registrar para producir un script completo que tenga comentarios.

Text
::stop-commands::{endtoken}

Para detener el procesamiento de los comandos de flujo de trabajo, pase un token único a stop-commands. Para resumir los comandos de flujo de trabajo de procesamiento, pasa el mismo token que utilizaste para detener los comandos de flujo de trabajo.

Advertencia

Asegúrate de que el token que usas se genera aleatoriamente y es único para cada ejecución.

Text
::{endtoken}::

YAML
jobs:
  workflow-command-job:
    runs-on: ubuntu-latest
    steps:
      - name: Disable workflow commands
        run: |
          echo '::warning:: This is a warning message, to demonstrate that commands are being processed.'
          stopMarker=$(uuidgen)
          echo "::stop-commands::$stopMarker"
          echo '::warning:: This will NOT be rendered as a warning, because stop-commands has been invoked.'
          echo "::$stopMarker::"
          echo '::warning:: This is a warning again, because stop-commands has been turned off.'
YAML
jobs:
  workflow-command-job:
    runs-on: windows-latest
    steps:
      - name: Disable workflow commands
        run: |
          Write-Output '::warning:: This is a warning message, to demonstrate that commands are being processed.'
          $stopMarker = New-Guid
          Write-Output "::stop-commands::$stopMarker"
          Write-Output '::warning:: This will NOT be rendered as a warning, because stop-commands has been invoked.'
          Write-Output "::$stopMarker::"
          Write-Output '::warning:: This is a warning again, because stop-commands has been turned off.'

Puede crear variables de entorno a fin de compartirlas con las acciones pre: o post: del flujo de trabajo escribiendo al archivo ubicado en _STATE. Por ejemplo, puede crear un archivo con la acción pre:, pasar la ubicación del archivo a la acción main: y, después, usar la acción post: para eliminar el archivo. Como alternativa, podría crear un archivo con la acción main:, pasar la ubicación del archivo a la acción post: y también usar la acción post: para eliminar el archivo.

Si tiene varias acciones pre: o post:, solo puede acceder al valor guardado en la acción donde se ha escrito a _STATE. Para más información sobre la acción post:, consulta Sintaxis de metadatos para Acciones de .

El archivo _STATE solo está disponible dentro de una acción. El valor guardado se almacena como un valor de entorno con el prefijo STATE_.

En este ejemplo se usa JavaScript para escribir al archivo _STATE. La variable de entorno resultante se denomina STATE_processID con el valor de 12345:

JavaScript
import * as fs from 'fs'
import * as os from 'os'

fs.appendFileSync(process.env._STATE, `processID=12345${os.EOL}`, {
  encoding: 'utf8'
})

Después, la variable STATE_processID está disponible exclusivamente para el script de limpieza que se ejecuta en la acción main. Este ejemplo se ejecuta en main y usa JavaScript para mostrar el valor asignado a la variable de entorno STATE_processID:

JavaScript
console.log("The running PID from the main action is: " + process.env.STATE_processID);

Durante la ejecución de un flujo de trabajo, el ejecutor genera archivos temporales que pueden utilizarse para llevar a cabo ciertas acciones. Se puede acceder a la ruta de acceso a estos archivos y editarse mediante las variables de entorno predeterminadas de . Consulta Almacenamiento de información en variables. Necesitarás utilizar codificación UTF-8 cuando escribas en estos archivos para garantizar el procesamiento adecuado de los comandos. Se pueden escribir varios comandos en el mismo archivo, separados por líneas nuevas. Para usar variables de entorno en una acción de , cree o modifique archivos .env mediante comandos específicos de Acciones de .

A continuación, se indica cómo puede hacerlo.

YAML
name: Example Workflow for Environment Files

on: push

jobs:
  set_and_use_env_vars:
    runs-on: ubuntu-latest
    steps:
      - name: Set environment variable
        run: echo "MY_ENV_VAR=myValue" >> $_ENV

      - name: Use environment variable
        run: |
          echo "The value of MY_ENV_VAR is $MY_ENV_VAR"

Otro ejemplo sería usarlo para almacenar metadatos como marcas de tiempo de compilación, confirmar SHA o nombres de artefacto:

YAML
steps:
  - name: Store build timestamp
    run: echo "BUILD_TIME=$(date +'%T')" >> $_ENV

  - name: Deploy using stored timestamp
    run: echo "Deploying at $BUILD_TIME"

Nota:

En las versiones 5.1 y posteriores de PowerShell (shell: powershell) no se usa UTF-8 de forma predeterminada, por lo que debes especificar la codificación UTF-8. Por ejemplo:

YAML
jobs:
  legacy-powershell-example:
    runs-on: windows-latest
    steps:
      - shell: powershell
        run: |
          "mypath" | Out-File -FilePath $env:_PATH -Encoding utf8 -Append

En las versiones 6 y superiores de PowerShell Core (shell: pwsh) se usa UTF-8 de forma predeterminada. Por ejemplo:

YAML
jobs:
  powershell-core-example:
    runs-on: windows-latest
    steps:
      - shell: pwsh
        run: |
          "mypath" >> $env:_PATH

Nota:

Para evitar problemas, se recomienda tratar las variables de entorno como que distinguen mayúsculas de minúsculas, independientemente del comportamiento del sistema operativo y del shell que utilices.

Bash
echo "{environment_variable_name}={value}" >> "$_ENV"
  • Utilizar PowerShell versión 6 y superior:

    PowerShell
    "{environment_variable_name}={value}" >> $env:_ENV
    
  • Utilizar PowerShell versión 5.1 e inferior:

    PowerShell
    "{environment_variable_name}={value}" | Out-File -FilePath $env:_ENV -Encoding utf8 -Append
    

Puede hacer que una variable de entorno esté disponible en cualquier paso posterior de un trabajo de un flujo de trabajo si define o actualiza la variable de entorno, y lo escribe en el archivo de entorno _ENV. El paso que crea o actualiza la variable de ambiente no tiene acceso al valor nuevo, pero todos los pasos subsecuentes en un job tendrán acceso.

No se puede sobrescribir el valor de las variables de entorno predeterminadas _* y RUNNER_*. Actualmente, se puede sobrescribir el valor de la variable CI. Sin embargo, no se garantiza que sea posible siempre. Para obtener más información sobre las variables de entorno predeterminadas, consulta Almacenamiento de información en variables.

Nota:

Debido a las restricciones de seguridad, _ENV no se puede usar para establecer la variable de entorno NODE_OPTIONS.

YAML
steps:
  - name: Set the value
    id: step_one
    run: |
      echo "action_state=yellow" >> "$_ENV"
  - name: Use the value
    id: step_two
    run: |
      printf '%s\n' "$action_state" # This will output 'yellow'
YAML
steps:
  - name: Set the value
    id: step_one
    run: |
      "action_state=yellow" >> $env:_ENV
  - name: Use the value
    id: step_two
    run: |
      Write-Output "$env:action_state" # This will output 'yellow'

Para las secuencias de lìnea mùltiple, puedes utilizar un delimitador con la siguiente sintaxis.

Text
{name}<<{delimiter}
{value}
{delimiter}

Advertencia

Asegúrate de que el delimitador que está usando no se producirá en una línea propia dentro del valor. Si el valor es completamente arbitrario, no debe usar este formato. Escriba el valor en un archivo en su lugar.

En este ejemplo se usa EOF como delimitador y se establece la variable de entorno JSON_RESPONSE en el valor de la respuesta curl.

YAML
steps:
  - name: Set the value in bash
    id: step_one
    run: |
      {
        echo 'JSON_RESPONSE<<EOF'
        curl https://example.com
        echo EOF
      } >> "$_ENV"
YAML
steps:
  - name: Set the value in pwsh
    id: step_one
    run: |
      $EOF = (New-Guid).Guid
      "JSON_RESPONSE<<$EOF" >> $env:_ENV
      (Invoke-WebRequest -Uri "https://example.com").Content >> $env:_ENV
      "$EOF" >> $env:_ENV
    shell: pwsh

Establece el parámetro de salida de un paso. Ten en cuenta en el paso hay que definir un id para recuperar el valor de salida posteriormente. Puedes establecer valores de salida de varias líneas con la misma técnica que se usa en la sección Cadenas multilínea para definir variables de entorno de varias líneas.

Bash
echo "{name}={value}" >> "$_OUTPUT"
PowerShell
"{name}=value" >> $env:_OUTPUT

En este ejemplo se muestra cómo establecer el parámetro de salida SELECTED_COLOR y recuperarlo posteriormente:

YAML
      - name: Set color
        id: color-selector
        run: echo "SELECTED_COLOR=green" >> "$_OUTPUT"
      - name: Get color
        env:
          SELECTED_COLOR: ${{ steps.color-selector.outputs.SELECTED_COLOR }}
        run: echo "The selected color is $SELECTED_COLOR"

En este ejemplo se muestra cómo establecer el parámetro de salida SELECTED_COLOR y recuperarlo posteriormente:

YAML
      - name: Set color
        id: color-selector
        run: |
            "SELECTED_COLOR=green" >> $env:_OUTPUT
      - name: Get color
        env:
          SELECTED_COLOR: ${{ steps.color-selector.outputs.SELECTED_COLOR }}
        run: Write-Output "The selected color is $env:SELECTED_COLOR"

Bash
echo "{markdown content}" >> $_STEP_SUMMARY
PowerShell
"{markdown content}" >> $env:_STEP_SUMMARY

Puedes establecer Markdown personalizado para cada trabajo de modo que se muestre en la página de resumen de una ejecución de flujo de trabajo. Puedes usar resúmenes de trabajos para mostrar y agrupar contenido único, como resúmenes de resultados de pruebas, de modo que alguien que vea el resultado de una ejecución de flujo de trabajo no necesite ir a los registros para ver información importante relacionada con la ejecución, como errores.

Los resúmenes de trabajos admiten Markdown de tipo y puedes agregar el contenido de Markdown para un paso al archivo de entorno _STEP_SUMMARY. _STEP_SUMMARY es único para cada paso de un trabajo. Para obtener más información sobre el archivo por paso al que hace referencia _STEP_SUMMARY, consulta Archivos de entorno.

Cuando un trabajo finaliza, los resúmenes de todos los pasos de un trabajo se agrupan en un único resumen de trabajo y se muestran en la página resumen de ejecución del flujo de trabajo. Si varios trabajos generan resúmenes, estos se ordenan según la hora de finalización del trabajo.

Bash
echo "### Hello world! :rocket:" >> $_STEP_SUMMARY
PowerShell
"### Hello world! :rocket:" >> $env:_STEP_SUMMARY

Captura de pantalla de la página de resumen de una ejecución de flujo de trabajo. Debajo de "example summary" se encuentra "Hello world!" y un emoji de cohete.

En el caso de contenido de Markdown multilínea, puedes usar >> para anexar continuamente contenido al paso actual. Con cada operación de anexión, se agrega automáticamente un carácter de nueva línea.

- name: Generate list using Markdown
  run: |
    echo "This is the lead in sentence for the list" >> $_STEP_SUMMARY
    echo "" >> $_STEP_SUMMARY # this is a blank line
    echo "- Lets add a bullet point" >> $_STEP_SUMMARY
    echo "- Lets add a second bullet point" >> $_STEP_SUMMARY
    echo "- How about a third one?" >> $_STEP_SUMMARY
- name: Generate list using Markdown
  run: |
    "This is the lead in sentence for the list" >> $env:_STEP_SUMMARY
    "" >> $env:_STEP_SUMMARY # this is a blank line
    "- Lets add a bullet point" >> $env:_STEP_SUMMARY
    "- Lets add a second bullet point" >> $env:_STEP_SUMMARY
    "- How about a third one?" >> $env:_STEP_SUMMARY

Para borrar todo el contenido del paso actual, puede usar > para sobrescribir cualquier contenido en Bash o eliminar -Append en PowerShell

- name: Overwrite Markdown
  run: |
    echo "Adding some Markdown content" >> $_STEP_SUMMARY
    echo "There was an error, we need to clear the previous Markdown with some new content." > $_STEP_SUMMARY
- name: Overwrite Markdown
  run: |
    "Adding some Markdown content" >> $env:_STEP_SUMMARY
    "There was an error, we need to clear the previous Markdown with some new content." >> $env:_STEP_SUMMARY

Para quitar completamente un resumen del paso actual, se puede eliminar el archivo al que hace referencia _STEP_SUMMARY.

- name: Delete all summary content
  run: |
    echo "Adding Markdown content that we want to remove before the step ends" >> $_STEP_SUMMARY
    rm $_STEP_SUMMARY
- name: Delete all summary content
  run: |
    "Adding Markdown content that we want to remove before the step ends" >> $env:_STEP_SUMMARY
    Remove-Item $env:_STEP_SUMMARY

Una vez que se ha completado un paso, se cargan los resúmenes de trabajo y los pasos posteriores no pueden modificar el contenido de Markdown cargado anteriormente. Los resúmenes enmascaran automáticamente los secretos que podrían haberse agregado de forma accidental. Si un resumen de trabajo contiene información confidencial que se debe eliminar, puedes eliminar toda la ejecución del flujo de trabajo para quitar todos sus resúmenes de trabajo. Para obtener más información, consulta Borrar una ejecución de flujo de trabajo.

Los resúmenes de trabajo están aislados entre los pasos y cada paso está restringido a un tamaño máximo de 1 MiB. Se aplica aislamiento entre los pasos para que el Markdown que podría tener un formato incorrecto en un paso no pueda interrumpir la representación de Markdown para los pasos posteriores. Si se agrega más de 1 MiB de contenido a un paso, se producirá un error en la carga del paso y se creará una anotación de error. Los errores de carga de resúmenes de trabajos no afectan al estado general de un paso o un trabajo. Se muestra un máximo de 20 resúmenes de trabajos de los pasos por trabajo.

Antepone un directorio a la variable del sistema PATH y hace que esté disponible automáticamente para todas las acciones posteriores en el trabajo actual; la acción que está actualmente en ejecución no puede acceder a la variable de ruta actualizada. A fin de ver las rutas definidas actualmente para el trabajo, puede usar echo "$PATH" en un paso o una acción.

En este ejemplo se muestra cómo agregar el directorio de usuario $HOME/.local/bin a PATH:

Bash
echo "$HOME/.local/bin" >> "$_PATH"

En este ejemplo se muestra cómo agregar el directorio de usuario $env:HOMEPATH/.local/bin a PATH:

PowerShell
"$env:HOMEPATH/.local/bin" | Out-File -FilePath "$env:_PATH" -Append