Functions to enable advanced PSObject analysis and comparison.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
Install the latest stable release
Install-Module -Name PSObjectTools -Repository PSGalleryImport the installed module
Import-Module PSObjectToolsImport the module during local development. This will build and import the latest local changes.
.\build.ps1 -Task ImportThere are some issues that arise during development due any required assemblies. Assemblies are loaded into your PowerShell session and cannot be removed. If you experience any issues while making changes and re-importing the module, please close all of your active PowerShell sessions.
Tests are located in the PSObjectTools\tests directory.
The following command will build and test the module.
.\build.ps1Static code analysis using PSCodeHealth for code quality and maintainability analysis. PSCodeHealth covers the following metrics:
- Code length
- Code complexity
- Code smells, styling issues and violations of best practices
- Comment-based help
.\build.ps1 -Task CodeHealthThe module is built with InvokeBuild.
When making changes, the project should be built and tested on your machine prior to pushing any changes to your branch.
For development changes, build and import with the following command:
.\build -Task ImportBefore committing code, build with the following command:
# This command will take a long time to run, it is not recommended until code is ready to be committed!
.\build.ps1The build steps are documented in the following graph.
All new development changes should be merged into the develop branch for release as a -prerelease version. For emergency patches, the code should be merged to both the develop and release branches.
Once a -prerelease version is determined to be stable and ready for production, the code should be merged from the develop branch into the release branch.
Alternatively, code can just be merged directly into the main branch, bypassing the -prerelease process.
This project uses semantic versioning.
- MAJOR version when you make incompatible API changes,
- MINOR version when you add functionality in a backwards compatible manner, and
- PATCH version when you make backwards compatible bug fixes.
Additional labels for pre-release and build metadata are available as extensions to the MAJOR.MINOR.PATCH format.
All versioning is handled in the build script.
- Richardson, Tyler
Inspired by Phil Factor's work, as seen here: https://www.red-gate.com/simple-talk/blogs/display-object-a-powershell-utility-cmdlet/