Compartir a través de


Personalizacion de JavaScript para Azure Pipelines

Puede usar Azure Pipelines para compilar las aplicaciones de JavaScript sin tener que configurar ninguna infraestructura propia. Las herramientas que se usan normalmente para compilar, probar y ejecutar aplicaciones JavaScript, como npm, Node, Yarn y Gulp, se instalan previamente en agentes hospedados por Microsoft en Azure Pipelines.

Para saber cuál es la versión de Node.js y npm preinstalada, consulte Agentes hospedados por Microsoft. Para instalar una versión específica de estas herramientas en agentes hospedados por Microsoft, agregue la tarea Instalador de herramientas de Node al principio del proceso. También puede usar un agente autohospedado.

Para crear la primera canalización con JavaScript, consulte el inicio rápido de JavaScript.

Uso de una versión específica de Node.js

Si necesita una versión de Node.js y npm que aún no esté instalada en el agente hospedado por Microsoft, use la tarea Instalador de herramientas de Node. Agregue el siguiente fragmento de código a su archivo azure-pipelines.yml.

Nota:

Los agentes hospedados se actualizan periódicamente y la configuración de esta tarea da como resultado invertir un tiempo considerable en una actualización a una versión secundaria más reciente cada vez que se ejecuta la canalización. Use esta tarea solo cuando necesite una versión específica de Node en la canalización.

- task: UseNode@1
  inputs:
    version: '16.x' # replace this value with the version that you need for your project

Si necesita una versión de Node.js/npm que aún no está instalada en el agente:

  1. En la canalización, seleccione Tareas, elija la fase que ejecuta las tareas de compilación y, a continuación, seleccione + para agregar una nueva tarea a esa fase.

  2. En el catálogo de tareas, busque y agregue la tarea Instalador de herramientas de Node.

  3. Seleccione la tarea y especifique la versión del entorno de ejecución de Node.js que desea instalar.

Para actualizar solo la herramienta npm, ejecute el comando npm i -g npm@version-number en el proceso de compilación.

Uso de varias versiones de Node

Puede compilar y probar la aplicación en varias versiones de Node con la tarea Instalador de herramientas de Node.

pool:
  vmImage: 'ubuntu-latest'
strategy:
  matrix:
    node_16_x:
      node_version: 16.x
    node_13_x:
      node_version: 18.x

steps:
- task: UseNode@1
  inputs:
    version: $(node_version)

- script: npm install

Instalación de herramientas en el agente de compilación

Si tiene herramientas que son dependencias de desarrollo en el archivo de proyecto package.json o package-lock.json, instale las herramientas y dependencias mediante npm. La versión exacta de las herramientas se define en el proyecto, aislada de otras versiones existentes en el agente de compilación.

Use un script o la tarea npm.

Uso de un script para instalar con package.json

- script: npm install --only=dev

Uso de la tarea npm para instalar con package.json

- task: Npm@1
  inputs:
     command: 'install'

Ejecute las herramientas instaladas de esta manera mediante el ejecutor de paquetes npm npx, que detecta las herramientas instaladas de esta manera en su resolución de ruta de acceso. En el ejemplo siguiente llama al ejecutor de pruebas mocha, pero busca la versión instalada como una dependencia de desarrollo antes de usar una versión instalada globalmente (mediante npm install -g).

- script: npx mocha

Para instalar herramientas necesarias para el proyecto, pero que no están establecidas como dependencias de desarrollo en package.json, llame a npm install -g desde una fase de script de la canalización.

En el ejemplo siguiente se instala la versión más reciente de la CLI de Angular mediante npm. A continuación, el resto de la canalización puede usar la herramienta ng de otras fases script.

Nota:

En los agentes de Linux hospedados por Microsoft, comience el comando con sudo, como sudo npm install -g.

- script: npm install -g @angular/cli

Sugerencia

