proxb/PoshRSJob

Add ImportPSModulesFromPath support

beargle opened this issue · 5 comments

Do you want to request a feature or report a bug?
Feature

What is the current behavior?
Importing modules in background runspace jobs requires that the module be:

  • "Installed" and accessible in $env:PSModulePath
  • Passed by name to Start-RSJob using the -ModuleToImport parameter

What is the proposed behavior?
Add support for passing a custom module path, from which modules will be imported into background runspace jobs.

This should require no modification of $env:PSModulePath, and shouldn't require the module to be pre-installed on the client. Expecting something similar to how modules are specified for import in psake-config.ps1. Specific use case is a portable CI/CD pipeline that manages PowerShell module dependencies, without relying on Install-Module or a specific build server configuration.

It looks like InitialSessionState.ImportPSModulesFromPath() could work for this, but would make a hard dependency on PowerShell V3. Wasn't sure if PowerShell V2 support was still important based on #162.

Please provide a code example showing the potential feature, if applicable:
Today we pass in one or more module names to import, which have to be accessible with $env:PSModulePath

Start-RSJob -ModulesToImport @("Pester")...

Would like to be able to pass in a custom module path, from which one or more modules are imported. Assuming a directory structure of:

Dependencies/
    PowerShell/
        Modules/

We should be able to:

Start-RSJob -ModulesFromPathToImport ".\Dependencies\PowerShell\Modules"...

If this looks like something that would be useful, I'm happy to put together a PR for review. Thanks!

proxb commented

@beargle This sounds cool! I am definitely done with adding new features for V2 and have already moved the V2 supporting module onto its own branch. I just need to work on removing the V2 code as well as adding a warning when this module is imported from a V2 host. I should have that completed by the end of the week if you can wait until then, otherwise go ahead and do the PR and I will merge it and then begin work on removing the V2 stuff.

btw this can be done thru -ModulesToImport parameter like Import-Module -Name.
If supplied path exists, that it is path to module, if not - just module name
and path can support wildcards thru Resolve-Path

@MVKozlov Good point about similar functionality with -ModulesToImport; I do see that it could be used if the collection of module paths is pre-built with Resolve-Path and wildcards.

I haven't been able to get -ModulesToImport to work with a single path that contains module subdirectories (ex. like what Windows users have at ~\Documents\WindowsPowerShell\Modules). Am I missing something on that front?

Regardless, PR has been raised - would appreciate any feedback you all have. Thanks!

I this this way close to your needs

$list = 'PoshWSUS', 'D:\Work\ps\test\', 'D:\Work\ps\test\PSAlphaFS\2.0.0.1\*.psm1'

$modulenames = New-Object System.Collections.ArrayList
$modulepaths = $list | ForEach-Object {
  $m = $_
  try {
    Resolve-Path $_ -ErrorAction Stop | Select-Object -ExpandProperty Path
  }
  catch {
    $null = $modulenames.Add($m)
  }
}
$modulenames
$modulepaths

here I'm split common list to names and paths