Book Image

Learn PowerShell Core 6.0

By : David das Neves, Jan-Hendrik Peters
Book Image

Learn PowerShell Core 6.0

By: David das Neves, Jan-Hendrik Peters

Overview of this book

Beginning with an overview of the different versions of PowerShell, Learn PowerShell Core 6.0 introduces you to VSCode and then dives into helping you understand the basic techniques in PowerShell scripting. You will cover advanced coding techniques, learn how to write reusable code as well as store and load data with PowerShell. This book will help you understand PowerShell security and Just Enough Administration, enabling you to create your own PowerShell repository. The last set of chapters will guide you in setting up, configuring, and working with Release Pipelines in VSCode and VSTS, and help you understand PowerShell DSC. In addition to this, you will learn how to use PowerShell with Windows, Azure, Microsoft Online Services, SCCM, and SQL Server. The final chapter will provide you with some use cases and pro tips. By the end of this book, you will be able to create professional reusable code using security insight and knowledge of working with PowerShell Core 6.0 and its most important capabilities.
Table of Contents (26 chapters)
Title Page
Dedication
Packt Upsell
Contributors
Preface
Index

PSScriptAnalyzer


While developing scripts in VSCode, you might see squiggly lines (indicating issues with your code) and a tab called PROBLEMS at the bottom of the window. These notifications are courtesy of PSScriptAnalyzer, a very versatile PowerShell module that helps to analyze your scripts for issues and errors:

Outside of VSCode, or during a build process, you can use PSScriptAnalyzer by using the exported cmdlets of that module. You can specify which built-in rules and rule sets to apply, as well as exclude certain rules on demand:

# On PS Gallery
Install-Module PSScriptAnalyzer -Force

Get-Command -Module PSScriptAnalyzer

# this triggers the analyzer
# Aliases should not be used
Get-Process | Where Name -eq explorer

# this also triggers a rule
# Variables that are not consumed should be removed
$var = "test"

Invoke-ScriptAnalyzer -Path .\Ch5\06_PSScriptAnalyzer.ps1

# you can exclude specific rules
# The argument completer should give you a list of all rules
Invoke-ScriptAnalyzer...