Estas tareas se ejecutan cada vez que se ejecuta la canalización, por lo que tenga en cuenta el impacto que tienen las herramientas de instalación en los tiempos de compilación. Considere la posibilidad de configurar agentes autohospedados con la versión de las herramientas que necesita si la sobrecarga se convierte en un impacto grave en el rendimiento de la compilación.

Use las tareas de npm o de línea de comandos de la canalización para instalar herramientas en el agente de compilación.

Administración de dependencias

En la compilación, use Yarn o Azure Artifacts para descargar paquetes del registro npm público. Este registro es un tipo de registro npm privado que se especifica en el archivo .npmrc.

Uso de npm

Puede usar npm de las siguientes formas a fin de descargar paquetes para la compilación:

  • Ejecute directamente npm install en la canalización, ya que es la manera más sencilla de descargar paquetes desde un registro sin autenticación. Si la compilación no necesita dependencias de desarrollo en el agente para ejecutarse, puede acelerar los tiempos de compilación con la opción --only=prod para npm install.
  • Use una tarea npm. Esta tarea es útil cuando se usa un registro autenticado.
  • Use una tarea de autenticación de npm. Esta tarea es útil cuando se ejecuta npm install desde dentro de los ejecutores de tareas: Gulp, Grunt o Maven.

Si desea especificar un registro npm, coloque las direcciones URL en un archivo .npmrc en el repositorio. Si la fuente se autentica, cree una conexión de servicio npm en la pestaña Servicios de Configuración del proyecto para administrar sus credenciales.

Para instalar paquetes npm con un script en la canalización, agregue el siguiente fragmento de código a azure-pipelines.yml.

- script: npm install

Para usar un registro privado especificado en el archivo.npmrc, agregue el siguiente fragmento de código a azure-pipelines.yml.

- task: Npm@1
  inputs:
    customEndpoint: <Name of npm service connection>

Para pasar las credenciales del registro a los comandos npm a través de ejecutores de tareas como Gulp, agregue la siguiente tarea a azure-pipelines.yml antes de llamar al ejecutor de tareas.

- task: npmAuthenticate@0
  inputs:
    customEndpoint: <Name of npm service connection>

Use la tarea npm o la tarea de autenticación npm en la canalización para descargar e instalar paquetes.

Si las compilaciones producen errores ocasionalmente debido a problemas de conexión al restaurar paquetes desde el registro npm, puede usar Azure Artifacts con orígenes ascendentes y almacenar en caché los paquetes. Las credenciales de la canalización se usan automáticamente al conectarse a Azure Artifacts. Estas credenciales se derivan normalmente de la cuenta del servicio de compilación de recopilación de proyectos.

Si usa agentes hospedados por Microsoft, obtendrá una nueva máquina cada vez que ejecute una compilación, lo que significa restaurar las dependencias cada vez, haciendo que pueda tardar un tiempo significativo. Para mitigarlo, puede usar Azure Artifacts o un agente autohospedado; a continuación, obtendrá la ventaja de usar la caché de paquetes.

Uso de Yarn

Use una fase de script a fin de invocar a Yarn para restaurar las dependencias. Yarn se instala previamente en algunos agentes hospedados por Microsoft. Puede instalarlo y configurarlo en agentes autohospedados como cualquier otra herramienta.

- script: yarn install

Use la CLI o la tarea de Bash en la canalización para invocar a Yarn.

Ejecución de compiladores de JavaScript

Use compiladores como Babel y el compilador de TypeScript tsc para convertir el código fuente en versiones utilizables por el entorno de ejecución de Node.js o en exploradores web.

Si tiene un objeto de script configurado en el archivo de proyecto package.json que ejecuta el compilador, invóquelo en la canalización mediante una tarea de script.

- script: npm run compile

Puede llamar a los compiladores directamente desde la canalización mediante la tarea de script. Estos comandos se ejecutan desde la raíz del repositorio de código fuente clonado.

- script: tsc --target ES6 --strict true --project tsconfigs/production.json

Use la tarea npm en la canalización si tiene un script de compilación definido en el archivo package.json del proyecto para compilar el código. Use la tarea deBash para compilar el código si no tiene un script independiente definido en la configuración del proyecto.

