using Microsoft.AspNetCore.Mvc.Testing;
using Microsoft.Extensions.DependencyInjection;
using OI.Metrology.Shared.DataModels;
using OI.Metrology.Shared.Models.Stateless;
using Serilog;

namespace OI.Metrology.Tests;

[TestClass]
public class UnitTestInfinityQSV2Controller
{

#pragma warning disable CS8618

    private static ILogger _Logger;
    private static string _ControllerName;
    private static TestContext _TestContext;
    private static WebApplicationFactory<Server.Program> _WebApplicationFactory;

#pragma warning restore

    [ClassInitialize]
    public static void ClassInitAsync(TestContext testContext)
    {
        _TestContext = testContext;
        _Logger = Log.ForContext<UnitTestInfinityQSV2Controller>();
        _WebApplicationFactory = new WebApplicationFactory<Server.Program>();
        _ControllerName = nameof(Server.ApiControllers.InfinityQSV2Controller)[..^10];
    }

    private static void NonThrowTryCatch()
    {
        try
        { throw new Exception(); }
        catch (Exception) { }
    }

    [TestMethod]
    public void TestControllerName()
    {
        _Logger.Information("Starting Web Application");
        Assert.AreEqual(IInfinityQSV2Controller<string>.GetRouteName(), _ControllerName);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

    [TestMethod]
    public void GetCommandText()
    {
        _Logger.Information("Starting Web Application");
        IServiceProvider serviceProvider = _WebApplicationFactory.Services.CreateScope().ServiceProvider;
        IInfinityQSV2Repository infinityQSV2Repository = serviceProvider.GetRequiredService<IInfinityQSV2Repository>();
        string result = infinityQSV2Repository.GetCommandText("1677273357", "61", "CDE5", "5012", "575908", "");
        Assert.IsNotNull(result);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public async Task GetCommandTextApi()
    {
        HttpClient httpClient = _WebApplicationFactory.CreateClient();
        _Logger.Information("Starting Web Application");
        string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357/commandText/?process=61&job=CDE5&part=5012&lot=575908&date_time=2023-02-24 15:15:00");
        File.WriteAllText(Path.Combine(AppContext.BaseDirectory, $"{_ControllerName}-{nameof(GetCommandText)}.sql"), json);
        Assert.IsNotNull(json);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public void GetData()
    {
        _Logger.Information("Starting Web Application");
        IServiceProvider serviceProvider = _WebApplicationFactory.Services.CreateScope().ServiceProvider;
        IInfinityQSV2Repository infinityQSV2Repository = serviceProvider.GetRequiredService<IInfinityQSV2Repository>();
        Result<InfinityQSBaseV2[]> result = infinityQSV2Repository.GetData("1677273357");
        Assert.IsNotNull(result?.Results);
        Assert.IsTrue(result?.Results.Any());
        Assert.IsNotNull(result?.Results[0].Process);
        Assert.IsNotNull(result?.Results[0].Variable);
        Assert.IsNotNull(result?.Results[0].SiteNumber);
        Assert.IsNotNull(result?.Results[0].VariableNumber);
        Assert.IsNotNull(result?.Results[0].SubGroupDateTime);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public async Task GetDataApi()
    {
        HttpClient httpClient = _WebApplicationFactory.CreateClient();
        _Logger.Information("Starting Web Application");
        //string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357 575908_2023-02-24 14-18-05.txt/data");
        string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357/data");
        File.WriteAllText(Path.Combine(AppContext.BaseDirectory, $"{_ControllerName}-{nameof(GetData)}.json"), json);
        Result<InfinityQSBaseV2[]>? result = System.Text.Json.JsonSerializer.Deserialize<Result<InfinityQSBaseV2[]>>(json);
        Assert.IsNotNull(result?.Results);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public void GetDescriptors()
    {
        _Logger.Information("Starting Web Application");
        IServiceProvider serviceProvider = _WebApplicationFactory.Services.CreateScope().ServiceProvider;
        IInfinityQSV2Repository infinityQSV2Repository = serviceProvider.GetRequiredService<IInfinityQSV2Repository>();
        Result<InfinityQSDescriptorV2[]> result = infinityQSV2Repository.GetDescriptors("1677273357");
        Assert.IsNotNull(result?.Results);
        Assert.IsTrue(result?.Results.Any());
        Assert.IsNotNull(result?.Results[0].SubGroupId);
        Assert.IsNotNull(result?.Results[0].SiteNumber);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public async Task GetDescriptorsApi()
    {
        HttpClient httpClient = _WebApplicationFactory.CreateClient();
        _Logger.Information("Starting Web Application");
        //string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357 575908_2023-02-24 14-18-05.txt/descriptors");
        string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357/descriptors");
        File.WriteAllText(Path.Combine(AppContext.BaseDirectory, $"{_ControllerName}-{nameof(GetDescriptors)}.json"), json);
        Result<InfinityQSDescriptorV2[]>? result = System.Text.Json.JsonSerializer.Deserialize<Result<InfinityQSDescriptorV2[]>>(json);
        Assert.IsNotNull(result?.Results);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public void GetEvents()
    {
        _Logger.Information("Starting Web Application");
        IServiceProvider serviceProvider = _WebApplicationFactory.Services.CreateScope().ServiceProvider;
        IInfinityQSV2Repository infinityQSV2Repository = serviceProvider.GetRequiredService<IInfinityQSV2Repository>();
        Result<InfinityQSEventV2[]> result = infinityQSV2Repository.GetEvents("1677273357");
        Assert.IsNotNull(result?.Results);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public async Task GetEventsApi()
    {
        HttpClient httpClient = _WebApplicationFactory.CreateClient();
        _Logger.Information("Starting Web Application");
        string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357/events");
        File.WriteAllText(Path.Combine(AppContext.BaseDirectory, $"{_ControllerName}-{nameof(GetEvents)}.json"), json);
        Result<InfinityQSEvent[]>? result = System.Text.Json.JsonSerializer.Deserialize<Result<InfinityQSEvent[]>>(json);
        Assert.IsNotNull(result?.Results);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public void GetHeader()
    {
        _Logger.Information("Starting Web Application");
        IServiceProvider serviceProvider = _WebApplicationFactory.Services.CreateScope().ServiceProvider;
        IInfinityQSV2Repository infinityQSV2Repository = serviceProvider.GetRequiredService<IInfinityQSV2Repository>();
        Result<InfinityQSBaseV2[]> result = infinityQSV2Repository.GetHeader("1677273357");
        Assert.IsNotNull(result?.Results);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

#if DEBUG
    [Ignore]
#endif
    [TestMethod]
    public async Task GetHeaderApi()
    {
        HttpClient httpClient = _WebApplicationFactory.CreateClient();
        _Logger.Information("Starting Web Application");
        string? json = await httpClient.GetStringAsync($"api/{_ControllerName}/1677273357/header");
        File.WriteAllText(Path.Combine(AppContext.BaseDirectory, $"{_ControllerName}-{nameof(GetHeader)}.json"), json);
        Result<InfinityQSBaseV2[]>? result = System.Text.Json.JsonSerializer.Deserialize<Result<InfinityQSBaseV2[]>>(json);
        Assert.IsNotNull(result?.Results);
        _Logger.Information($"{_TestContext?.TestName} completed");
        NonThrowTryCatch();
    }

}