-
Notifications
You must be signed in to change notification settings - Fork 867
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Mask URL with credentials on publish telemetry
- Loading branch information
1 parent
42229c7
commit c6b214f
Showing
3 changed files
with
59 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,8 +10,11 @@ | |
using System.Runtime.CompilerServices; | ||
using System.Threading.Tasks; | ||
using Xunit; | ||
using System.Text.Json; | ||
using System.Threading; | ||
using Pipelines = Microsoft.TeamFoundation.DistributedTask.Pipelines; | ||
using Microsoft.VisualStudio.Services.Agent.Worker.Telemetry; | ||
using Microsoft.VisualStudio.Services.WebPlatform; | ||
|
||
namespace Microsoft.VisualStudio.Services.Agent.Tests.Worker | ||
{ | ||
|
@@ -61,6 +64,8 @@ public override void InitializeJobExtension(IExecutionContext context, IList<Pip | |
private Mock<IPagingLogger> _logger; | ||
private Mock<IExpressionManager> _express; | ||
private Mock<IContainerOperationProvider> _containerProvider; | ||
private Mock<ICustomerIntelligenceServer> _mockCiService; | ||
private Mock<IAsyncCommandContext> _asyncCommandContext; | ||
private TestHostContext CreateTestContext(CancellationTokenSource _tokenSource, [CallerMemberName] String testName = "") | ||
{ | ||
var hc = new TestHostContext(this, testName); | ||
|
@@ -291,6 +296,9 @@ private TestHostContext CreateMSITestContext(CancellationTokenSource _tokenSourc | |
_express = new Mock<IExpressionManager>(); | ||
_containerProvider = new Mock<IContainerOperationProvider>(); | ||
_logPlugin = new Mock<IAgentLogPlugin>(); | ||
_mockCiService = new Mock<ICustomerIntelligenceServer>(); | ||
_asyncCommandContext = new Mock<IAsyncCommandContext>(); | ||
|
||
|
||
TaskRunner step1 = new TaskRunner(); | ||
TaskRunner step2 = new TaskRunner(); | ||
|
@@ -333,7 +341,7 @@ private TestHostContext CreateMSITestContext(CancellationTokenSource _tokenSourc | |
Url = new Uri("https://test.visualstudio.com"), | ||
Authorization = new EndpointAuthorization() | ||
{ | ||
Scheme = "ManagedServiceIdentity", | ||
Scheme = "OAuth", | ||
} | ||
}; | ||
environment.SystemConnection.Authorization.Parameters["AccessToken"] = "token"; | ||
|
@@ -462,6 +470,7 @@ private TestHostContext CreateMSITestContext(CancellationTokenSource _tokenSourc | |
hc.SetSingleton(_express.Object); | ||
hc.SetSingleton(_containerProvider.Object); | ||
hc.SetSingleton(_logPlugin.Object); | ||
hc.SetSingleton(_mockCiService.Object); | ||
hc.EnqueueInstance<IPagingLogger>(_logger.Object); // jobcontext logger | ||
hc.EnqueueInstance<IPagingLogger>(_logger.Object); // init step logger | ||
hc.EnqueueInstance<IPagingLogger>(_logger.Object); // step 1 | ||
|
@@ -762,5 +771,51 @@ public async Task JobExtensionManagementScriptStepMSI() | |
Environment.SetEnvironmentVariable("VSTS_AGENT_CLEANUP_INTERNAL_TEMP_HACK", ""); | ||
} | ||
} | ||
[Fact] | ||
[Trait("Level", "L0")] | ||
[Trait("Category", "Worker")] | ||
[Trait("SkipOn", "darwin")] | ||
[Trait("SkipOn", "linux")] | ||
public async Task JobExtensionTelemetryPublisherSecretValue() | ||
{ | ||
using CancellationTokenSource tokenSource = new CancellationTokenSource(); | ||
using TestHostContext hc = CreateMSITestContext(tokenSource); | ||
|
||
hc.EnqueueInstance<IAsyncCommandContext>(_asyncCommandContext.Object); | ||
hc.EnqueueInstance<IAsyncCommandContext>(_asyncCommandContext.Object); | ||
hc.EnqueueInstance<IAsyncCommandContext>(_asyncCommandContext.Object); | ||
|
||
hc.SetSingleton(new TaskRestrictionsChecker() as ITaskRestrictionsChecker); | ||
|
||
Environment.SetEnvironmentVariable("http_proxy", "http://admin:[email protected]"); | ||
|
||
var expectedEvent = new Dictionary<string, object>() | ||
{ | ||
{ "JobId", null }, | ||
{ "ProxyAddress-${http_proxy}", "http://admin:***@localhost.com"}, | ||
}; | ||
|
||
var actualEvents = new List<CustomerIntelligenceEvent[]>(); | ||
|
||
_mockCiService.Setup(s => s.PublishEventsAsync(It.IsAny<CustomerIntelligenceEvent[]>())) | ||
.Callback<CustomerIntelligenceEvent[]>(actualEvents.Add) | ||
.Returns(Task.CompletedTask); | ||
|
||
|
||
TestJobExtension testExtension = new TestJobExtension(); | ||
testExtension.Initialize(hc); | ||
await testExtension.InitializeJob(_jobEc, _message); | ||
|
||
var result = actualEvents.Where(w => w[0].Properties.ContainsKey("ProxyAddress-${http_proxy}")); | ||
|
||
Assert.True(result?.Count() == 1); | ||
|
||
Assert.True( | ||
!expectedEvent.Except(result.First()[0].Properties).Any(), | ||
$"Event does not match. " + | ||
$"Expected:{JsonSerializer.Serialize(expectedEvent)};" + | ||
$"Actual:{JsonSerializer.Serialize(result.First()[0].Properties)}" | ||
); | ||
} | ||
} | ||
} | ||
} |