2022-12-02 08:03:23 +00:00
|
|
|
using System.Globalization;
|
2022-04-19 15:06:10 +02:00
|
|
|
using Microsoft.Extensions.Hosting;
|
|
|
|
|
using Microsoft.Extensions.Options;
|
|
|
|
|
using Moq;
|
2022-04-20 15:54:09 +02:00
|
|
|
using NPoco;
|
2022-04-19 15:06:10 +02:00
|
|
|
using NUnit.Framework;
|
|
|
|
|
using Umbraco.Cms.Core;
|
|
|
|
|
using Umbraco.Cms.Core.Configuration;
|
|
|
|
|
using Umbraco.Cms.Core.Configuration.Models;
|
|
|
|
|
using Umbraco.Cms.Core.Services;
|
2022-07-04 01:54:27 +02:00
|
|
|
using Umbraco.Cms.Core.Sync;
|
2025-09-23 11:58:09 +02:00
|
|
|
using Umbraco.Cms.DevelopmentMode.Backoffice.InMemoryAuto;
|
2022-04-19 15:06:10 +02:00
|
|
|
using Umbraco.Cms.Infrastructure.Persistence;
|
|
|
|
|
using Umbraco.Cms.Infrastructure.Telemetry.Providers;
|
|
|
|
|
|
2022-06-21 08:09:38 +02:00
|
|
|
namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Core.Telemetry;
|
|
|
|
|
|
|
|
|
|
[TestFixture]
|
2023-12-22 10:21:11 +01:00
|
|
|
public class SystemTroubleshootingInformationTelemetryProviderTests
|
2022-04-19 15:06:10 +02:00
|
|
|
{
|
2022-06-21 08:09:38 +02:00
|
|
|
[Test]
|
2025-09-23 11:58:09 +02:00
|
|
|
[TestCase(Constants.ModelsBuilder.ModelsModes.Nothing)]
|
|
|
|
|
[TestCase(ModelsModeConstants.InMemoryAuto)]
|
|
|
|
|
[TestCase(Constants.ModelsBuilder.ModelsModes.SourceCodeAuto)]
|
|
|
|
|
[TestCase(Constants.ModelsBuilder.ModelsModes.SourceCodeManual)]
|
|
|
|
|
public void ReportsModelsModeCorrectly(string modelsMode)
|
2022-06-21 08:09:38 +02:00
|
|
|
{
|
|
|
|
|
var telemetryProvider = CreateProvider(modelsMode);
|
|
|
|
|
var usageInformation = telemetryProvider.GetInformation().ToArray();
|
|
|
|
|
|
|
|
|
|
var actual = usageInformation.FirstOrDefault(x => x.Name == Constants.Telemetry.ModelsBuilderMode);
|
|
|
|
|
Assert.IsNotNull(actual?.Data);
|
2025-09-23 11:58:09 +02:00
|
|
|
Assert.AreEqual(modelsMode, actual.Data);
|
2022-06-21 08:09:38 +02:00
|
|
|
}
|
|
|
|
|
|
2022-12-02 08:03:23 +00:00
|
|
|
[Test]
|
|
|
|
|
[TestCase(RuntimeMode.BackofficeDevelopment)]
|
|
|
|
|
[TestCase(RuntimeMode.BackofficeDevelopment)]
|
|
|
|
|
[TestCase(RuntimeMode.BackofficeDevelopment)]
|
|
|
|
|
|
|
|
|
|
public void ReportsRuntimeModeCorrectly(RuntimeMode runtimeMode)
|
|
|
|
|
{
|
|
|
|
|
var telemetryProvider = CreateProvider(runtimeMode: runtimeMode);
|
|
|
|
|
var usageInformation = telemetryProvider.GetInformation().ToArray();
|
|
|
|
|
|
|
|
|
|
var actual = usageInformation.FirstOrDefault(x => x.Name == Constants.Telemetry.RuntimeMode);
|
|
|
|
|
Assert.IsNotNull(actual?.Data);
|
|
|
|
|
Assert.AreEqual(runtimeMode.ToString(), actual.Data);
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-21 08:09:38 +02:00
|
|
|
[Test]
|
|
|
|
|
[TestCase(true)]
|
|
|
|
|
[TestCase(false)]
|
|
|
|
|
public void ReportsDebugModeCorrectly(bool isDebug)
|
|
|
|
|
{
|
|
|
|
|
var telemetryProvider = CreateProvider(isDebug: isDebug);
|
|
|
|
|
var usageInformation = telemetryProvider.GetInformation().ToArray();
|
|
|
|
|
|
|
|
|
|
var actual = usageInformation.FirstOrDefault(x => x.Name == Constants.Telemetry.IsDebug);
|
|
|
|
|
Assert.IsNotNull(actual?.Data);
|
|
|
|
|
Assert.AreEqual(isDebug, actual.Data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
[TestCase("en-US")]
|
|
|
|
|
[TestCase("de-DE")]
|
|
|
|
|
[TestCase("en-NZ")]
|
|
|
|
|
[TestCase("sv-SE")]
|
|
|
|
|
public void ReportsOsLanguageCorrectly(string culture)
|
|
|
|
|
{
|
|
|
|
|
Thread.CurrentThread.CurrentCulture = new CultureInfo(culture);
|
|
|
|
|
var telemetryProvider = CreateProvider();
|
|
|
|
|
|
|
|
|
|
var usageInformation = telemetryProvider.GetInformation().ToArray();
|
|
|
|
|
var actual = usageInformation.FirstOrDefault(x => x.Name == Constants.Telemetry.OsLanguage);
|
|
|
|
|
|
|
|
|
|
Assert.NotNull(actual?.Data);
|
|
|
|
|
Assert.AreEqual(culture, actual.Data.ToString());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
[TestCase("Development")]
|
|
|
|
|
[TestCase("Staging")]
|
|
|
|
|
[TestCase("Production")]
|
|
|
|
|
public void ReportsCorrectAspEnvironment(string environment)
|
|
|
|
|
{
|
|
|
|
|
var telemetryProvider = CreateProvider(environment: environment);
|
|
|
|
|
|
|
|
|
|
var usageInformation = telemetryProvider.GetInformation().ToArray();
|
|
|
|
|
var actual = usageInformation.FirstOrDefault(x => x.Name == Constants.Telemetry.AspEnvironment);
|
|
|
|
|
|
|
|
|
|
Assert.NotNull(actual?.Data);
|
|
|
|
|
Assert.AreEqual(environment, actual.Data);
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-22 10:21:11 +01:00
|
|
|
private SystemTroubleshootingInformationTelemetryProvider CreateProvider(
|
2025-09-23 11:58:09 +02:00
|
|
|
string modelsMode = ModelsModeConstants.InMemoryAuto,
|
2022-06-21 08:09:38 +02:00
|
|
|
bool isDebug = true,
|
2022-12-02 08:03:23 +00:00
|
|
|
string environment = "",
|
|
|
|
|
RuntimeMode runtimeMode = RuntimeMode.BackofficeDevelopment)
|
2022-04-19 15:06:10 +02:00
|
|
|
{
|
2022-06-21 08:09:38 +02:00
|
|
|
var hostEnvironment = new Mock<IHostEnvironment>();
|
|
|
|
|
hostEnvironment.Setup(x => x.EnvironmentName).Returns(environment);
|
|
|
|
|
|
|
|
|
|
var databaseMock = new Mock<IUmbracoDatabase>();
|
|
|
|
|
databaseMock.Setup(x => x.DatabaseType.GetProviderName()).Returns("SQL");
|
|
|
|
|
|
2023-12-22 10:21:11 +01:00
|
|
|
return new SystemTroubleshootingInformationTelemetryProvider(
|
2022-06-21 08:09:38 +02:00
|
|
|
Mock.Of<IUmbracoVersion>(),
|
|
|
|
|
Mock.Of<ILocalizationService>(),
|
2022-12-02 08:03:23 +00:00
|
|
|
Mock.Of<IOptionsMonitor<ModelsBuilderSettings>>(x => x.CurrentValue == new ModelsBuilderSettings { ModelsMode = modelsMode }),
|
2022-06-21 08:09:38 +02:00
|
|
|
Mock.Of<IOptionsMonitor<HostingSettings>>(x => x.CurrentValue == new HostingSettings { Debug = isDebug }),
|
|
|
|
|
hostEnvironment.Object,
|
2022-07-11 14:07:08 +02:00
|
|
|
Mock.Of<IUmbracoDatabaseFactory>(x => x.CreateDatabase() == Mock.Of<IUmbracoDatabase>(y => y.DatabaseType == DatabaseType.SQLite)),
|
2022-12-02 08:03:23 +00:00
|
|
|
Mock.Of<IServerRoleAccessor>(),
|
|
|
|
|
Mock.Of<IOptionsMonitor<RuntimeSettings>>(x => x.CurrentValue == new RuntimeSettings { Mode = runtimeMode }));
|
2022-04-19 15:06:10 +02:00
|
|
|
}
|
|
|
|
|
}
|