TrackingProfile.WorkflowTrackPoints Propiedad
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Obtiene la colección de puntos de seguimiento de flujo de trabajo utilizados por la infraestructura de seguimiento en tiempo de ejecución para filtrar eventos de estado de flujo de trabajo.
public:
property System::Workflow::Runtime::Tracking::WorkflowTrackPointCollection ^ WorkflowTrackPoints { System::Workflow::Runtime::Tracking::WorkflowTrackPointCollection ^ get(); };
public System.Workflow.Runtime.Tracking.WorkflowTrackPointCollection WorkflowTrackPoints { get; }
member this.WorkflowTrackPoints : System.Workflow.Runtime.Tracking.WorkflowTrackPointCollection
Public ReadOnly Property WorkflowTrackPoints As WorkflowTrackPointCollection
Valor de propiedad
WorkflowTrackPointCollection que especifica los puntos en una instancia de flujo de trabajo para los que la infraestructura de seguimiento en tiempo de ejecución debe enviar WorkflowTrackingRecord al servicio de seguimiento.
Ejemplos
El ejemplo de código siguiente muestra cómo puede crear TrackingProfile mediante el constructor TrackingProfile y utilizar las propiedades del objeto para ayudar a realizar el seguimiento de la ejecución de un flujo de trabajo. El código de ejemplo utiliza las propiedades ActivityTrackPoints, Version y WorkflowTrackPoints.
Este ejemplo de código pertenece a la consulta generada con el ejemplo del SDK de SQLTrackingService del archivo Program.cs. Para obtener más información, vea Consulta mediante SQLTrackingService.
private static void CreateAndInsertTrackingProfile()
{
TrackingProfile profile = new TrackingProfile();
ActivityTrackPoint activityTrack = new ActivityTrackPoint();
ActivityTrackingLocation activityLocation = new ActivityTrackingLocation(typeof(Activity));
activityLocation.MatchDerivedTypes = true;
IEnumerable<ActivityExecutionStatus> statuses = Enum.GetValues(typeof(ActivityExecutionStatus)) as IEnumerable<ActivityExecutionStatus>;
foreach (ActivityExecutionStatus status in statuses)
{
activityLocation.ExecutionStatusEvents.Add(status);
}
activityTrack.MatchingLocations.Add(activityLocation);
profile.ActivityTrackPoints.Add(activityTrack);
profile.Version = version;
WorkflowTrackPoint workflowTrack = new WorkflowTrackPoint();
WorkflowTrackingLocation workflowLocation = new WorkflowTrackingLocation();
IEnumerable<TrackingWorkflowEvent> eventStatuses = Enum.GetValues(typeof(TrackingWorkflowEvent)) as IEnumerable<TrackingWorkflowEvent>;
foreach (TrackingWorkflowEvent status in eventStatuses)
{
workflowLocation.Events.Add(status);
}
workflowTrack.MatchingLocation = workflowLocation;
profile.WorkflowTrackPoints.Add(workflowTrack);
TrackingProfileSerializer serializer = new TrackingProfileSerializer();
StringWriter writer = new StringWriter(new StringBuilder(), CultureInfo.InvariantCulture);
serializer.Serialize(writer, profile);
string trackingprofile = writer.ToString();
InsertTrackingProfile(trackingprofile);
}
Shared Sub CreateAndInsertTrackingProfile()
Dim profile As TrackingProfile = New TrackingProfile()
Dim activityTrack As ActivityTrackPoint = New ActivityTrackPoint()
Dim activityLocation As ActivityTrackingLocation = New ActivityTrackingLocation(GetType(Activity))
activityLocation.MatchDerivedTypes = True
Dim statuses As IEnumerable(Of ActivityExecutionStatus) = CType(System.Enum.GetValues(GetType(ActivityExecutionStatus)), IEnumerable(Of ActivityExecutionStatus))
For Each status As ActivityExecutionStatus In statuses
activityLocation.ExecutionStatusEvents.Add(status)
Next
activityTrack.MatchingLocations.Add(activityLocation)
profile.ActivityTrackPoints.Add(activityTrack)
profile.Version = version
Dim workflowTrack As WorkflowTrackPoint = New WorkflowTrackPoint()
Dim workflowLocation As WorkflowTrackingLocation = New WorkflowTrackingLocation()
Dim eventStatuses As IEnumerable(Of TrackingWorkflowEvent) = CType(System.Enum.GetValues(GetType(TrackingWorkflowEvent)), IEnumerable(Of TrackingWorkflowEvent))
For Each status As TrackingWorkflowEvent In eventStatuses
workflowLocation.Events.Add(status)
Next
workflowTrack.MatchingLocation = workflowLocation
profile.WorkflowTrackPoints.Add(workflowTrack)
Dim serializer As TrackingProfileSerializer = New TrackingProfileSerializer()
Dim writer As StringWriter = New StringWriter(New StringBuilder(), CultureInfo.InvariantCulture)
serializer.Serialize(writer, profile)
Dim trackingProfile As String = writer.ToString()
InsertTrackingProfile(trackingProfile)
End Sub
Comentarios
Una instancia de flujo de trabajo emite eventos de estado de flujo de trabajo a la infraestructura de seguimiento en tiempo de ejecución cada vez que se produce un evento TrackingWorkflowEvent que indica que el estado de una instancia de flujo de trabajo ha cambiado. La infraestructura de seguimiento en tiempo de ejecución utiliza la propiedad WorkflowTrackPoints para filtrar estos eventos de estado de flujo de trabajo a fin de determinar cuándo enviar WorkflowTrackingRecord al servicio de seguimiento. Puede agregar WorkflowTrackPoint a la propiedad WorkflowTrackPoints para especificar los puntos de interés en la ruta de acceso de ejecución potencial de la instancia de flujo de trabajo para los que desea enviar WorkflowTrackingRecord.
WorkflowTrackPoint no define un punto físico en una instancia de flujo de trabajo, sino que define uno o más valores de TrackingWorkflowEvent que la infraestructura de seguimiento en tiempo de ejecución puede usar para encontrar coincidencias con eventos de estado de flujo de trabajo. Por consiguiente, se pueden encontrar muchas coincidencias con el mismo WorkflowTrackPoint durante el tiempo de vida de una instancia de flujo de trabajo. WorkflowTrackPoint también puede especificar las anotaciones que se van a devolver en WorkflowTrackingRecord.