Ejecutar pruebas unitarias

Configure las canalizaciones para ejecutar las pruebas de JavaScript y que generen resultados con formato XML JUnit. A continuación, puede publicar los resultados mediante la tarea de resultados de la prueba de publicación integrada.

Si la plataforma de pruebas no admite la salida de JUnit, agregue compatibilidad mediante un módulo de informes de asociados, como mocha-junit-reporter. Puede actualizar el script de prueba para usar el informador de JUnit, o si el informador admite opciones de línea de comandos, pase esas opciones a la definición de la tarea.

En la tabla siguiente se enumeran los ejecutores de pruebas más usados y los informadores que se pueden usar para generar resultados XML:

Ejecutor de pruebas Informadores para generar informes XML
mocha mocha-junit-reporter
cypress-multi-reporter
jasmine jasmine-reporters
jest jest-junit
jest-junit-reporter
karma karma-junit-reporter
Ava tap-xunit

En el ejemplo siguiente se usa mocha-junit-reporter y se invoca a mocha test directamente mediante un script. Este script genera la salida XML de JUnit en la ubicación predeterminada de ./test-results.xml.

- script: mocha test --reporter mocha-junit-reporter

Si ha definido un script test en el archivo package.json del proyecto, puede invocarlo mediante npm test.

- script: npm test

Publicación de los resultados de las pruebas

Para publicar los resultados, use la tarea Publicar resultados de pruebas.

- task: PublishTestResults@2
  condition: succeededOrFailed()
  inputs:
    testRunner: JUnit
    testResultsFiles: '**/test-results.xml'

Publicación de resultados de cobertura de código

Si los scripts de prueba ejecutan una herramienta de cobertura de código, como Istanbul, agregue la tarea Publicar resultados de cobertura de código. Al hacerlo, puede encontrar métricas de cobertura en el resumen de compilación y descargar informes HTML para su posterior análisis. La tarea espera la salida de informes de Cobertura o JaCoCo, por lo que debe asegurarse de que la herramienta de cobertura de código se ejecuta con las opciones necesarias para generar la salida correcta. Por ejemplo, --report cobertura.

En el ejemplo siguiente se usa nyc, la interfaz de la línea de comandos de Istanbul, junto con mocha-junit-reporter y se invoca el comando npm test.

- script: |
    nyc --reporter=cobertura --reporter=html \
    npm test -- --reporter mocha-junit-reporter --reporter-options mochaFile=./test-results.xml
  displayName: 'Build code coverage report'

- task: PublishCodeCoverageResults@2
  inputs: 
    summaryFileLocation: '$(System.DefaultWorkingDirectory)/**/*coverage.xml'

Use las tareas Publicar resultados de pruebas y Publicar resultados de cobertura de código en la canalización para publicar resultados de prueba junto con los resultados de cobertura de código mediante Istanbul.

Establezca las opciones de control de la tarea Publicar resultados de pruebas para ejecutar la tarea aunque se haya producido un error en una tarea anterior, a menos que se cancele la implementación.

Prueba del explorador de un extremo a otro

Ejecute pruebas en exploradores sin periféricos como parte de la canalización con herramientas como Protractor o Karma. A continuación, publique los resultados de la compilación en Azure DevOps con los pasos siguientes:

  1. Instale un controlador de prueba de explorador sin periféricos, como Chrome o Firefox, o una herramienta de simulacro de explorador como PhantomJS, en el agente de compilación.
  2. Configure la plataforma de pruebas para usar la opción de controlador o explorador sin periféricos que prefiera según la documentación de la herramienta.
  3. Configure la plataforma de pruebas (normalmente con un complemento informador o una configuración) para generar salidas de pruebas con formato JUnit.
  4. Configure una tarea de script para ejecutar los comandos de la CLI necesarios para iniciar las instancias del explorador sin periféricos.
  5. Ejecute las pruebas de un extremo a otro en las fases de canalización junto con las pruebas unitarias.
  6. Publique los resultados mediante la misma tarea Publicar resultados de pruebas junto con las pruebas unitarias.

