Skip to content
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

Add support for capturing MSBuild properties, items and target results #4329

Merged
merged 4 commits into from
Jan 13, 2025

Conversation

paulomorgado
Copy link
Contributor

Add support for capturing MSBuild properties, items and target results using Evaluate items and properties and display results of targets.

  • Added StandardOutputAction properties to DotNetCoreMSBuildBuilderFixture and MSBuildRunnerFixture.
  • Updated RunTool methods to pass StandardOutputAction to Build and Run methods.
  • Added new test cases in DotNetMSBuildBuilderTests and MSBuildRunnerTests to verify functionality.
  • Added overloads in DotNetAliases and MSBuildAliases to accept standardOutputAction parameter.
  • Updated DotNetMSBuildBuilder and MSBuildRunner to handle standardOutputAction and configure process settings.
  • Enhanced MSBuildArgumentBuilderExtensions to append MSBuild arguments for properties, items, and target results.
  • Extended DotNetMSBuildSettings and MSBuildSettings with new properties and collections.
  • Added extension methods in DotNetMSBuildSettingsExtensions for fluent configuration.

@paulomorgado paulomorgado force-pushed the MSBuild-GetProperty-GetItem branch from b95922c to 0333fcc Compare August 30, 2024 19:20
@paulomorgado paulomorgado force-pushed the MSBuild-GetProperty-GetItem branch 2 times, most recently from 6a074da to 76a1b2b Compare September 26, 2024 19:12
@paulomorgado
Copy link
Contributor Author

@devlead, is there anything needed here?

@devlead
Copy link
Member

devlead commented Oct 30, 2024

@devlead, is there anything needed here?

Don't know, a the moment just the maintainers' time to get bearings on what's trying to be achieved and review and understand the multiple changes introduced. Meanwhile, answers to most questions about what's expected from PRs and what to expect can be found in our Contribution Guidelines.

Introduce the ability to capture and process the standard output of MSBuild commands in the Cake build automation system.

- Added `StandardOutputAction` properties to `DotNetCoreMSBuildBuilderFixture` and `MSBuildRunnerFixture`.
- Updated `RunTool` methods to pass `StandardOutputAction` to `Build` and `Run` methods.
- Added new test cases in `DotNetMSBuildBuilderTests` and `MSBuildRunnerTests` to verify functionality.
- Added overloads in `DotNetAliases` and `MSBuildAliases` to accept `standardOutputAction` parameter.
- Updated `DotNetMSBuildBuilder` and `MSBuildRunner` to handle `standardOutputAction` and configure process settings.
- Enhanced `MSBuildArgumentBuilderExtensions` to append MSBuild arguments for properties, items, and target results.
- Extended `DotNetMSBuildSettings` and `MSBuildSettings` with new properties and collections.
- Added extension methods in `DotNetMSBuildSettingsExtensions` for fluent configuration.
@devlead devlead force-pushed the MSBuild-GetProperty-GetItem branch from fa9d0c6 to 6a26f31 Compare January 6, 2025 15:11
Copy link
Member

@devlead devlead left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There’s a lot going on in this pull request, could you add integration tests below for the new bits introduced in this PR
https://github.com/cake-build/cake/blob/develop/tests/integration/Cake.Common/Tools/DotNet/DotNetAliases.cake

@paulomorgado paulomorgado force-pushed the MSBuild-GetProperty-GetItem branch from 657bd71 to 73877eb Compare January 6, 2025 18:45
@paulomorgado paulomorgado force-pushed the MSBuild-GetProperty-GetItem branch from 73877eb to b085967 Compare January 6, 2025 18:57
@paulomorgado
Copy link
Contributor Author

There’s a lot going on in this pull request, could you add integration tests below for the new bits introduced in this PR https://github.com/cake-build/cake/blob/develop/tests/integration/Cake.Common/Tools/DotNet/DotNetAliases.cake

Done, @devlead!

Please, check if it's enough. I don't want the tests to become too brittle.

Copy link
Member

@devlead devlead left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Found a typo in the integration tests, also as it's json in a given format wondering if helpers / overload for that should be provided for this to be more useful🤔

Co-authored-by: Mattias Karlsson <mattias@devlead.se>
@paulomorgado
Copy link
Contributor Author

Found a typo in the integration tests, also as it's json in a given format wondering if helpers / overload for that should be provided for this to be more useful🤔

The output can be a string if requesting the value of only one property or JSON for any other cases.

The interpretation of the output is very tied to what the user wants to retrieve and this change does not limit the collection of the output to querying properties, items or results.

I would defer creating any helpers for when the community asks and makes a good case for them.

@devlead devlead enabled auto-merge January 13, 2025 06:49
Copy link
Member

@devlead devlead left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@devlead devlead linked an issue Jan 13, 2025 that may be closed by this pull request
@devlead devlead disabled auto-merge January 13, 2025 06:52
@devlead devlead merged commit c664bbb into cake-build:develop Jan 13, 2025
15 checks passed
@devlead
Copy link
Member

devlead commented Jan 13, 2025

@paulomorgado your changes have been merged, thanks for your contribution 👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add support for capturing MSBuild properties, items and target results
2 participants