mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-01-14 01:25:40 -05:00
* Initial non-refactored SQL Agent alert classes (WIP) * Move agent classes into subdirectories * Refactor the agent config code a bit more * Add more implementation for handlers * Add more code to the create alert handler * Clean up agent alert class * Clean up alert methods a bit * Initial Operator contracts * Additonal SQL Agent config changes * More Proxy config cleanup * Cleanup AgentProxy class * Additional cleanups * Run SRGen * Add security service to create credential objects
97 lines
3.6 KiB
C#
97 lines
3.6 KiB
C#
//
|
|
// Copyright (c) Microsoft. All rights reserved.
|
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
//
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data.SqlClient;
|
|
using System.IO;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.SqlServer.Management.Smo;
|
|
using Microsoft.SqlServer.Management.XEvent;
|
|
using Microsoft.SqlTools.Hosting.Protocol;
|
|
using Microsoft.SqlTools.ServiceLayer.Agent;
|
|
using Microsoft.SqlTools.ServiceLayer.Agent.Contracts;
|
|
using Microsoft.SqlTools.ServiceLayer.Connection;
|
|
using Microsoft.SqlTools.ServiceLayer.IntegrationTests.Utility;
|
|
using Microsoft.SqlTools.ServiceLayer.Profiler;
|
|
using Microsoft.SqlTools.ServiceLayer.Profiler.Contracts;
|
|
using Microsoft.SqlTools.ServiceLayer.Test.Common;
|
|
using Moq;
|
|
using Xunit;
|
|
|
|
namespace Microsoft.SqlTools.ServiceLayer.IntegrationTests.Agent
|
|
{
|
|
public class AgentServiceTests
|
|
{
|
|
/// <summary>
|
|
/// Verify that a start profiling request starts a profiling session
|
|
/// </summary>
|
|
[Fact]
|
|
public async Task TestHandleAgentJobsRequest()
|
|
{
|
|
using (SelfCleaningTempFile queryTempFile = new SelfCleaningTempFile())
|
|
{
|
|
var connectionResult = await LiveConnectionHelper.InitLiveConnectionInfoAsync("master", queryTempFile.FilePath);
|
|
|
|
var requestParams = new AgentJobsParams()
|
|
{
|
|
OwnerUri = connectionResult.ConnectionInfo.OwnerUri
|
|
};
|
|
|
|
var requestContext = new Mock<RequestContext<AgentJobsResult>>();
|
|
|
|
AgentService service = new AgentService();
|
|
await service.HandleAgentJobsRequest(requestParams, requestContext.Object);
|
|
requestContext.VerifyAll();
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Verify that a job history request returns the job history
|
|
/// </summary>
|
|
[Fact]
|
|
public async Task TestHandleJobHistoryRequests()
|
|
{
|
|
using (SelfCleaningTempFile queryTempFile = new SelfCleaningTempFile())
|
|
{
|
|
var connectionResult = await LiveConnectionHelper.InitLiveConnectionInfoAsync("master", queryTempFile.FilePath);
|
|
|
|
var requestParams = new AgentJobHistoryParams()
|
|
{
|
|
OwnerUri = connectionResult.ConnectionInfo.OwnerUri,
|
|
JobId = "e9420919-b8c2-4a3d-a26c-b7ffde5342cf"
|
|
};
|
|
|
|
var requestContext = new Mock<RequestContext<AgentJobHistoryResult>>();
|
|
|
|
AgentService service = new AgentService();
|
|
await service.HandleJobHistoryRequest(requestParams, requestContext.Object);
|
|
requestContext.VerifyAll();
|
|
}
|
|
}
|
|
|
|
[Fact]
|
|
public async Task TestHandleAgentJobActionRequest()
|
|
{
|
|
using (SelfCleaningTempFile queryTempFile = new SelfCleaningTempFile())
|
|
{
|
|
var connectionResult = await LiveConnectionHelper.InitLiveConnectionInfoAsync("master", queryTempFile.FilePath);
|
|
|
|
var requestParams = new AgentJobActionParams()
|
|
{
|
|
OwnerUri = connectionResult.ConnectionInfo.OwnerUri,
|
|
JobName = "Agent history clean up: distribution"
|
|
};
|
|
|
|
var requestContext = new Mock<RequestContext<AgentJobActionResult>>();
|
|
|
|
AgentService service = new AgentService();
|
|
await service.HandleJobActionRequest(requestParams, requestContext.Object);
|
|
requestContext.VerifyAll();
|
|
}
|
|
}
|
|
}
|
|
} |