Empaquetar aplicaciones web

Empaquetar aplicaciones para agrupar todos los módulos de aplicación con salidas intermedias y dependencias en recursos estáticos listos para la implementación. Agregue una fase de canalización después de la compilación y las pruebas para ejecutar una herramienta como webpack o ng build mediante la CLI de Angular.

En el primer ejemplo se llama a webpack. Para conseguirlo, asegúrese de que webpack está configurado como una dependencia de desarrollo en el archivo de proyecto package.json. Esto ejecuta webpack con la configuración predeterminada a menos que tenga un archivo webpack.config.js en la carpeta raíz del proyecto.

- script: webpack

En el ejemplo siguiente se usa la tarea npm para llamar a npm run build y luego al objeto de script build definido en el archivo package.json del proyecto. El uso de objetos de script en el proyecto mueve la lógica de la compilación en el código fuente y fuera de la canalización.

- script: npm run build

Use la CLI o la tarea deBash en la canalización para invocar a la herramienta de empaquetado, como webpack o ng build de Angular.

Implementación de plataformas de JavaScript

Angular

Para las aplicaciones de Angular, puede incluir comandos específicos de Angular, como ng test, ng build y ng e2e. Para usar los comandos de la CLI de Angular en la canalización, instale el paquete angular/cli npm en el agente de compilación.

Nota:

En los agentes de Linux hospedados por Microsoft, comience el comando con sudo, como sudo npm install -g.

- script: |
    npm install -g @angular/cli
    npm install
    ng build --prod

Agregue las siguientes tareas a la canalización:

  • npm

    • Comando: custom
    • Comandos y argumentos: install -g @angular/cli
  • npm

    • Comando: install
  • bash

    • Tipo: inline
    • Script: ng build --prod

Para las pruebas de la canalización que requieren que se ejecute un explorador, como el comando ng test en la aplicación de inicio, que ejecuta Karma, use un explorador sin periféricos en lugar de un explorador estándar. En la aplicación de inicio de Angular:

  1. Cambie la entrada browsers del archivo de proyecto karma.conf.js de browsers: ['Chrome'] a browsers: ['ChromeHeadless'].

  2. Cambie la entrada singleRun del archivo de proyecto karma.conf.js de un valor de false a true. Este cambio ayuda a asegurarse de que el proceso Karma se detiene después de que se ejecute.

React y Vue

Todas las dependencias de las aplicaciones de React y Vue se capturan en el archivo package.json. El archivo azure-pipelines.yml contiene el script de Node.js estándar:

- script: |
    npm install
  displayName: 'npm install'

- script: |
    npm run build
  displayName: 'npm build'

Los archivos de compilación están en una carpeta nueva, dist para Vue o build para React. Este fragmento de código compila un artefacto, www, que está listo para su lanzamiento. Usa las tareas Instalador de nodo, Copiar archivosy Publicar artefactos de compilación.

trigger:
- main

pool:
  vmImage: 'ubuntu-latest'

steps:
- task: UseNode@1
  inputs:
    version: '16.x'
  displayName: 'Install Node.js'

- script: |
    npm install
  displayName: 'npm install'

- script: |
    npm run build
  displayName: 'npm build'

- task: CopyFiles@2
  inputs:
    Contents: 'build/**' # Pull the build directory (React)
    TargetFolder: '$(Build.ArtifactStagingDirectory)'

- task: PublishBuildArtifacts@1
  inputs: 
    PathtoPublish: $(Build.ArtifactStagingDirectory) # dist or build files
    ArtifactName: 'www' # output artifact named www

Para liberarla, dirija la tarea de liberación al artefacto dist o build y use la tarea Implementación de aplicación web de Azure.

Webpack

Puede usar un archivo de configuración de webpack para especificar un compilador, como Babel o TypeScript, para transpilar JSX o TypeScript a JavaScript sin formato y para agrupar la aplicación.

