Reglas y evaluación de reglas
Azure DevOps Services | Azure DevOps Server 2022 | Azure DevOps Server 2019
Las reglas se usan para establecer o restringir las asignaciones de valores a un campo de elemento de trabajo. Hay dos tipos principales de reglas, las generadas automáticamente y las personalizadas definidas para un proceso o proyecto. Las reglas generadas automáticamente minimizan la necesidad de agregar reglas personalizadas para áreas que deberían funcionar de forma estándar.
Las reglas personalizadas se definen para admitir los casos de uso empresariales. Según el tipo de datos de un campo, puede establecer varias restricciones sobre los datos que se pueden introducir en ese campo. Puede establecer los valores de una lista de selección (menú desplegable), establecer los valores predeterminados, borrar entradas o restringir los cambios. Con reglas condicionales, puede aplicar reglas a un campo según las dependencias entre los diferentes valores del campo. También puede restringir quién puede modificar un campo o definir una regla para que solo se aplique a un grupo.
Lea este artículo para comprender lo siguiente:
- Cómo aplica el sistema las reglas generadas automáticamente
- Restricciones colocadas en la definición de reglas personalizadas en campos del sistema
- Los distintos tipos de reglas personalizadas que puede aplicar
- Cómo se evalúan las reglas
- Diferencia entre las reglas definidas para un proceso de herencia frente a un proceso XML local
- Por qué debe minimizar el número de reglas personalizadas que defina
Antes de definir reglas personalizadas, lea Configuración y personalización de Azure Boards para comprender ampliamente cómo personalizar Azure Boards para satisfacer sus necesidades empresariales.
Sugerencia
Minimice el número de reglas que defina para un WIT. Aunque puede crear varias reglas para un WIT, las reglas de adición pueden afectar negativamente al rendimiento cuando un usuario agrega y modifica elementos de trabajo. Cuando los usuarios guardan elementos de trabajo, el sistema valida todas las reglas asociadas a los campos para su tipo de elemento de trabajo. En determinadas condiciones, la expresión de validación de la regla es demasiado compleja para que SQL la evalúe.
Reglas generadas automáticamente
Las reglas generadas automáticamente minimizan la necesidad de agregar reglas personalizadas para áreas que deberían funcionar de forma estándar.
Reglas de transición de estado
Los procesos heredados generan todo el conjunto de reglas de transición de estado a cualquier de forma dinámica para cada tipo de elemento de trabajo personalizado y el estado personalizado agregado a un flujo de trabajo. Una transición de cualquier estado a cualquier estado es válida.
Para los procesos XML locales, debe especificar las transiciones válidas dentro de la sección de la WORKFLOW
definición de tipo de elemento de trabajo.
Transiciones de estado y reglas de campo Por/Fecha
Los campos By/Date corresponden a Created By/Date, Activated By/Date, Resolved By/Date y Closed By/Date.
En el caso de los procesos heredados, estos campos se establecen o borran automáticamente al realizar la transición de un elemento de trabajo de un estado a otro. Los campos Modificados por fecha no se incluyen ya que se actualizan con cada elemento de trabajo guardado y no están relacionados con las transiciones de estado.
Las reglas y comportamientos predeterminados que rigen estos campos incluyen:
- El estado Closed siempre está incluido en la categoría Estado completado .
- La categoría Estado completado no es configurable y está asociada a uno y solo un estado.
- Este estado Cerrado siempre está cerrado para los procesos agile y CMMI, y siempre listo para los procesos de Scrum y Basic.
- La generación automática de estas reglas se ve afectada por la configuración regional, ya que la condición de regla contiene el nombre de estado, que se localiza. El sistema genera diferentes reglas para diferentes configuraciones regionales.
- Las reglas generadas automáticamente para estos campos solo se especifican para los tipos de elementos de trabajo que incluyen estos campos. Es posible que un tipo de elemento de trabajo no incluya uno o varios de estos campos.
- Estas reglas son necesarias cuando un tipo de elemento de trabajo tiene estados personalizados o el tipo de elemento de trabajo es un tipo de elemento de trabajo personalizado.
- Estas reglas solo se aplican a los procesos heredados; nunca se generan para los procesos XML hospedados o XML locales.
Los estados de flujo de trabajo están asociados a categorías de estado para admitir el flujo de trabajo en los paneles. Para más información, consulte Uso de los estados de flujo de trabajo y las categorías de estado en trabajos pendientes y paneles.
Reglas de campo De fecha de cambio de estado
Estas reglas son técnicamente mucho más sencillas que las reglas cerradas por fecha cerrada porque no dependen de ningún estado determinado. Para cualquier tipo de elemento de trabajo, las mismas reglas siempre funcionarán. Deben generarse automáticamente porque algunos tipos de elementos de trabajo OOB no contienen el campo Fecha de cambio de estado, por lo que cuando el usuario agrega este campo a un tipo de elemento de trabajo personalizado, estas reglas también deben generarse automáticamente. Los mismos principios para las reglas Closed By/Closed Date también se aplican aquí.
Reglas personalizadas
Todas las reglas personalizadas son opcionales. Para un proceso heredado, especifique una regla que consta de una condición más una acción. Para un proceso XML local, especifique reglas para un campo o dentro del flujo de trabajo.
No hay una asignación uno a uno entre los dos procesos. En algunos casos, la regla de elementos XML se define dentro del cuadro de diálogo Editar campo para el proceso heredado y no como regla. Otros elementos XML, como FROZEN
, MATCH
, NOTSAMEAS
, , no se admiten en el proceso heredado.
Tenga en cuenta lo siguiente:
- Las reglas siempre se aplican, no solo cuando interactúa con el formulario, sino también al interactuar con otras herramientas. Por ejemplo, establecer un campo como de solo lectura no solo aplica la regla en el formulario de elemento de trabajo, sino también a través de la API y el complemento de Azure DevOps Server de Excel.
- Las entradas de proceso heredadas especifican condiciones y acciones para realizar una regla completa. Los elementos XML no distinguen esas diferencias.
- Las reglas de campo no admiten la asignación de valores que son la suma de otros dos campos o que realizan cálculos matemáticos. Sin embargo, puede encontrar una solución que se adapte a sus necesidades a través de la extensión de Marketplace del agregador de TFS (servicio web). Consulte también Acumulación de trabajo y otros campos.
- Puede encontrar soluciones adicionales para aplicar reglas personalizadas a campos mediante extensiones de Marketplace, como la extensión biblioteca de control de formularios del elemento de trabajo.
Composición de reglas
Para un proceso heredado, cada regla consta de dos partes: Condiciones y acciones. Las condiciones definen las circunstancias que deben cumplirse para que se aplique la regla. Las acciones definen las operaciones que se van a realizar. Para la mayoría de las reglas, puede especificar un máximo de dos condiciones y 10 acciones por regla. Todas las reglas personalizadas requieren que se cumplan todas las condiciones para poder ejecutarse.
Por ejemplo, puede hacer que un campo sea necesario en función del valor asignado al estado y a otro campo. Por ejemplo:
(Condition) When a work item State is
Activo
(Condition) And when the value of
Área de valor = Negocio
(Action) Then make required
Puntos de historia
Nota:
Actualmente, solo se admite una condición para las reglas de transición de estado. Si aplica reglas basadas en el estado, consulte Aplicar reglas a estados de flujo de trabajo.
En la tabla siguiente se resumen las acciones que están disponibles con las condiciones seleccionadas.
Condición
Acciones admitidas
Establecer el valor de campo o hacer necesario o de solo lectura
Restricción de una transición basada en el estado
Ocultar el campo o hacer que el campo sea de solo lectura o necesario en función del estado y la pertenencia a usuarios o grupos
Según y la pertenencia a grupos o usuarios, establezca el atributo de campo o restrinja una transición de estado.
¿Qué ocurre si se definen demasiadas reglas?
Se define una expresión SQL única por proyecto para validar los elementos de trabajo cada vez que se crean o actualizan. Esta expresión crece con el número de reglas que se especifican para todos los tipos de elementos de trabajo definidos para el proyecto. Cada calificador de comportamiento especificado para un campo da como resultado un aumento en el número de subexpresiones. Las reglas anidadas, reglas que solo se aplican en una transición o condicionadas en el valor de algún otro campo, hacen que se agreguen más condiciones a una IF
instrucción . Una vez que la expresión alcanza un tamaño o complejidad determinado, SQL no puede evaluarla más y genera un error. La eliminación de algunas WIT o la eliminación de algunas reglas puede resolver el error.
Puede establecer los valores de una lista de selección (menú desplegable), establecer los valores predeterminados, borrar entradas o restringir los cambios. Con reglas condicionales, puede aplicar reglas a un campo según las dependencias entre los diferentes valores del campo. También puede restringir quién puede modificar un campo o definir una regla para que solo se aplique a un grupo.
Las reglas de elementos de trabajo no existen como una sola colección. Las reglas se generan y combinan dinámicamente a partir de diferentes orígenes de datos. La lógica de combinación es una sencilla, consolida reglas idénticas, pero no recorta las reglas en conflicto.
Reglas de omisión
En general, el motor de reglas valida todos los elementos de trabajo cuando los usuarios modifican el elemento de trabajo. Sin embargo, para admitir determinados escenarios, los usuarios asignados a las reglas de omisión en las actualizaciones de elementos de trabajo del permiso de nivel de proyecto pueden guardar elementos de trabajo sin que se evalúen las reglas.
Las reglas se pueden omitir de una de estas dos maneras. La primera es a través de la API REST Elementos de trabajo: actualice y establezca el bypassRules
parámetro en true
. El segundo es a través del modelo de objetos de cliente, inicializando en modo bypassrules (inicializar WorkItemStore
con WorkItemStoreFlags.BypassRules
).
Campos del sistema y reglas personalizadas
Los campos del sistema tienen Sistema.Nombres de referencia de nombre, por ejemplo System.Title y System.State.
Los siguientes campos del sistema deben tener un valor: Id. de área, Fecha de cambio, Fecha de creación, Creado por, Estado y Motivo.
El motor de reglas restringe la configuración de condiciones o acciones a los campos del sistema, excepto los siguientes:
- Puede hacer que los campos Estado y Motivo sean de solo lectura.
- Puede aplicar la mayoría de las reglas a los campos Título, Asignado a, Descripción y Modificado por .
Si no ve un campo que aparece en el menú desplegable de la interfaz de usuario de regla para el proceso de herencia, este es el motivo. Por ejemplo, si intenta hacer que la ruta de acceso del área (System.AreaPath) sea de solo lectura en función de una condición, el campo Ruta de acceso del área no está disponible para la selección. Incluso si puede especificar un campo del sistema, el motor de reglas puede impedir que guarde la regla.
Reglas predeterminadas y de copia
Las reglas predeterminadas y de copia modifican los valores de los campos de elemento de trabajo. Definen el comportamiento y las restricciones en tiempo de ejecución, como especificar valores predeterminados, borrar campos, requerir que se definan los campos y mucho más.
Puede restringir la aplicación de estas reglas en función de la pertenencia a grupos del usuario actual, tal como se describe en Restricciones de reglas de pertenencia a grupos o usuarios.
La mayoría de estas acciones de regla se pueden aplicar con la selección de cualquier condición.
Acción de proceso heredado
Descripción
Copy the value from...
Especifica otro campo que contiene un valor que se va a copiar en el campo actual.
Clear the value of...
Borra el campo de cualquier valor que contenga.
Use the current time to set the value of ...
Establece la hora de un campo en función de la configuración de hora del usuario actual.
Reglas de restricción
Las reglas de restricción restringen el cambio del valor de un campo. Definen los estados válidos para un elemento de trabajo. Cada restricción funciona en un solo campo. Las restricciones se evalúan en el servidor en el guardado del elemento de trabajo y, si se infringe alguna restricción, se rechaza la operación de guardado.
Puede restringir la aplicación de estas reglas en función de la pertenencia a grupos del usuario actual, tal como se describe en Restricciones de reglas de pertenencia a grupos o usuarios.
La mayoría de estas acciones de regla se pueden aplicar con la selección de cualquier condición.
Acción de proceso heredado
Descripción
Hide the field...
Solo está disponible cuando se selecciona una condición de pertenencia a grupos.
Especifica que no se muestra el campo en el formulario de elemento de trabajo, lo que básicamente elimina la capacidad de que el usuario actual cambie el valor del campo.
Make read-only
Impide que un campo se modifique en absoluto. Es posible que quiera aplicar esta regla en determinadas condiciones. Por ejemplo, después de cerrar un elemento de trabajo, quiere hacer que un campo sea de solo lectura para conservar los datos con fines de informes.
Para especificar que el campo predeterminado es de solo lectura, especifique en el cuadro de diálogo Editar campo, pestaña Opciones .
Make required
Requiere que un usuario especifique un valor para el campo. Los usuarios no pueden guardar un elemento de trabajo hasta que hayan asignado valores a todos los campos obligatorios.
Para especificar el valor predeterminado del campo, especifique en el cuadro de diálogo Editar campo, pestaña Opciones .
Listas desplegables
Las listas de selección definen los valores que un usuario puede o no puede elegir para un campo String o Integer. Los valores definidos en una lista de selección aparecen en un formulario de elemento de trabajo y en el editor de consultas.
Para un proceso heredado, las listas de selección se definen mediante el cuadro de diálogo Editar campo.
Cuadro de diálogo Editar campo
Descripción
Pestaña Definición de un campo de lista desplegable
Define una lista de valores permitidos para el campo. Los valores permitidos son valores que están disponibles para la selección en una lista de campos en formularios de elementos de trabajo y en el generador de consultas. Debe seleccionar uno de estos valores.
Active la casilla Permitir que los usuarios escriban sus propios valores en la pestaña Opciones para permitir que los usuarios especifiquen sus propias entradas.
Define una lista de valores sugeridos para el campo. Los valores sugeridos son valores que están disponibles para la selección en una lista de campos en formularios de elementos de trabajo y en el generador de consultas. Puede escribir otros valores además de los de la lista.
Cambios o valores de campo condicionales
Las reglas condicionales especifican una acción basada en el valor de un campo que es igual o no es igual a un valor específico, o si se realizó un cambio o no en el valor de un campo específico. En general, las reglas condicionales se aplican primero sobre las reglas incondicionales. Cuando varias reglas condicionales se evalúan como true, el orden de ejecución es: When, WhenNot, WhenChanged, WhenNotChanged.
Puede especificar varias reglas condicionales por campo. Sin embargo, solo puede especificar un único campo de conducción por regla condicional.
Condición heredada
Descripción
The value of ... (equals)
[Cuándo]
Especifica una o varias reglas que se aplicarán al campo actual cuando otro campo tiene un valor específico.
A change was made to the value of ...
[WhenChanged]
Aplica una o varias reglas al campo actual cuando se cambia el valor de un campo específico.
The value of ... (not equals)
[WhenNot]
Aplica una o varias reglas al campo actual cuando otro campo no tiene un valor específico.
No change was made to the value of ...
[WhenNotChanged]
Aplica una o varias reglas al campo actual cuando no se cambia el valor de un campo específico.
Acción heredada
Descripción
Clear the value of ...
Copy the value from ...
Make read-only ...
Make required ...
Set the value of ...
Use the current time to set the value of ...
Use the current user to set the value of ...
Especifica la acción que se va a realizar en un campo específico.
Restricciones de reglas de pertenencia a grupos o usuarios
Puede restringir la aplicación de una regla en función de la pertenencia del usuario actual. Se recomienda limitar el ámbito de la regla a un grupo de seguridad de Azure DevOps y no a un solo usuario, aunque puede especificar este último. Para que la regla tenga el ámbito de varios grupos, debe crear un grupo primario de Azure DevOps que incluya el conjunto de grupos que desea usar.
Implementación de procesos
Sugerencia
Para evitar problemas de evaluación de reglas que pueden surgir, especifique los grupos de seguridad de Azure DevOps y no el identificador de Microsoft Entra o los grupos de seguridad de Active Directory. Para obtener más información, consulte Reglas predeterminadas y el motor de reglas.
Como se indica en la tabla siguiente, para restringir una regla basada en la pertenencia del usuario actual, especifique una de las dos condiciones para un proceso heredado. Estas reglas están activas para Azure DevOps 2020 y versiones posteriores.
Se aplica a
Regla
Condición
Current user is a member of group ...
Current user is not member of group ...
Action
Hide the field ...
Make read-only ...
Make required ...
Restrict the transition to state ...
Uso de tokens para hacer referencia a usuarios o grupos
Los campos de identidad o selector de personas pueden aceptar valores que hacen referencia a usuarios y grupos. Al restringir una regla a un grupo, se indica el dominio o el ámbito del grupo. Para algunos valores, puede usar tokens.
Entre los ejemplos de tokens se incluyen los siguientes:
- [ProjectName], como [Fabrikam], [FabrikamFiber], [MyProject]
- [OrganizationName], como [fabrikam], [myorganization]
- [CollectionName], como [fabrikam], [myorganization]
Para obtener información sobre los ámbitos disponibles para el proyecto o la organización, vaya a la página Grupos de permisos de configuración del proyecto o Grupos de permisos>>de configuración>>de la organización, puede filtrar la lista según sea necesario. Por ejemplo, en la imagen siguiente se muestran las cuatro primeras entradas en una lista filtrada basada en Azure DevOps. Para obtener más información, vea Cambiar permisos de nivel de proyecto o Cambiar permisos de nivel de colección de proyectos.
Para más información sobre los grupos de seguridad predeterminados, consulte Permisos y grupos.
Evaluación de reglas
Las reglas que especifican una condición basada en la pertenencia de usuario o grupo del usuario que modifica un elemento de trabajo se evalúan de dos maneras. Cuando se evalúa la regla, la aplicación debe determinar si la regla se aplica al usuario actual comprobando si ese usuario es o no es miembro del grupo especificado.
- Al modificar el elemento de trabajo desde el portal web, la API REST o el comando azure boards , se realiza una solicitud al identificador de Microsoft Entra o Active Directory. No se producen problemas para esta operación.
- Al modificar el elemento de trabajo desde Visual Studio, Excel u otra herramienta personalizada mediante el modelo de objetos de cliente WIT, la solicitud para evaluar la pertenencia se basa en una caché de cliente. La caché de cliente no es consciente de los grupos de Active Directory.
Nota:
Visual Studio 2019 Team Explorer para proyectos que usan GIT se ha vuelto a escribir para usar las API REST.
Para evitar problemas con los usuarios que actualizan elementos de trabajo de varios clientes, especifique grupos de seguridad de Azure DevOps en lugar de grupos de Active Directory. Puede crear fácilmente un grupo de seguridad de Azure DevOps para que se corresponda con un grupo de Active Directory. Para obtener información sobre cómo, consulte Agregar o quitar usuarios o grupos, administrar grupos de seguridad.
Nota:
El OM del cliente WIT está en desuso. A partir del 1 de enero de 2020, ya no se admite cuando se trabaja con Azure DevOps Services y Azure DevOps Server 2020.
Orden en el que se evalúan las reglas
Normalmente, las reglas se procesan en la secuencia en la que se enumeran. Sin embargo, la secuencia completa para la evaluación de todas las reglas no es totalmente determinista.
En esta sección se describen el comportamiento esperado y las interacciones cuando se aplican reglas condicionales, de copia y predeterminadas.
Los pasos siguientes muestran, en la secuencia correcta, las interacciones que realiza Azure DevOps y por el usuario de un formulario de elemento de trabajo. El usuario solo realiza los pasos 1, 8 y 13.
Desde un cliente de Azure DevOps, como el portal web o Visual Studio Team Explorer, un usuario crea un nuevo elemento de trabajo o edita un elemento de trabajo existente.
Rellene los valores predeterminados del campo. Para todos los campos, aplique los valores predeterminados asignados al campo que no formen parte de una cláusula condicional.
Copie o establezca valores de campo. Para todos los campos, aplique las reglas para copiar un valor o establecer el valor de un campo que no forme parte de una cláusula condicional.
Para todos los campos con una regla condicional When que coincida, aplique reglas para establecer o copiar un valor de campo.
Para todos los campos con una regla condicional When Not que coincida, aplique reglas para establecer o copiar un valor de campo.
El sistema siempre procesa las reglas When before When Not .
Para todos los campos que han cambiado sus valores desde el paso 1 y que contienen reglas When Changed , aplique reglas para establecer o copiar un valor de campo.
Permitir al usuario iniciar la edición.
El usuario cambia un valor de campo y, a continuación, mueve el foco del campo.
Procese las reglas When para ese campo que coincidan con el nuevo valor.
Procese las reglas When Not para ese campo que coincidan con el nuevo valor.
Procese las reglas When Changed para ese campo que coincidan con el nuevo valor.
Devolver la capacidad de edición al usuario.
El usuario guarda los cambios en el almacén de datos.
Para todos los campos, aplique las
Use the current time to set the value of ...
acciones definidas para el campo directamente o indirectamente bajo una regla condicional.