-
Notifications
You must be signed in to change notification settings - Fork 61
Use Azure DevOps logger formatting commands #1702
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Draft
lbussell
wants to merge
10
commits into
dotnet:main
Choose a base branch
from
lbussell:azdo-logging
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Changes from all commits
Commits
Show all changes
10 commits
Select commit
Hold shift + click to select a range
461b95b
Add disposable logging group class
lbussell 06e80e8
Add Azure pipelines logging commands
lbussell ac75f69
Update nullability for Logger
lbussell 98c192d
Sync LoggerService with Logger
lbussell f17b468
Log executing commands with command logging command
lbussell c81d900
Use logging scope for command output
lbussell 479316f
Remove unnecessary diff
lbussell 887a0cd
Use file scoped namespaces
lbussell 52db00e
Add LoggingGroup dependency on ILoggerService and document LoggerServ…
lbussell b2e436e
Add note about nested logging groups
lbussell File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or 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 hidden or 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 hidden or 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 hidden or 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 hidden or 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 |
---|---|---|
@@ -0,0 +1,44 @@ | ||
// Licensed to the .NET Foundation under one or more agreements. | ||
// The .NET Foundation licenses this file to you under the MIT license. | ||
// See the LICENSE file in the project root for more information. | ||
|
||
#nullable enable | ||
|
||
using System; | ||
|
||
namespace Microsoft.DotNet.ImageBuilder; | ||
|
||
/// <summary> | ||
/// Manages an Azure Pipelines collapsible logging group. | ||
/// Disposing of the object closes the logging group. | ||
/// See https://learn.microsoft.com/azure/devops/pipelines/scripts/logging-commands | ||
/// </summary> | ||
/// <remarks> | ||
/// Only one LoggingGroup can be open at a time. If a second group is created | ||
/// without closing the first, then the first group will not be collapsible. | ||
/// </remarks> | ||
internal sealed class LoggingGroup : IDisposable | ||
{ | ||
private readonly ILoggerService _logger; | ||
|
||
/// <summary> | ||
/// Creates a new collapsible logging group. When this object is created, | ||
/// all subsequent logging output will be inside this group until this | ||
/// object is disposed. | ||
/// </summary> | ||
/// <param name="groupName">The name of the logging group</param> | ||
/// <param name="loggerService">The logger service to use for output</param> | ||
public LoggingGroup(string name, ILoggerService loggerService) | ||
{ | ||
_logger = loggerService; | ||
_logger.WriteMessage($"##[group]{name}"); | ||
} | ||
|
||
/// <summary> | ||
/// Ends the current collapsible logging group. | ||
/// </summary> | ||
public void Dispose() | ||
{ | ||
_logger.WriteMessage($"##[endgroup]"); | ||
} | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This may be tough to notice while writing code. Can we enforce this from the logging service?