Compatibilidad con expresiones de plantilla en definiciones de recursos de contenedor y repositorio
Con esta actualización, se incluyó compatibilidad con expresiones de plantilla en definiciones de recursos de repositorio y contenedor. Ahora puede usar expresiones de plantilla al definir la ref
propiedad de un repository
recurso en una canalización YAML para elegir la rama de un recurso de repositorio. Además, hemos agregado compatibilidad con expresiones de plantilla al definir las endpoint
propiedades , volumes
, ports
y options
de un recurso en una container
canalización YAML.
Consulte las notas de la versión para obtener más información.
Azure Boards
- Editar tipos de vínculo de elemento de trabajo
- Creación de un punto de conexión DE REST de consulta temporal
- API de eliminación por lotes (versión preliminar privada)
- macro de @CurrentIteration en planes de entrega
Azure Pipelines
- Expresiones de plantilla en la definición de recursos del repositorio
- Expresiones de plantilla en definición de recursos de contenedor
- Auditar eventos para cambios en aprobaciones
- La biblioteca de tareas expone el modelo de hospedaje del agente
Azure Boards
Editar tipos de vínculo de elemento de trabajo
Anteriormente, cambiar un vínculo de elemento de trabajo requiere al menos tres pasos para completar. Por ejemplo, para cambiar un vínculo primario a un vínculo relacionado, debe copiar el identificador del elemento de trabajo, quitar el vínculo primario, agregar un nuevo vínculo existente de tipo relacionado y, por último, pegar el identificador copiado y guardarlo. Es un proceso complicado.
Hemos resuelto el problema al permitirle editar y cambiar el tipo de vínculo directamente. Puede cambiar rápidamente el tipo de vínculo en un solo paso.
Nota:
Esta característica solo estará disponible con la versión preliminar de New Boards Hubs.
Creación de un punto de conexión DE REST de consulta temporal
Hemos visto varias instancias de autores de extensiones que intentan ejecutar consultas no guardadas pasando la instrucción Lenguaje de consulta de elementos de trabajo (WIQL) a través de la cadena de consulta. Esto funciona bien a menos que tenga una instrucción WIQL grande que alcance los límites del explorador en la longitud de la cadena de consulta. Para resolver esto, hemos creado un nuevo punto de conexión REST para permitir que los autores de herramientas generen una consulta temporal. El uso del identificador de la respuesta para pasar a través de querystring elimina este problema.
Obtenga más información en la página de documentación de la API REST de consultas temporales.
API de eliminación por lotes (versión preliminar privada)
Actualmente, la única manera de quitar elementos de trabajo de la papelera de reciclaje es usar esta API REST para eliminarlos de uno en uno. Esto puede ser un proceso lento y está sujeto a la limitación de velocidad al intentar realizar cualquier tipo de limpieza masiva. En respuesta, hemos agregado un nuevo punto de conexión de API REST para eliminar o destruir elementos de trabajo por lotes.
Si está interesado en participar en una versión preliminar privada de este nuevo punto de conexión, envíenos un correo electrónico directamente.
@CurrentIteration macro en Planes de entrega
Con esta actualización, hemos agregado compatibilidad con la @CurrentIteration macro para estilos en Planes de entrega. Esta macro le permitirá obtener la iteración actual del contexto del equipo de cada fila del plan.
Azure Pipelines
Expresiones de plantilla en la definición de recursos del repositorio
Se ha agregado compatibilidad con expresiones de plantilla al definir la ref
propiedad de un repository
recurso en una canalización YAML. Esta fue una característica muy solicitada por nuestra Comunidad de desarrolladores.
Existen casos de uso en los que desea que la canalización consulte diferentes ramas del mismo recurso de repositorio.
Por ejemplo, supongamos que tiene una canalización que compila su propio repositorio y, para ello, debe consultar una biblioteca de un repositorio de recursos. Además, supongamos que quiere que la canalización consulte la misma rama de biblioteca que está usando. Por ejemplo, si la canalización se ejecuta en la main
rama, debe consultar la main
rama del repositorio de biblioteca. Si las canalizaciones se ejecutan en la dev
rama, debe desactive la rama de dev
biblioteca.
Hasta hoy, tenía que especificar explícitamente la rama para desasecar y cambiar el código de canalización cada vez que cambia la rama.
Ahora, puede usar expresiones de plantilla para elegir la rama de un recurso de repositorio. Consulte el ejemplo siguiente de código YAML que se va a usar para las ramas que no son principales de la canalización:
resources:
repositories:
- repository: library
type: git
name: FabrikamLibrary
ref: ${{ variables['Build.SourceBranch'] }}
steps:
- checkout: library
- script: echo ./build.sh
- script: echo ./test.sh
Al ejecutar la canalización, puede especificar la rama que se va a descarcarcar para el library
repositorio.
Especificar la versión de una plantilla que se va a extender en tiempo de cola de compilación
Las plantillas representan una excelente manera de reducir la duplicación de código ymejorar la seguridad de las canalizaciones.
Un caso de uso popular es hospedar plantillas en su propio repositorio. Esto reduce el acoplamiento entre una plantilla y las canalizaciones que lo extienden y facilita la evolución de la plantilla y las canalizaciones de forma independiente.
Considere el ejemplo siguiente, en el que se usa una plantilla para supervisar la ejecución de una lista de pasos. El código de plantilla se encuentra en el Templates
repositorio.
# template.yml in repository Templates
parameters:
- name: steps
type: stepList
default: []
jobs:
- job:
steps:
- script: ./startMonitoring.sh
- ${{ parameters.steps }}
- script: ./stopMonitoring.sh
Supongamos que tiene una canalización YAML que extiende esta plantilla, ubicada en el repositorio FabrikamFiber
. Hasta hoy, no era posible especificar dinámicamente la ref
propiedad del recurso del templates
repositorio al usar el repositorio como origen de plantilla. Esto significaba que tenía que cambiar el código de la canalización si quería que la canalización: ampliar una plantilla de otra rama extienda una plantilla desde el mismo nombre de rama que la canalización, independientemente de la rama que ejecutó la canalización.
Con la introducción de expresiones de plantilla en la definición de recursos del repositorio, puede escribir la canalización de la siguiente manera:
resources:
repositories:
- repository: templates
type: git
name: Templates
ref: ${{ variables['Build.SourceBranch'] }}
extends:
template: template.yml@templates
parameters:
steps:
- script: echo ./build.sh
- script: echo ./test.sh
Al hacerlo, la canalización extenderá la plantilla en la misma rama que la rama en la que se ejecuta la canalización, por lo que puede asegurarse de que las ramas de la canalización y de la plantilla siempre coinciden. Es decir, si ejecuta la canalización en una rama dev
, extenderá la plantilla especificada por el template.yml
archivo en la dev
rama del templates
repositorio.
También puede elegir, en tiempo de cola de compilación, qué rama del repositorio de plantillas se va a usar; para ello, escriba el siguiente código YAML.
parameters:
- name: branch
default: main
resources:
repositories:
- repository: templates
type: git
name: Templates
ref: ${{ parameters.branch }}
extends:
template: template.yml@templates
parameters:
steps:
- script: echo ./build.sh
- script: echo ./test.sh
Ahora, puede hacer que la canalización en la rama main
extienda una plantilla desde una rama dev
en una ejecución y ampliar una plantilla desde una rama main
en otra ejecución, sin cambiar el código de la canalización.
Al especificar una expresión de plantilla para la ref
propiedad de un recurso de repositorio, puede usar y las parameters
variables predefinidas del sistema, pero no puede usar variables definidas por la interfaz de usuario de YAML o Pipelines.
Expresiones de plantilla en definición de recursos de contenedor
Se ha agregado compatibilidad con expresiones de plantilla al definir las endpoint
propiedades , volumes
, ports
y options
de un container
recurso en una canalización YAML. Esta fue una característica muy solicitada por nuestra Comunidad de desarrolladores.
Ahora, puede escribir canalizaciones YAML como las siguientes.
parameters:
- name: endpointName
default: AzDOACR
type: string
resources:
containers:
- container: linux
endpoint: ${{ parameters.endpointName }}
image: fabrikamfiber.azurecr.io/ubuntu:latest
jobs:
- job:
container: linux
steps:
- task: CmdLine@2
inputs:
script: 'echo Hello world'
Puede usar parameters.
y variables.
en las expresiones de plantilla. En el caso de las variables, solo puede usar las definidas en el archivo YAML, pero no las definidas en la interfaz de usuario de canalizaciones. Si vuelve a definir la variable, por ejemplo, mediante comandos de registro del agente, no tendrá ningún efecto.
Auditar eventos para cambios en aprobaciones
Las aprobaciones permiten controlar cuándo se debe ejecutar una fase. Estas comprobaciones se usan normalmente para controlar las implementaciones en entornos de producción. La auditoría le permite cumplir los requisitos de cumplimiento y supervisar la seguridad de su organización de Azure DevOps.
Cuando se pide a un usuario que apruebe una canalización para implementar en una fase determinada, ese usuario puede optar por reasignar la aprobación a otra persona.
Hasta ahora, estas acciones no se registraron en los registros de auditoría. Este problema se ha corregido ahora.
Los registros de auditoría contendrán una entrada similar a la siguiente.
[
{
"Id": "2517368925862632546;00000264-0000-8888-8000-000000000000;839ad1ba-f72b-4258-bc3f-88be7a4553b5",
"CorrelationId": "aaaa0000-bb11-2222-33cc-444444dddddd",
"ActivityId": "a298a06c-965f-4e60-9643-2593f2066e37",
"ActorCUID": "fe950802-bf07-755b-826d-e8dcc066252c",
"ActorUserId": "fe950802-bf07-755b-826d-e8dcc066252c",
"ActorUPN": "silviu@fabrikam.app",
"AuthenticationMechanism": "AAD_Cookie",
"Timestamp": "2022-10-10T11:26:53.7367453Z",
"ScopeType": "Organization",
"ScopeDisplayName": "Fabrikam (Organization)",
"ScopeId": "547a7316-cdf4-40d2-af16-3215f97d053e",
"ProjectId": "4bf16944-3595-421f-9947-79d9eb190284",
"ProjectName": "FabrikamFiber",
"IpAddress": "127.0.0.1",
"UserAgent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36 Edg/106.0.1370.37",
"ActionId": "ApproverReassigned",
"Data": {
"ApprovalId": "dae6e7c9-2a10-4cd8-b63a-579a6e7ba78d",
"OldApproverUserId": "692b6e2a-dd61-4872-866a-85498da390fc",
"OldApproverDisplayName": "[FabrikamFiber]\\Build Administrators",
"NewApproverUserId": "fe95080b-bf07-655b-226d-e8dcc066252c",
"NewApproverDisplayName": "Jack Fabrikam",
"Comment": "All admins are OOO"
},
"Details": "Reassigned approver of Approval dae6e7c9-9a10-4cd8-b63a-579a6e7ba78d in Project \"FabrikamFiber\" from \"[FabrikamFiber]\\Build Administrators\" to \"Jack Fabrikam\" with comment \"All admins are OOO\".",
"Area": "Checks",
"Category": "Modify",
"CategoryDisplayName": "Modify",
"ActorDisplayName": "Silviu"
}
]
Además, se mostrará en la interfaz de usuario de auditoría.
La biblioteca de tareas expone el modelo de hospedaje del agente
Los autores de tareas que desean determinar si un agente se ejecuta en grupos hospedados por Microsoft o no ahora puede usar la función getAgentMode()
Biblioteca de tareas para determinar el modelo de hospedaje. Esto es beneficioso en escenarios en los que una tarea quiere influir en el comportamiento en función de tener acceso a la red de un cliente o no. Una tarea puede intentar llegar a un servicio de Azure a través de un punto de conexión privado si se ejecuta desde un agente autohospedado o agentes de conjunto de escalado que residen en la red de un cliente.
Consulte la referencia de tareas.
Pasos siguientes
Nota:
Estas características se implementarán en las próximas dos a tres semanas.
Vaya a Azure DevOps y eche un vistazo.
Cómo enviar sus comentarios
Nos encantaría escuchar lo que piensas sobre estas características. Use el menú de ayuda para notificar un problema o proporcionar una sugerencia.
También puede obtener consejos y sus preguntas respondidas por la comunidad en Stack Overflow.
Gracias,
Vijay Machiraju