From cf148fd7397f85fc502447c0599161af25b007e7 Mon Sep 17 00:00:00 2001 From: Keith Hill Date: Sat, 18 Feb 2017 12:29:15 -0700 Subject: [PATCH 1/7] Remove PowerShell v2 support. Also doing some miscellaneous cleanup (remove Invoke-NullCoalescing, remove testDebugHarness.ps1 in favor of using the Pester Tests debug configuration, rename CheckVersion.ps1 to CheckRequirements.ps1). --- .vscode/launch.json | 6 +-- CHANGELOG.md | 9 ++++ README.md | 4 +- appveyor.yml | 2 +- chocolatey/poshgit.nuspec | 2 +- ...CheckVersion.ps1 => CheckRequirements.ps1} | 6 ++- src/posh-git.psd1 | 27 ++++++------ src/posh-git.psm1 | 41 +++++++------------ test/Utils.Tests.ps1 | 5 ++- test/testDebugHarness.ps1 | 2 - 10 files changed, 51 insertions(+), 53 deletions(-) rename src/{CheckVersion.ps1 => CheckRequirements.ps1} (86%) delete mode 100644 test/testDebugHarness.ps1 diff --git a/.vscode/launch.json b/.vscode/launch.json index e9d4d633f..608c8f608 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -4,10 +4,10 @@ { "type": "PowerShell", "request": "launch", - "name": "PowerShell Launch Pester Tests", - "script": "${workspaceRoot}/test/testDebugHarness.ps1", + "name": "PowerShell Pester Tests", + "script": "Invoke-Pester", "args": [], - "cwd": "${file}" + "cwd": "${workspaceRoot}/test" }, { "type": "PowerShell", diff --git a/CHANGELOG.md b/CHANGELOG.md index 6d7f65242..27821e601 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,14 @@ # posh-git Release History +## 1.0.0 - TBD +This release introduces breaking changes with 0.x to both drop support for PowerShell 2.0 and support writing prompt strings using ANSI sequences. +The ANSI sequence support will help with cross-platform PowerShell support which is another goal of this release. + +- Drop support for PowerShell 2.0 +- Remove Invoke-NullCoalescing command + ([#93](https://github.com/dahlbyk/posh-git/issues/93)) + ([PR #426](https://github.com/dahlbyk/posh-git/pull/426)) + ## 0.7.0 - February 14, 2017 This release has focused on improving the "getting started" experience by adding an `Add-PoshGitToProfile` command that modifies the user's PowerShell profile script to import the posh-git module whenever PowerShell starts. diff --git a/README.md b/README.md index 029bbebe0..d98031cd6 100644 --- a/README.md +++ b/README.md @@ -23,7 +23,7 @@ Rather than turn off file status entirely (`$GitPromptSettings.EnableFileStatus ### Prerequisites Before installing posh-git make sure the following prerequisites have been met. -1. PowerShell 2.0 or higher. Check your PowerShell version by executing `$PSVersionTable.PSVersion`. +1. PowerShell 3.0 or higher. Check your PowerShell version by executing `$PSVersionTable.PSVersion`. 2. Script execution policy must be set to either `RemoteSigned` or `Unrestricted`. Check the script execution policy setting by executing `Get-ExecutionPolicy`. @@ -58,7 +58,7 @@ Update-Module posh-git ``` ### Installing posh-git via Chocolatey -If you have PowerShell version 2 or are having issues using Install-Module with PowerShell version 3 or 4, you can use [Chocolatey](https://chocolatey.org) to install posh-git. +If you are having issues using Install-Module with PowerShell version 3 or 4, you can use [Chocolatey](https://chocolatey.org) to install posh-git. If you don't have Chocolatey, you can install it from the [Chocolately Install page](https://chocolatey.org/install). With Chocolatey installed, execute the following command to install posh-git: ``` diff --git a/appveyor.yml b/appveyor.yml index a662e20e1..72cbe4641 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -3,7 +3,7 @@ os: branches: only: - - master + - develop init: - git config --global core.autocrlf true diff --git a/chocolatey/poshgit.nuspec b/chocolatey/poshgit.nuspec index e83c9064b..160b65452 100644 --- a/chocolatey/poshgit.nuspec +++ b/chocolatey/poshgit.nuspec @@ -3,7 +3,7 @@ poshgit posh-git - 0.7.0 + 1.0.0-pre00 Keith Dahlby, Mark Embling, Jeremy Skinner, Keith Hill Keith Dahlby ### posh-git diff --git a/src/CheckVersion.ps1 b/src/CheckRequirements.ps1 similarity index 86% rename from src/CheckVersion.ps1 rename to src/CheckRequirements.ps1 index 99e1506f2..eb6e3b3f1 100644 --- a/src/CheckVersion.ps1 +++ b/src/CheckRequirements.ps1 @@ -7,12 +7,14 @@ if (!(Get-Command git -TotalCount 1 -ErrorAction SilentlyContinue)) { } $requiredVersion = [Version]'1.7.2' -if ([String](git --version 2> $null) -match '(?\d+(?:\.\d+)+)') { +if ([string](git --version 2> $null) -match '(?\d+(?:\.\d+)+)') { $version = [Version]$Matches['ver'] } + if ($version -lt $requiredVersion) { Write-Warning "posh-git requires Git $requiredVersion or better. You have $version." $false -} else { +} +else { $true } diff --git a/src/posh-git.psd1 b/src/posh-git.psd1 index 52a97e74b..237a3718d 100644 --- a/src/posh-git.psd1 +++ b/src/posh-git.psd1 @@ -1,10 +1,10 @@ @{ # Script module or binary module file associated with this manifest. -ModuleToProcess = 'posh-git.psm1' +RootModule = 'posh-git.psm1' # Version number of this module. -ModuleVersion = '0.7.0' +ModuleVersion = '1.0.0' # ID used to uniquely identify this module GUID = '74c9fd30-734b-4c89-a8ae-7727ad21d1d5' @@ -19,27 +19,26 @@ Copyright = '(c) 2010-2017 Keith Dahlby and contributors' Description = 'Provides prompt with Git status summary information and tab completion for Git commands, parameters, remotes and branch names.' # Minimum version of the Windows PowerShell engine required by this module -PowerShellVersion = '2.0' +PowerShellVersion = '3.0' # Functions to export from this module FunctionsToExport = @( - 'Invoke-NullCoalescing', 'Add-PoshGitToProfile', - 'Write-GitStatus', - 'Write-Prompt', - 'Write-VcsStatus', + 'Enable-GitColors', + 'Get-AliasPattern', 'Get-GitBranch', 'Get-GitStatus', - 'Enable-GitColors', 'Get-GitDirectory', - 'TabExpansion', - 'Get-AliasPattern', + 'Update-AllBranches', + 'Write-GitStatus', + 'Write-Prompt', + 'Write-VcsStatus', 'Get-SshAgent', 'Start-SshAgent', 'Stop-SshAgent', 'Add-SshKey', 'Get-SshPath', - 'Update-AllBranches', + 'TabExpansion', 'tgit' ) @@ -50,7 +49,7 @@ CmdletsToExport = @() VariablesToExport = @() # Aliases to export from this module -AliasesToExport = @('??') +AliasesToExport = @() # Private data to pass to the module specified in RootModule/ModuleToProcess. This may also contain a PSData hashtable with additional module metadata used by PowerShell. PrivateData = @{ @@ -61,13 +60,13 @@ PrivateData = @{ Tags = @('git', 'prompt', 'tab', 'tab-completion', 'tab-expansion', 'tabexpansion') # A URL to the license for this module. - LicenseUri = 'https://github.com/dahlbyk/posh-git/blob/v0.7.0/LICENSE.txt' + LicenseUri = 'https://github.com/dahlbyk/posh-git/blob/develop/LICENSE.txt' # A URL to the main website for this project. ProjectUri = 'https://github.com/dahlbyk/posh-git' # ReleaseNotes of this module - ReleaseNotes = 'https://github.com/dahlbyk/posh-git/blob/v0.7.0/CHANGELOG.md' + ReleaseNotes = 'https://github.com/dahlbyk/posh-git/blob/develop/CHANGELOG.md' } # End of PSData hashtable diff --git a/src/posh-git.psm1 b/src/posh-git.psm1 index 3fd17fad5..a2f9c29f0 100644 --- a/src/posh-git.psm1 +++ b/src/posh-git.psm1 @@ -1,17 +1,6 @@ -param([switch]$NoVersionWarn,[switch]$ForcePoshGitPrompt) +param([switch]$NoVersionWarn, [switch]$ForcePoshGitPrompt) -if (Get-Module posh-git) { return } - -$psv = $PSVersionTable.PSVersion - -if ($psv.Major -lt 3 -and !$NoVersionWarn) { - Write-Warning ("posh-git support for PowerShell 2.0 is deprecated; you have version $($psv).`n" + - "To download version 5.0, please visit https://www.microsoft.com/en-us/download/details.aspx?id=50395`n" + - "For more information and to discuss this, please visit https://github.com/dahlbyk/posh-git/issues/163`n" + - "To suppress this warning, change your profile to include 'Import-Module posh-git -Args `$true'.") -} - -& $PSScriptRoot\CheckVersion.ps1 > $null +& $PSScriptRoot\CheckRequirements.ps1 > $null . $PSScriptRoot\Utils.ps1 . $PSScriptRoot\GitUtils.ps1 @@ -27,11 +16,12 @@ Get-TempEnv 'SSH_AGENT_PID' Get-TempEnv 'SSH_AUTH_SOCK' # Get the default prompt definition. -if (($psv.Major -eq 2) -or ![Runspace]::DefaultRunspace.InitialSessionState.Commands) { +$initialSessionState = [Runspace]::DefaultRunspace.InitialSessionState +if (!$initialSessionState.Commands -or !$initialSessionState.Commands['prompt']) { $defaultPromptDef = "`$(if (test-path variable:/PSDebugContext) { '[DBG]: ' } else { '' }) + 'PS ' + `$(Get-Location) + `$(if (`$nestedpromptlevel -ge 1) { '>>' }) + '> '" } else { - $defaultPromptDef = [Runspace]::DefaultRunspace.InitialSessionState.Commands['prompt'].Definition + $defaultPromptDef = $initialSessionState.Commands['prompt'].Definition } # If there is no prompt function or the prompt function is the default, replace the current prompt function definition @@ -44,8 +34,7 @@ if (!$currentPromptDef) { } if ($ForcePoshGitPrompt -or !$currentPromptDef -or ($currentPromptDef -eq $defaultPromptDef)) { - # Have to use [scriptblock]::Create() to get debugger detection to work in PS v2 - $poshGitPromptScriptBlock = [scriptblock]::Create(@' + $poshGitPromptScriptBlock = { if ($GitPromptSettings.DefaultPromptEnableTiming) { $sw = [System.Diagnostics.Stopwatch]::StartNew() } @@ -107,7 +96,7 @@ if ($ForcePoshGitPrompt -or !$currentPromptDef -or ($currentPromptDef -eq $defau $global:LASTEXITCODE = $origLastExitCode $expandedPromptSuffix -'@) + } # Set the posh-git prompt as the default prompt Set-Item Function:\prompt -Value $poshGitPromptScriptBlock @@ -128,25 +117,23 @@ $ExecutionContext.SessionState.Module.OnRemove = { } $exportModuleMemberParams = @{ - Alias = @('??') # TODO: Remove in 1.0.0 Function = @( - 'Invoke-NullCoalescing', 'Add-PoshGitToProfile', + 'Enable-GitColors', + 'Get-AliasPattern', + 'Get-GitBranch', + 'Get-GitDirectory', + 'Get-GitStatus', + 'Update-AllBranches', 'Write-GitStatus', 'Write-Prompt', 'Write-VcsStatus', - 'Get-GitBranch', - 'Get-GitStatus', - 'Enable-GitColors', - 'Get-GitDirectory', - 'TabExpansion', - 'Get-AliasPattern', 'Get-SshAgent', 'Start-SshAgent', 'Stop-SshAgent', 'Add-SshKey', 'Get-SshPath', - 'Update-AllBranches', + 'TabExpansion', 'tgit' ) } diff --git a/test/Utils.Tests.ps1 b/test/Utils.Tests.ps1 index d2c0964f8..55dc84bf1 100644 --- a/test/Utils.Tests.ps1 +++ b/test/Utils.Tests.ps1 @@ -4,9 +4,11 @@ Describe 'Utils Function Tests' { Context 'Add-PoshGitToProfile Tests' { BeforeAll { - $newLine = [System.Environment]::NewLine + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssigments', '')] + $newLine = [System.Environment]::NewLine } BeforeEach { + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssigments', '')] $profilePath = [System.IO.Path]::GetTempFileName() } AfterEach { @@ -84,6 +86,7 @@ New-Alias pscore C:\Users\Keith\GitHub\rkeithhill\PowerShell\src\powershell-win- Context 'Test-PoshGitImportedInScript Tests' { BeforeEach { + [System.Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssigments', '')] $profilePath = [System.IO.Path]::GetTempFileName() } AfterEach { diff --git a/test/testDebugHarness.ps1 b/test/testDebugHarness.ps1 deleted file mode 100644 index 56b32b1aa..000000000 --- a/test/testDebugHarness.ps1 +++ /dev/null @@ -1,2 +0,0 @@ - -Invoke-Pester $PSScriptRoot From b4165df4abb0bae107b1656b3ed9e472ad729389 Mon Sep 17 00:00:00 2001 From: Keith Hill Date: Sun, 19 Feb 2017 19:03:37 -0700 Subject: [PATCH 2/7] Add master as AppVeyor branch. Also add PrereleaseVersion as module private data property. Might come in handy. I'll update the issue template on master and then submit a PR to merge master to develop. --- appveyor.yml | 1 + src/posh-git.psd1 | 10 ++++++---- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/appveyor.yml b/appveyor.yml index 72cbe4641..e678718b0 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -4,6 +4,7 @@ os: branches: only: - develop + - master init: - git config --global core.autocrlf true diff --git a/src/posh-git.psd1 b/src/posh-git.psd1 index 237a3718d..8c3c1cc23 100644 --- a/src/posh-git.psd1 +++ b/src/posh-git.psd1 @@ -51,11 +51,11 @@ VariablesToExport = @() # Aliases to export from this module AliasesToExport = @() -# Private data to pass to the module specified in RootModule/ModuleToProcess. This may also contain a PSData hashtable with additional module metadata used by PowerShell. +# Private data to pass to the module specified in RootModule/ModuleToProcess. +# This may also contain a PSData hashtable with additional module metadata used by PowerShell. PrivateData = @{ PSData = @{ - # Tags applied to this module. These help with module discovery in online galleries. Tags = @('git', 'prompt', 'tab', 'tab-completion', 'tab-expansion', 'tabexpansion') @@ -68,8 +68,10 @@ PrivateData = @{ # ReleaseNotes of this module ReleaseNotes = 'https://github.com/dahlbyk/posh-git/blob/develop/CHANGELOG.md' - } # End of PSData hashtable + # TODO: REMOVE BEFOE RELEASE + PrereleaseVersion = 'pre00' + } -} # End of PrivateData hashtable +} } From 40263787c1da5a269885f88b6f9e4efd96ae5e7f Mon Sep 17 00:00:00 2001 From: Keith Hill Date: Sun, 19 Feb 2017 19:36:05 -0700 Subject: [PATCH 3/7] Change case to be more readable. --- src/posh-git.psd1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/posh-git.psd1 b/src/posh-git.psd1 index 8c3c1cc23..94495ce73 100644 --- a/src/posh-git.psd1 +++ b/src/posh-git.psd1 @@ -69,7 +69,7 @@ PrivateData = @{ ReleaseNotes = 'https://github.com/dahlbyk/posh-git/blob/develop/CHANGELOG.md' # TODO: REMOVE BEFOE RELEASE - PrereleaseVersion = 'pre00' + PreReleaseVersion = 'pre00' } } From 28c3bba9c21b6a1ad374de66d60b2ccdadb81dc7 Mon Sep 17 00:00:00 2001 From: Keith Dahlby Date: Sun, 19 Feb 2017 22:03:04 -0600 Subject: [PATCH 4/7] Update CHANGELOG.md --- CHANGELOG.md | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 27821e601..aa21a7f85 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,12 +2,14 @@ ## 1.0.0 - TBD This release introduces breaking changes with 0.x to both drop support for PowerShell 2.0 and support writing prompt strings using ANSI sequences. -The ANSI sequence support will help with cross-platform PowerShell support which is another goal of this release. +The ANSI sequence support will help with cross-platform PowerShell support, which is another goal of this release. - Drop support for PowerShell 2.0 -- Remove Invoke-NullCoalescing command +  ([#163](https://github.com/dahlbyk/posh-git/issues/163)) +  ([PR #427](https://github.com/dahlbyk/posh-git/pull/427)) +- Remove `Invoke-NullCoalescing` command ([#93](https://github.com/dahlbyk/posh-git/issues/93)) - ([PR #426](https://github.com/dahlbyk/posh-git/pull/426)) +  ([PR #427](https://github.com/dahlbyk/posh-git/pull/427)) ## 0.7.0 - February 14, 2017 This release has focused on improving the "getting started" experience by adding an `Add-PoshGitToProfile` command that From d4b1669fbbbcbf64caa21a3a017515f6005105db Mon Sep 17 00:00:00 2001 From: Keith Hill Date: Sun, 19 Feb 2017 21:42:43 -0700 Subject: [PATCH 5/7] Don't exp Get-AliasPattern/GitBranch, En-GitColors --- src/posh-git.psd1 | 5 +---- src/posh-git.psm1 | 3 --- test/Get-GitBranch.Tests.ps1 | 24 +++++++++++++----------- 3 files changed, 14 insertions(+), 18 deletions(-) diff --git a/src/posh-git.psd1 b/src/posh-git.psd1 index 94495ce73..82be71d21 100644 --- a/src/posh-git.psd1 +++ b/src/posh-git.psd1 @@ -4,7 +4,7 @@ RootModule = 'posh-git.psm1' # Version number of this module. -ModuleVersion = '1.0.0' +ModuleVersion = '1.0.0.0' # ID used to uniquely identify this module GUID = '74c9fd30-734b-4c89-a8ae-7727ad21d1d5' @@ -24,9 +24,6 @@ PowerShellVersion = '3.0' # Functions to export from this module FunctionsToExport = @( 'Add-PoshGitToProfile', - 'Enable-GitColors', - 'Get-AliasPattern', - 'Get-GitBranch', 'Get-GitStatus', 'Get-GitDirectory', 'Update-AllBranches', diff --git a/src/posh-git.psm1 b/src/posh-git.psm1 index a2f9c29f0..b54a025ce 100644 --- a/src/posh-git.psm1 +++ b/src/posh-git.psm1 @@ -119,9 +119,6 @@ $ExecutionContext.SessionState.Module.OnRemove = { $exportModuleMemberParams = @{ Function = @( 'Add-PoshGitToProfile', - 'Enable-GitColors', - 'Get-AliasPattern', - 'Get-GitBranch', 'Get-GitDirectory', 'Get-GitStatus', 'Update-AllBranches', diff --git a/test/Get-GitBranch.Tests.ps1 b/test/Get-GitBranch.Tests.ps1 index ee124536b..bf10e9296 100644 --- a/test/Get-GitBranch.Tests.ps1 +++ b/test/Get-GitBranch.Tests.ps1 @@ -1,16 +1,18 @@ . $PSScriptRoot\Shared.ps1 -Describe 'Get-GitBranch Tests' { - Context 'Get-GitBranch GIT_DIR Tests' { - It 'Returns GIT_DIR! when in .git dir of the repo' { - $repoRoot = (Resolve-Path $PSScriptRoot\..).Path - Set-Location $repoRoot\.git -ErrorAction Stop - Get-GitBranch | Should BeExactly 'GIT_DIR!' - } - It 'Returns correct path when in a child folder of the .git dir of the repo' { - $repoRoot = (Resolve-Path $PSScriptRoot\..).Path - Set-Location $repoRoot\.git\hooks -ErrorAction Stop - Get-GitBranch | Should BeExactly 'GIT_DIR!' +InModuleScope posh-git { + Describe 'Get-GitBranch Tests' { + Context 'Get-GitBranch GIT_DIR Tests' { + It 'Returns GIT_DIR! when in .git dir of the repo' { + $repoRoot = (Resolve-Path $PSScriptRoot\..).Path + Set-Location $repoRoot\.git -ErrorAction Stop + Get-GitBranch | Should BeExactly 'GIT_DIR!' + } + It 'Returns correct path when in a child folder of the .git dir of the repo' { + $repoRoot = (Resolve-Path $PSScriptRoot\..).Path + Set-Location $repoRoot\.git\hooks -ErrorAction Stop + Get-GitBranch | Should BeExactly 'GIT_DIR!' + } } } } From 12416444f75bb200e7698ed349122c089550e1ef Mon Sep 17 00:00:00 2001 From: Keith Dahlby Date: Sun, 19 Feb 2017 23:49:06 -0600 Subject: [PATCH 6/7] README formatting --- README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index d98031cd6..8ee9a5429 100644 --- a/README.md +++ b/README.md @@ -45,12 +45,12 @@ You may be asked if you trust packages coming from the PowerShell Gallery. Answe If you are on PowerShell version 3 or 4, you will need to install the [Package Management Preview for PowerShell 3 & 4](https://www.microsoft.com/en-us/download/details.aspx?id=51451) in order to run the command above. -Note: If you get an error message from Install-Module about NuGet being required to interact with NuGet-based repositories, execute the following commands to bootstrap the NuGet provider: +Note: If you get an error message from `Install-Module` about NuGet being required to interact with NuGet-based repositories, execute the following commands to bootstrap the NuGet provider: ``` Install-PackageProvider NuGet -Force Import-PackageProvider NuGet -Force ``` -Then retry the Install-Module command above. +Then retry the `Install-Module` command above. After you have successfully installed the posh-git module from the PowerShell Gallery, you will be able to update to a newer version by executing the command: ``` @@ -58,7 +58,7 @@ Update-Module posh-git ``` ### Installing posh-git via Chocolatey -If you are having issues using Install-Module with PowerShell version 3 or 4, you can use [Chocolatey](https://chocolatey.org) to install posh-git. +If you are having issues using `Install-Module` with PowerShell version 3 or 4, you can use [Chocolatey](https://chocolatey.org) to install posh-git. If you don't have Chocolatey, you can install it from the [Chocolately Install page](https://chocolatey.org/install). With Chocolatey installed, execute the following command to install posh-git: ``` From 6b2d854907e90966e4ce34eb572950bc6c29b8b4 Mon Sep 17 00:00:00 2001 From: Keith Dahlby Date: Sun, 19 Feb 2017 23:51:46 -0600 Subject: [PATCH 7/7] Update CHANGELOG.md --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index aa21a7f85..c1125fc0d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,7 +7,7 @@ The ANSI sequence support will help with cross-platform PowerShell support, whic - Drop support for PowerShell 2.0   ([#163](https://github.com/dahlbyk/posh-git/issues/163))  ([PR #427](https://github.com/dahlbyk/posh-git/pull/427)) -- Remove `Invoke-NullCoalescing` command +- Remove public `Enable-GitColors`, `Get-AliasPattern` and `Get-GitBranch`; plus `Invoke-NullCoalescing` and its `??` alias ([#93](https://github.com/dahlbyk/posh-git/issues/93))  ([PR #427](https://github.com/dahlbyk/posh-git/pull/427))