- script: |
    npm install webpack webpack-cli --save-dev
    npx webpack --config webpack.config.js

Agregue las siguientes tareas a la canalización:

  • npm

    • Comando: custom
    • Comandos y argumentos: install -g webpack webpack-cli --save-dev
  • bash

    • Tipo: inline
    • Script: npx webpack --config webpack.config.js

Ejecutores de tareas de compilación

Es habitual usar Gulp o Grunt como ejecutor de tareas para compilar y probar una aplicación de JavaScript.

Gulp

Gulp se preinstala en agentes hospedados de Microsoft. Ejecute el comando gulp en el archivo YAML:

- script: gulp                       # include any additional options that are needed

Si los pasos del archivo de gulpfile.js requieren autenticación con un registro npm:

- task: npmAuthenticate@0
  inputs:
    customEndpoint: <Name of npm service connection>

- script: gulp                       # include any additional options that are needed

Agregue la tarea Publicar resultados de pruebas para publicar resultados de pruebas JUnit o xUnit en el servidor.

- task: PublishTestResults@2
  inputs:
    testResultsFiles: '**/TEST-RESULTS.xml'
    testRunTitle: 'Test results for JavaScript using gulp'

Agregue la tarea Publicar resultados de cobertura de código para publicar los resultados de cobertura de código en el servidor. Puede encontrar métricas de cobertura en el resumen de compilación y puede descargar informes HTML para su posterior análisis.

- task: PublishCodeCoverageResults@1
  inputs: 
    codeCoverageTool: Cobertura
    summaryFileLocation: '$(System.DefaultWorkingDirectory)/**/*coverage.xml'
    reportDirectory: '$(System.DefaultWorkingDirectory)/**/coverage'

La manera más sencilla de crear una canalización si la aplicación usa Gulp es utilizar Node.js con la plantilla de compilación de Gulp al crear la canalización. Esta plantilla agrega automáticamente varias tareas para invocar comandos de Gulp y publicar artefactos. En la tarea, seleccione Habilitar cobertura de código para habilitar la cobertura de código mediante Istanbul.

Grunt

Grunt se instala previamente en agentes hospedados de Microsoft. Para ejecutar el comando Grunt en el archivo YAML:

- script: grunt                      # include any additional options that are needed

Si los pasos del archivo Gruntfile.js requieren autenticación con un registro npm:

- task: npmAuthenticate@0
  inputs:
    customEndpoint: <Name of npm service connection>

- script: grunt                      # include any additional options that are needed

La manera más sencilla de crear una canalización si la aplicación usa Grunt es utilizar Node.js con la plantilla de compilación de Grunt al crear la canalización. Esto agrega automáticamente varias tareas para invocar comandos de Gulp y publicar artefactos. En la tarea, seleccione la opción Publicar en TFS/Team Services para publicar los resultados de las pruebas y seleccione Habilitar cobertura de código para habilitar la cobertura de código mediante Istanbul.

Empaquetado y entrega del código

Después de compilar y probar la aplicación, puede cargar la salida de compilación en Azure Pipelines, crear y publicar un paquete npm o Maven o empaquetar la salida de compilación en un archivo .zip para la implementación en una aplicación web.

Publicación de archivos en Azure Pipelines

Para cargar todo el directorio de trabajo de los archivos, use la tarea Publicar artefactos de compilación y agregue lo siguiente al archivo azure-pipelines.yml.

- task: PublishBuildArtifacts@1
  inputs:
    PathtoPublish: '$(System.DefaultWorkingDirectory)'

Para cargar un subconjunto de archivos, copie primero los archivos necesarios del directorio de trabajo en un directorio provisional con la tarea Copiar archivos y, a continuación, use la tarea Publicar artefactos de compilación.

- task: CopyFiles@2
  inputs:
    SourceFolder: '$(System.DefaultWorkingDirectory)'
    Contents: |
      **\*.js
      package.json
    TargetFolder: '$(Build.ArtifactStagingDirectory)'

