From 1a65e6c50ef9461c0d4e8466c2ed3b110f439e57 Mon Sep 17 00:00:00 2001 From: Joel Timothy Oh Date: Mon, 13 May 2024 05:35:07 +0000 Subject: [PATCH] Docs (usage): Improve and add documentation on usage of the project --- README.md | 50 +++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 43 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index 7d9714a..c9457fa 100644 --- a/README.md +++ b/README.md @@ -89,13 +89,26 @@ By default, `PSModulePublisher` uses the main project's root directory as the pa ### Development -The project provides a all-in-one cmdlet [`Invoke-PSModulePublisher`](src/PSModulePublisher/Public/Invoke-PSModulePublisher.ps1) which can be used for executing the same build, test, and publish steps that will run in CI environments. +The project includes the cmdlet [`Invoke-PSModulePublisher`](src/PSModulePublisher/Public/Invoke-PSModulePublisher.ps1) which can be used for executing the project's build, test, and publish steps for PowerShell modules: -### Continuous Integration +```powershell +# Build and Test steps (Generates module manifest, tests module via module manifest) +Invoke-PSModulePublisher -#### Steps +# Publish steps (Publishes module as a dry run) +Invoke-PSModulePublisher -Repository MyPSRepository -DryRun -The CI process is composed of the following steps: +# Publish steps (Publishes module) +Invoke-PSModulePublisher -Repository MyPSRepository +``` + +### Continuous Integration (CI) + +The project includes provided CI templates and cmdlets for executing the project's build, test, and publish steps for PowerShell modules. + +#### via Templates + +The CI process with the included [CI templates](docs/samples/ci) is composed of the following steps: ##### Build @@ -115,8 +128,6 @@ The CI process is composed of the following steps: **Build** and **Test** steps can be executed for every commit pushed. Simply [configure](docs/samples/ci/azure-pipelines/azure-pipelines.linux.sample.yml#L8-L11) your main project's CI file(s) and/or settings to allow so. -#### Publishing the module - **Publish** steps will run only for [*tag* refs](templates/azure-pipelines/steps/pwsh/run-publish.yml#L10). Ensure your main project's CI file(s) and/or settings are [configured](docs/samples/ci/azure-pipelines/azure-pipelines.linux.sample.yml#L5-L7) to run CI jobs for *tag* refs. Tags must follow [Semantic Versioning](https://semver.org/) and be prepended with a lowercase `v`: @@ -129,7 +140,7 @@ git tag v1.0.12 git push remotename v1.0.12 ``` -#### Use cases +##### Use cases For a basic use case, the CI process could simply comprise a single stage containing all the steps from **Build**, **Test**, and **Publish**. @@ -137,6 +148,31 @@ In cases where the module needs to be tested across multiple operating systems a Refer to the [sample CI files](docs/samples/ci) for some working examples. +#### via Cmdlets + +##### Parameters + +```powershell +Invoke-Build [] +Invoke-Test [-ModuleManifestPath] [] +Invoke-Publish [-ModuleManifestPath] [-Repository] [-DryRun] [] +``` + +##### Commands + +Simply execute the individual cmdlets within your CI environment to perform their respective functions: + +```powershell +# Build (Generates module manifest) +$moduleManifestPath = Invoke-Build + +# Test (Tests module via module manifest) +Invoke-Test -ModuleManifestPath $moduleManifestPath + +# Publish (Publishes module) +Invoke-Publish -ModuleManifestPath $moduleManifestPath -Repository PSGallery +``` + ### Managing the submodule #### Retrieving updates