-
-
Notifications
You must be signed in to change notification settings - Fork 476
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Shorten TestDrive directory name #2239
Shorten TestDrive directory name #2239
Conversation
Pester currently uses a full GUID as its temp directory name, which uses 36 characters. This contributes to test errors when paths used in tests exceed the Windows max path of 260 characters. The `[IO.Path]::GetTempFileName()` only uses 4 characters for the unique/random part of its filename. Follow the same pattern in `New-RandomTempDirectory` by only using the 4 characters. A GUID, when converted to a string, only uses hex characters: 0-9 and a-f, which gives us 65,536 unique possible values. Instead, lets use `[IO.Path]::GetRandomFileName()`. It generates a name that uses all letters of the alphabet and the numbers 0-9, which gives us 36^4 = 1,679,616 possible values.
db52706
to
fb84215
Compare
src/functions/TestDrive.ps1
Outdated
@@ -71,7 +71,8 @@ function Clear-TestDrive ([String[]]$Exclude, [string]$TestDrivePath) { | |||
function New-RandomTempDirectory { | |||
do { | |||
$tempPath = Get-TempDirectory | |||
$Path = [IO.Path]::Combine($tempPath, ([Guid]::NewGuid())); | |||
$dirName = [IO.Path]::GetRandomFileName().Substring(0, 4) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps 6 or 8.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I chose 4 because that's what the System.IO.Path.GetTempFileName()
static method uses. It returns a filename with four unique hex characters. But I'm not against six or eight characters, either.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Which implementation of GetTempFileName() (or GetRandomFileName ?) are you looking at? .NET does not do it. And .NET Framework does that neither, by looking at the code, they both use cryptographically safe randomization and a file check.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That said, running this on my computer produces 1-10 conflicts. Which we would resolve by file check, so it is not likely to cause too many problems.
1..1000000 | % { [IO.Path]::GetRandomFileName().Substring(0, 4) } | unique | Measure-Object
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was looking at [System.IO.Path]::GetTempFileName()
as the basis for "four unique characters is enough", and not at how it's implemented under the covers. The problem with [IO.Path]::GetTempFileName()
is that it actually creates a temporary file, so I don't want to do that.
Not sure why I thought this is an ask for feature, rather than PR. |
@fflaten any opinion on shortening the names? Maybe we should also unify this with Test Registry? |
Sounds good, but 4 chars sounds a bit low without a Pester-prefix
Yes |
The current test directory name doesn't have a Pester-prefix, it uses an inscrutable Guid. The object is to use as short a name as possible to avoid path too long issues. Adding a prefix would partially defeat that. |
@fflaten We should just make it the same for registry, if that did not happen yet? Update: I thought wrong, no Pester folder in TEMP. But we do doublecheck for conflicts though, so still okay? |
Currently if cleanup doesn't run as expected (ex. cancelled script), then those guid-folders will be unidentifiable. "What keeps filling up my temp and is it safe to delete?" By adding a source hint like
10 vs 36 is still a solid improvement. If the last 6 chars breaks your solution then you're one long username from breaking and should modify the test code itself. So this PR is mostly a quality improvement and not a "every char counts" critical fix imo. 🙂 |
PR Summary
Pester currently uses a full GUID as its temp directory name, which uses 36 characters. This contributes to test errors when paths used in tests exceed the Windows max path of 260 characters.
The
[IO.Path]::GetTempFileName()
only uses 4 characters for the unique/random part of its filename. Pester should follow the same pattern and only use a temp directory with 4 characters.Let's not use a GUID anymore, either. A GUID, when converted to a string, only uses hex characters: 0-9 and a-f, which gives us 65,536 unique possible values. Instead, lets use the first four characters of the file name returned by
[IO.Path]::GetRandomFileName()
. It generates a name that uses all letters of the alphabet and the numbers 0-9, which gives us 36^4 = 1,679,616 possible values.Fix #2238
PR Checklist
Create Pull Request
to mark it as a draft. PR can be markedReady for review
when it's ready.