- task: PublishBuildArtifacts@1

Publicación de un módulo en un registro npm

Si la salida del proyecto es un módulo npm que usan otros proyectos y no una aplicación web, use la tarea npm para publicar el módulo en un registro local o en el registro npm público. Proporcione una combinación de nombre y versión única cada vez que publique.

Ejemplos

En el primer ejemplo se supone que administra la información de la versión (por ejemplo, con una versión de npm) mediante los cambios en el archivo package.json en el control de versiones. En el ejemplo siguiente se usa la tarea script para publicar en el registro público.

- script: npm publish

En el ejemplo siguiente se publica en un registro personalizado definido en el repositorio del archivo .npmrc. Configure una conexión de servicio npm para insertar credenciales de autenticación en la conexión a medida que se ejecuta la compilación.

- task: Npm@1
  inputs:
     command: publish
     publishRegistry: useExternalRegistry
     publishEndpoint: https://my.npmregistry.com

En el ejemplo final se publica el módulo en una fuente de administración de paquetes de Azure DevOps Services.

- task: Npm@1
  inputs:
     command: publish
     publishRegistry: useFeed
     publishFeed: https://my.npmregistry.com

Para más información sobre el control de versiones y la publicación de paquetes npm, consulte Publicación de paquetes npm y ¿Cómo puedo crear una versión de mis paquetes npm como parte del proceso de compilación?.

Implementación de una aplicación sitio

Para crear un archivo de archivos .zip que esté listo para publicarse en una aplicación web, use la tarea Archivar archivos:

- task: ArchiveFiles@2
  inputs:
    rootFolderOrFile: '$(System.DefaultWorkingDirectory)'
    includeRootFolder: false

Para publicar este archivo en una aplicación web, consulte Implementación de aplicaciones web de Azure.

Publicación de artefactos en Azure Pipelines

Use la tarea Publicar artefactos de compilación para publicar archivos de la compilación en Azure Pipelines.

Publicación en un registro npm

Para crear y publicar un paquete npm, use la tarea npm. Para más información sobre el control de versiones y la publicación de paquetes npm, consulte Publicación de paquetes npm.

Implementación de una aplicación sitio

Para crear un archivo de archivos .zip que esté listo para publicarse en una aplicación web, use la tarea Archivar archivos. Para publicar este archivo en una aplicación web, consulte Implementación de aplicación web de Azure.

Compilación e inserción de imágenes en un registro de contenedor

Una vez que el código fuente se compila de forma correcta y las pruebas unitarias se han realizado de modo correcto, también puede compilar una imagen e insertarla en un registro de contenedor.

Solución de problemas

Si puede compilar el proyecto en la máquina de desarrollo pero tiene problemas para compilarlo en Azure Pipelines, explore las siguientes causas potenciales y acciones correctivas:

  • Compruebe que las versiones de Node.js y el ejecutor de tareas de la máquina de desarrollo coincidan con las del agente. Puede incluir scripts de línea de comandos como node --version en la canalización para comprobar lo que está instalado en el agente. Use el Instalador de herramientas de Node (como se explica en esta guía) para implementar la misma versión en el agente o ejecutar comandos npm install para actualizar las herramientas a las versiones deseadas.

  • Si las compilaciones producen un error intermitente mientras restaura paquetes, el registro npm tiene problemas o hay problemas de red entre el centro de datos de Azure y el registro. No podemos controlar estos factores. Explore si el uso de Azure Artifacts con un registro npm como origen ascendente mejora la confiabilidad de las compilaciones.

  • Si usa nvm para administrar diferentes versiones de Node.js, considere la posibilidad de cambiar a la tarea Instalador de herramientas de Node en su lugar. (nvm se instala por tradición en la imagen de macOS). nvm administra varias versiones de Node.js mediante la adición de alias de shell y la modificación de PATH, que interactúa mal con la forma en que Azure Pipelines ejecuta cada tarea en un proceso nuevo.

    La tarea Instalador de herramientas de Node controla correctamente este modelo. Sin embargo, si el trabajo requiere el uso de nvm, puede agregar el siguiente script al principio de cada canalización:

    steps:
    - bash: |
        NODE_VERSION=16  # or whatever your preferred version is
        npm config delete prefix  # avoid a warning
        . ${NVM_DIR}/nvm.sh
        nvm use ${NODE_VERSION}
        nvm alias default ${NODE_VERSION}
        VERSION_PATH="$(nvm_version_path ${NODE_VERSION})"
        echo "##vso[task.prependPath]$VERSION_PATH"
    

    A continuación, node y otras herramientas de línea de comandos trabajan para el resto del trabajo de canalización. En cada paso en el que se usa el comando nvm, inicie el script con el código siguiente:

    - bash: |
        . ${NVM_DIR}/nvm.sh
        nvm <command>
    

