From 44a69dbe6f5ad894e2d5c16db37a29c409df2111 Mon Sep 17 00:00:00 2001 From: deadlydog Date: Thu, 26 Dec 2024 22:43:30 -0600 Subject: [PATCH] tip: Add tip for the VSTeam module for Azure DevOps --- ...utomate-azure-devops-tasks-with-vsteam.ps1 | 38 +++++++++++++++++++ src/tiPS/PowerShellTips.json | 26 +++++++++++++ 2 files changed, 64 insertions(+) create mode 100644 src/PowerShellTips/2024-12-26-automate-azure-devops-tasks-with-vsteam.ps1 diff --git a/src/PowerShellTips/2024-12-26-automate-azure-devops-tasks-with-vsteam.ps1 b/src/PowerShellTips/2024-12-26-automate-azure-devops-tasks-with-vsteam.ps1 new file mode 100644 index 0000000..70767ca --- /dev/null +++ b/src/PowerShellTips/2024-12-26-automate-azure-devops-tasks-with-vsteam.ps1 @@ -0,0 +1,38 @@ +$tip = [tiPS.PowerShellTip]::new() +$tip.CreatedDate = [DateTime]::Parse('2024-12-26') +$tip.Title = 'Automate Azure DevOps tasks with VSTeam' +$tip.TipText = @' +Many organizations use Azure DevOps as their application lifecycle management (ALM) tool. VSTeam is a PowerShell module that provides cmdlets for many Azure DevOps tasks, which can be easier than calling the Azure DevOps APIs directly. It's a great way to simplify and automate many Azure DevOps tasks, such as retrieving and updating work items, teams, git repos, pull requests, release definitions, and more. +'@ +$tip.Example = @' +# List all commits in the demo project for a specific repository. +Get-VSTeamGitCommit -ProjectName demo -RepositoryId 118C262F-0D4C-4B76-BD9B-7DD8CA12F196 + +# List of all agent pools. +Get-VSTeamPool + +# Gets work items with IDs 47 and 48. +Get-VSTeamWorkItem -Id 47,48 + +# Updates the title of work item 1. +Update-VSTeamWorkItem -WorkItemId 1 -Title "Updated Work Item Title" +'@ +$tip.Urls = @( + 'https://methodsandpractices.github.io/vsteam-docs/' + 'https://methodsandpractices.github.io/vsteam-docs/docs/modules/vsteam/commands/' + 'https://github.com/MethodsAndPractices/vsteam-docs' +) +$tip.Category = [tiPS.TipCategory]::Module # Community, Editor, Module, NativeCmdlet, Performance, Security, Syntax, Terminal, or Other. +$tip.Author = 'Daniel Schroeder (deadlydog)' # Optional. Get credit for your tip. e.g. 'Daniel Schroeder (deadlydog)'. +#$tip.ExpiryDate = [DateTime]::Parse('2024-10-30') # Optional. If the tip is not relevant after a certain date, set the expiration date. e.g. Announcing a conference or event. + +# Category meanings: +# Community: Social events and community resources. e.g. PowerShell Summit, podcasts, etc. +# Editor: Editor tips and extensions. e.g. VSCode, ISE, etc. +# Module: Modules and module tips. e.g. PSScriptAnalyzer, Pester, etc. +# NativeCmdlet: Native cmdlet tips. e.g. Get-Process, Get-ChildItem, Get-Content, etc. +# Performance: Tips to improve runtime performance. e.g. foreach vs ForEach-Object, ForEach-Object -Parallel, etc. +# Security: Security tips. e.g. ExecutionPolicy, Constrained Language Mode, passwords, etc. +# Syntax: Syntax tips. e.g. splatting, pipeline, etc. +# Terminal: Terminal shortcuts and tips. e.g. PSReadLine, Windows Terminal, ConEmu, etc. +# Other: Tips that don't fit into any of the other categories. diff --git a/src/tiPS/PowerShellTips.json b/src/tiPS/PowerShellTips.json index fed4b1f..d154de4 100644 --- a/src/tiPS/PowerShellTips.json +++ b/src/tiPS/PowerShellTips.json @@ -828,5 +828,31 @@ "Category": 6, "ExpiryDate": "9999-12-31T23:59:59.9999999", "Author": "Daniel Schroeder (deadlydog)" + }, + { + "CreatedDate": "2024-12-26T00:00:00", + "Title": "Attend the PowerShell + DevOps Global Summit", + "TipText": "The PowerShell + DevOps Global Summit happens every year somewhere in the United States, usually in April. The conference is a great place to learn about PowerShell and DevOps, and to meet and network with other people in the PowerShell community, including Microsoft MVPs and the Microsoft PowerShell team. Discuss the latest trends, best practices, and tips and tricks with other PowerShell enthusiasts!\r\n\r\nWant to speak at the conference? The call for speakers is typically open during October and November, where you can submit your session ideas for consideration. Speakers often receive a free ticket to the conference and sometimes additional reimbursement. It's a great opportunity to share your knowledge with the community.\r\n\r\nCheck the website for the latest information on the conference dates, location, sessions, and registration details.", + "Example": "Start-Process https://www.powershellsummit.org", + "Urls": [ + "https://www.powershellsummit.org" + ], + "Category": 0, + "ExpiryDate": "9999-12-31T23:59:59.9999999", + "Author": "Daniel Schroeder (deadlydog)" + }, + { + "CreatedDate": "2024-12-26T00:00:00", + "Title": "Automate Azure DevOps tasks with VSTeam", + "TipText": "Many organizations use Azure DevOps as their application lifecycle management (ALM) tool. VSTeam is a PowerShell module that provides cmdlets for many Azure DevOps tasks, which can be easier than calling the Azure DevOps APIs directly. It's a great way to simplify and automate many Azure DevOps tasks, such as retrieving and updating work items, teams, git repos, pull requests, release definitions, and more.", + "Example": "# List all commits in the demo project for a specific repository.\r\nGet-VSTeamGitCommit -ProjectName demo -RepositoryId 118C262F-0D4C-4B76-BD9B-7DD8CA12F196\r\n\r\n# List of all agent pools.\r\nGet-VSTeamPool\r\n\r\n# Gets work items with IDs 47 and 48.\r\nGet-VSTeamWorkItem -Id 47,48\r\n\r\n# Updates the title of work item 1.\r\nUpdate-VSTeamWorkItem -WorkItemId 1 -Title \"Updated Work Item Title\"", + "Urls": [ + "https://methodsandpractices.github.io/vsteam-docs/", + "https://methodsandpractices.github.io/vsteam-docs/docs/modules/vsteam/commands/", + "https://github.com/MethodsAndPractices/vsteam-docs" + ], + "Category": 2, + "ExpiryDate": "9999-12-31T23:59:59.9999999", + "Author": "Daniel Schroeder (deadlydog)" } ]