2020-04-08 22:28:50 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Dapper;
|
2020-06-26 17:08:30 +00:00
|
|
|
|
using Wabbajack.Lib;
|
2020-05-09 05:12:51 +00:00
|
|
|
|
using Wabbajack.Server.DataLayer;
|
2020-05-09 13:22:02 +00:00
|
|
|
|
using Wabbajack.Server.DTOs;
|
2020-04-08 22:28:50 +00:00
|
|
|
|
using Xunit;
|
|
|
|
|
using Xunit.Abstractions;
|
|
|
|
|
|
|
|
|
|
namespace Wabbajack.BuildServer.Test
|
|
|
|
|
{
|
|
|
|
|
public class MetricsTests : ABuildServerSystemTest
|
|
|
|
|
{
|
|
|
|
|
public MetricsTests(ITestOutputHelper output, SingletonAdaptor<BuildServerFixture> fixture) : base(output, fixture)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
2020-05-09 13:22:02 +00:00
|
|
|
|
public async Task CanSendAndGetMetrics()
|
2020-04-08 22:28:50 +00:00
|
|
|
|
{
|
|
|
|
|
var action = "action_" + Guid.NewGuid().ToString();
|
|
|
|
|
var subject = "subject_" + Guid.NewGuid().ToString();
|
|
|
|
|
await Metrics.Send(action, subject);
|
|
|
|
|
|
|
|
|
|
var sql = Fixture.GetService<SqlService>();
|
|
|
|
|
var conn = await sql.Open();
|
|
|
|
|
var result = await conn.QueryFirstOrDefaultAsync<string>("SELECT Subject FROM dbo.Metrics WHERE Action = @Action",
|
|
|
|
|
new {Action = action});
|
|
|
|
|
|
|
|
|
|
Assert.Equal(subject, result);
|
2020-05-09 13:22:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var report = await _client.GetJsonAsync<MetricResult[]>(MakeURL($"metrics/report/{action}"));
|
|
|
|
|
// we'll just make sure this doesn't error, with limited data that's about all we can do atm
|
|
|
|
|
|
2020-04-08 22:28:50 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|