GivenThatWeWantToBuildANetCoreAppForTelemetry.cs 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. // Licensed to the .NET Foundation under one or more agreements.
  2. // The .NET Foundation licenses this file to you under the MIT license.
  3. using System.Reflection;
  4. namespace Microsoft.NET.Build.Tests
  5. {
  6. public class GivenThatWeWantToBuildANetCoreAppAndPassingALogger : SdkTest
  7. {
  8. public GivenThatWeWantToBuildANetCoreAppAndPassingALogger(ITestOutputHelper log) : base(log)
  9. {
  10. }
  11. [CoreMSBuildOnlyFact]
  12. public void It_collects_TargetFramework_version_and_other_properties()
  13. {
  14. string targetFramework = ToolsetInfo.CurrentTargetFramework;
  15. var testProject = new TestProject()
  16. {
  17. Name = "FrameworkTargetTelemetryTest",
  18. TargetFrameworks = targetFramework,
  19. };
  20. Type loggerType = typeof(LogTelemetryToStdOutForTest);
  21. var TelemetryTestLogger = new[]
  22. {
  23. $"/Logger:{loggerType.FullName},{loggerType.GetTypeInfo().Assembly.Location}"
  24. };
  25. var testAsset = _testAssetsManager.CreateTestProject(testProject);
  26. var buildCommand = new BuildCommand(testAsset);
  27. buildCommand
  28. .Execute(TelemetryTestLogger)
  29. .StdOut.Should()
  30. .Contain($"{{\"EventName\":\"targetframeworkeval\",\"Properties\":{{\"TargetFrameworkVersion\":\".NETCoreApp,Version=v{ToolsetInfo.CurrentTargetFrameworkVersion}\",\"RuntimeIdentifier\":\"null\",\"SelfContained\":\"null\",\"UseApphost\":\"null\",\"OutputType\":\"Library\",\"UseArtifactsOutput\":\"null\",\"ArtifactsPathLocationType\":\"null\"}}");
  31. }
  32. [CoreMSBuildOnlyFact]
  33. public void It_collects_multi_TargetFramework_version_and_other_properties()
  34. {
  35. string targetFramework = $"net46;{ToolsetInfo.CurrentTargetFramework}";
  36. var testProject = new TestProject()
  37. {
  38. Name = "MultitargetTelemetry",
  39. TargetFrameworks = targetFramework,
  40. };
  41. Type loggerType = typeof(LogTelemetryToStdOutForTest);
  42. var TelemetryTestLogger = new[]
  43. {
  44. $"/Logger:{loggerType.FullName},{loggerType.GetTypeInfo().Assembly.Location}"
  45. };
  46. var testAsset = _testAssetsManager.CreateTestProject(testProject);
  47. var buildCommand = new BuildCommand(testAsset);
  48. var result = buildCommand
  49. .Execute(TelemetryTestLogger);
  50. result
  51. .StdOut.Should()
  52. .Contain(
  53. "{\"EventName\":\"targetframeworkeval\",\"Properties\":{\"TargetFrameworkVersion\":\".NETFramework,Version=v4.6\",\"RuntimeIdentifier\":\"null\",\"SelfContained\":\"null\",\"UseApphost\":\"null\",\"OutputType\":\"Library\",\"UseArtifactsOutput\":\"null\",\"ArtifactsPathLocationType\":\"null\"}")
  54. .And
  55. .Contain(
  56. $"{{\"EventName\":\"targetframeworkeval\",\"Properties\":{{\"TargetFrameworkVersion\":\".NETCoreApp,Version=v{ToolsetInfo.CurrentTargetFrameworkVersion}\",\"RuntimeIdentifier\":\"null\",\"SelfContained\":\"null\",\"UseApphost\":\"null\",\"OutputType\":\"Library\",\"UseArtifactsOutput\":\"null\",\"ArtifactsPathLocationType\":\"null\"}}");
  57. }
  58. }
  59. }