Preguntas más frecuentes

P: ¿Dónde puedo obtener más información sobre Azure Artifacts y el servicio administración de paquetes?

R: Administración de paquetes en Azure Artifacts

P: ¿Dónde puedo obtener más información sobre las tareas?

R: Tareas de compilación, versión y prueba

P: ¿Cómo puedo corregir un error de canalización con el mensaje "FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory"?

R: Este tipo de error se produce cuando el paquete de Node.js ha superado el límite de uso de la memoria. Para resolver la incidencia, agregue una variable como NODE_OPTIONS y asígnele un valor de --max_old_space_size=16384.

P: ¿Cómo puedo crear una versión de mis paquetes npm como parte del proceso de compilación?

R: Una opción es usar una combinación de control de versiones y versión de npm. Al final de una ejecución de canalización, puede actualizar el repositorio con la nueva versión. En este YAML, hay un repositorio de GitHub y el paquete se implementa en npmjs. Se produce un error en la compilación si la versión del paquete en npmjs y el archivo package.json no coinciden.

variables:
    MAP_NPMTOKEN: $(NPMTOKEN) # Mapping secret var

trigger:
- none

pool:
  vmImage: 'ubuntu-latest'

steps: # Checking out connected repo
- checkout: self
  persistCredentials: true
  clean: true
    
- task: npmAuthenticate@0
  inputs:
    workingFile: .npmrc
    customEndpoint: 'my-npm-connection'
    
- task: UseNode@1
  inputs:
    version: '16.x'
  displayName: 'Install Node.js'

- script: |
    npm install
  displayName: 'npm install'

- script: |
    npm pack
  displayName: 'Package for release'

- bash: | # Grab the package version
    v=`node -p "const p = require('./package.json'); p.version;"`
    echo "##vso[task.setvariable variable=packageVersion]$v"

- task: CopyFiles@2
  inputs:
      contents: '*.tgz'
      targetFolder: $(Build.ArtifactStagingDirectory)/npm
  displayName: 'Copy archives to artifacts staging directory'

- task: CopyFiles@2
  inputs:
    sourceFolder: '$(Build.SourcesDirectory)'
    contents: 'package.json' 
    targetFolder: $(Build.ArtifactStagingDirectory)/npm
  displayName: 'Copy package.json'

- task: PublishBuildArtifacts@1 
  inputs:
    PathtoPublish: '$(Build.ArtifactStagingDirectory)/npm'
    artifactName: npm
  displayName: 'Publish npm artifact'

- script: |  # Config can be set in .npmrc
    npm config set //registry.npmjs.org/:_authToken=$(MAP_NPMTOKEN) 
    npm config set scope "@myscope"
    # npm config list
    # npm --version
    npm version patch --force
    npm publish --access public

- task: CmdLine@2 # Push changes to GitHub (substitute your repo)
  inputs:
    script: |
      git config --global user.email "username@contoso.com"
      git config --global user.name "Azure Pipeline"
      git add package.json
      git commit -a -m "Test Commit from Azure DevOps"
      git push -u origin HEAD:main