private async Task TrackProjectAsync(GenStatusEnum status, string templateName, UserSelectionContext context, Guid vsProjectId, GenItemsTelemetryData genItemsTelemetryData = null, double?timeSpent = null, Dictionary <ProjectMetricsEnum, double> performanceCounters = null, CreationResultStatus genStatus = CreationResultStatus.Success, string message = "") { // TODO: Remove TelemetryProperties.Framework and use TelemetryProperties.FrontendFramework var properties = new Dictionary <string, string>() { { TelemetryProperties.Status, status.ToString() }, { TelemetryProperties.ProjectType, context.ProjectType }, { TelemetryProperties.Framework, context.FrontEndFramework }, { TelemetryProperties.FrontendFramework, context.FrontEndFramework }, { TelemetryProperties.BackendFramework, context.BackEndFramework }, { TelemetryProperties.TemplateName, templateName }, { TelemetryProperties.GenEngineStatus, genStatus.ToString() }, { TelemetryProperties.GenEngineMessage, message }, { TelemetryProperties.EventName, TelemetryEvents.ProjectGen }, { TelemetryProperties.Language, context.Language }, { TelemetryProperties.VisualStudioActiveProjectGuid, vsProjectId.ToString() }, { TelemetryProperties.VsProjectCategory, context.Platform }, }; AddPropertiesFromPropertyBag(context, properties); var metrics = new Dictionary <string, double>(); if (genItemsTelemetryData.PagesCount.HasValue) { metrics.Add(TelemetryMetrics.PagesCount, genItemsTelemetryData.PagesCount.Value); } if (genItemsTelemetryData.FeaturesCount.HasValue) { metrics.Add(TelemetryMetrics.FeaturesCount, genItemsTelemetryData.FeaturesCount.Value); } if (genItemsTelemetryData.ServicesCount.HasValue) { metrics.Add(TelemetryMetrics.ServicesCount, genItemsTelemetryData.ServicesCount.Value); } if (genItemsTelemetryData.TestingCount.HasValue) { metrics.Add(TelemetryMetrics.TestingCount, genItemsTelemetryData.TestingCount.Value); } if (timeSpent.HasValue) { metrics.Add(TelemetryMetrics.TimeSpent, timeSpent.Value); } if (performanceCounters != null) { foreach (var perfCounter in performanceCounters) { metrics.Add(TelemetryMetrics.ProjectMetricsTimeSpent + perfCounter.Key.ToString(), perfCounter.Value); } } GenContext.ToolBox.Shell.SafeTrackProjectVsTelemetry(properties, genItemsTelemetryData.PageIdentities, genItemsTelemetryData.FeatureIdentities, genItemsTelemetryData.ServiceIdentities, genItemsTelemetryData.TestingIdentities, metrics, status == GenStatusEnum.Completed); await TelemetryService.Current.TrackEventAsync(TelemetryEvents.ProjectGen, properties, metrics).ConfigureAwait(false); }
private async Task TrackProjectAsync(GenStatusEnum status, string templateName, string appType, string appFx, int?pagesCount = null, int?featuresCount = null, double?timeSpent = null, CreationResultStatus genStatus = CreationResultStatus.Success, string message = "") { Dictionary <string, string> properties = new Dictionary <string, string>() { { TelemetryProperties.Status, status.ToString() }, { TelemetryProperties.ProjectType, appType }, { TelemetryProperties.Framework, appFx }, { TelemetryProperties.TemplateName, templateName }, { TelemetryProperties.GenEngineStatus, genStatus.ToString() }, { TelemetryProperties.GenEngineMessage, message }, { TelemetryProperties.EventName, TelemetryEvents.ProjectGen } }; Dictionary <string, double> metrics = new Dictionary <string, double>(); if (pagesCount.HasValue) { metrics.Add(TelemetryMetrics.PagesCount, pagesCount.Value); } if (timeSpent.HasValue) { metrics.Add(TelemetryMetrics.TimeSpent, timeSpent.Value); } if (featuresCount.HasValue) { metrics.Add(TelemetryMetrics.FeaturesCount, featuresCount.Value); } await TelemetryService.Current.TrackEventAsync(TelemetryEvents.ProjectGen, properties, metrics).ConfigureAwait(false); }
private async Task TrackItemGenAsync(string eventToTrack, GenStatusEnum status, string appType, string pageFx, string templateName, CreationResultStatus genStatus = CreationResultStatus.Success, string message = "") { var properties = new Dictionary <string, string>() { { TelemetryProperties.Status, status.ToString() }, { TelemetryProperties.Framework, pageFx }, { TelemetryProperties.TemplateName, templateName }, { TelemetryProperties.GenEngineStatus, genStatus.ToString() }, { TelemetryProperties.GenEngineMessage, message }, { TelemetryProperties.EventName, eventToTrack } }; await TelemetryService.Current.TrackEventAsync(eventToTrack, properties).ConfigureAwait(false); }
private async Task TrackProjectAsync(GenStatusEnum status, string templateName, string appType, string appFx, string appPlatform, Guid vsProjectId, string language, int?pagesCount = null, int?featuresCount = null, string pageIdentities = "", string featureIdentites = "", double?timeSpent = null, Dictionary <ProjectMetricsEnum, double> performanceCounters = null, CreationResultStatus genStatus = CreationResultStatus.Success, string message = "") { var properties = new Dictionary <string, string>() { { TelemetryProperties.Status, status.ToString() }, { TelemetryProperties.ProjectType, appType }, { TelemetryProperties.Framework, appFx }, { TelemetryProperties.TemplateName, templateName }, { TelemetryProperties.GenEngineStatus, genStatus.ToString() }, { TelemetryProperties.GenEngineMessage, message }, { TelemetryProperties.EventName, TelemetryEvents.ProjectGen }, { TelemetryProperties.Language, language }, { TelemetryProperties.VisualStudioActiveProjectGuid, vsProjectId.ToString() }, { TelemetryProperties.VsProjectCategory, appPlatform }, }; var metrics = new Dictionary <string, double>(); if (pagesCount.HasValue) { metrics.Add(TelemetryMetrics.PagesCount, pagesCount.Value); } if (featuresCount.HasValue) { metrics.Add(TelemetryMetrics.FeaturesCount, featuresCount.Value); } if (timeSpent.HasValue) { metrics.Add(TelemetryMetrics.TimeSpent, timeSpent.Value); } if (performanceCounters != null) { foreach (var perfCounter in performanceCounters) { metrics.Add(TelemetryMetrics.ProjectMetricsTimeSpent + perfCounter.Key.ToString(), perfCounter.Value); } } TelemetryService.Current.SafeTrackProjectVsTelemetry(properties, pageIdentities, featureIdentites, metrics, status == GenStatusEnum.Completed); await TelemetryService.Current.TrackEventAsync(TelemetryEvents.ProjectGen, properties, metrics).ConfigureAwait(false); }
private async Task TrackItemGenAsync(string eventToTrack, GenStatusEnum status, string appType, string appFrontendFramework, string appBackendFramework, string appPlatform, string templateName, GenSourceEnum genSource, CreationResultStatus genStatus = CreationResultStatus.Success, string message = "") { // TODO: Remove TelemetryProperties.Framework and use TelemetryProperties.FrontendFramework var properties = new Dictionary <string, string> { { TelemetryProperties.Status, status.ToString() }, { TelemetryProperties.Framework, appFrontendFramework }, { TelemetryProperties.FrontendFramework, appFrontendFramework }, { TelemetryProperties.BackendFramework, appBackendFramework }, { TelemetryProperties.TemplateName, templateName }, { TelemetryProperties.GenEngineStatus, genStatus.ToString() }, { TelemetryProperties.GenEngineMessage, message }, { TelemetryProperties.EventName, eventToTrack }, { TelemetryProperties.GenSource, genSource.ToString() }, { TelemetryProperties.ProjectType, appType }, { TelemetryProperties.VsProjectCategory, appPlatform }, }; await TelemetryService.Current.TrackEventAsync(eventToTrack, properties).ConfigureAwait(false); }
private async Task TrackProjectAsync(GenStatusEnum status, string templateName, string appType, string appFx, Guid vsProjectId, int?pagesCount = null, int?featuresCount = null, double?timeSpent = null, CreationResultStatus genStatus = CreationResultStatus.Success, string message = "") { var properties = new Dictionary <string, string>() { { TelemetryProperties.Status, status.ToString() }, { TelemetryProperties.ProjectType, appType }, { TelemetryProperties.Framework, appFx }, { TelemetryProperties.TemplateName, templateName }, { TelemetryProperties.GenEngineStatus, genStatus.ToString() }, { TelemetryProperties.GenEngineMessage, message }, { TelemetryProperties.EventName, TelemetryEvents.ProjectGen }, { TelemetryProperties.VisualStudioActiveProjectGuid, vsProjectId.ToString() }, { TelemetryProperties.VsProjectCategory, "Uwp" } }; var metrics = new Dictionary <string, double>(); if (pagesCount.HasValue) { metrics.Add(TelemetryMetrics.PagesCount, pagesCount.Value); } if (timeSpent.HasValue) { metrics.Add(TelemetryMetrics.TimeSpent, timeSpent.Value); } if (featuresCount.HasValue) { metrics.Add(TelemetryMetrics.FeaturesCount, featuresCount.Value); } TelemetryService.Current.SafeTrackProjectVsTelemetry(properties, metrics, status == GenStatusEnum.Completed); await TelemetryService.Current.TrackEventAsync(TelemetryEvents.ProjectGen, properties, metrics).ConfigureAwait(false); }