From dff695b6eb42292d7dc17d13a9bfd68a4fdb9fb4 Mon Sep 17 00:00:00 2001 From: Wouter Mellema Date: Thu, 8 Feb 2024 12:18:53 +0100 Subject: [PATCH 1/4] Added python_path to pyvenv class Issue #685 - Add: `python_path` variable to `python::pyvenv` --- REFERENCE.md | 9 +++++++ manifests/pyvenv.pp | 14 +++++++--- spec/acceptance/pyvenv_spec.rb | 49 ++++++++++++++++++++++++++++++++++ 3 files changed, 69 insertions(+), 3 deletions(-) diff --git a/REFERENCE.md b/REFERENCE.md index 3c51151b..bc53587b 100644 --- a/REFERENCE.md +++ b/REFERENCE.md @@ -913,6 +913,7 @@ The following parameters are available in the `python::pyvenv` defined type: * [`path`](#-python--pyvenv--path) * [`environment`](#-python--pyvenv--environment) * [`prompt`](#-python--pyvenv--prompt) +* [`python_path`](#-python--pyvenv--python_path) * [`pip_version`](#-python--pyvenv--pip_version) ##### `ensure` @@ -995,6 +996,14 @@ Optionally specify the virtualenv prompt (python >= 3.6) Default value: `undef` +##### `python_path` + +Data type: `Optional[String[1]]` + +Optionally specify python path for creation of virtualenv + +Default value: `undef` + ##### `pip_version` Data type: `Python::Venv::PipVersion` diff --git a/manifests/pyvenv.pp b/manifests/pyvenv.pp index 14dcb9fb..98eb61e0 100644 --- a/manifests/pyvenv.pp +++ b/manifests/pyvenv.pp @@ -11,6 +11,7 @@ # @param path Specifies the PATH variable. # @param environment Optionally specify environment variables for pyvenv # @param prompt Optionally specify the virtualenv prompt (python >= 3.6) +# @param python_path Optionally specify python path for creation of virtualenv # # @example # python::pyvenv { '/var/www/project1' : @@ -34,6 +35,7 @@ Array $environment = [], Optional[String[1]] $prompt = undef, Python::Venv::PipVersion $pip_version = 'latest', + Optional[String[1]] $python_path = undef, ) { include python @@ -46,11 +48,17 @@ $python_version_parts = split($python_version, '[.]') $normalized_python_version = sprintf('%s.%s', $python_version_parts[0], $python_version_parts[1]) + $local_exec_prefix = $python_path ? { + undef => $python::exec_prefix, + default => $python_path, + } # pyvenv is deprecated since 3.6 and will be removed in 3.8 - if versioncmp($normalized_python_version, '3.6') >=0 { - $virtualenv_cmd = "${python::exec_prefix}python${normalized_python_version} -m venv" + if $python_path != undef { + $virtualenv_cmd = "${python_path} -m venv" + } elsif versioncmp($normalized_python_version, '3.6') >=0 { + $virtualenv_cmd = "${local_exec_prefix}python${normalized_python_version} -m venv" } else { - $virtualenv_cmd = "${python::exec_prefix}pyvenv-${normalized_python_version}" + $virtualenv_cmd = "${local_exec_prefix}pyvenv-${normalized_python_version}" } $_path = $python::provider ? { diff --git a/spec/acceptance/pyvenv_spec.rb b/spec/acceptance/pyvenv_spec.rb index 318c2f73..774fc3e2 100644 --- a/spec/acceptance/pyvenv_spec.rb +++ b/spec/acceptance/pyvenv_spec.rb @@ -192,4 +192,53 @@ class { 'python': its(:stdout) { is_expected.to match %r{agent.* 0\.1\.2} } end end + + context 'with versioned minimal python::pip and without systempkgs using custom python path' do + it 'works with no errors' do + pp = <<-PUPPET + + class { 'python': + dev => 'present', + venv => 'present', + } + file { '/usr/bin/mycustompython': + ensure => link, + target => '/usr/bin/python', + } + user { 'agent': + ensure => 'present', + managehome => true, + home => '/opt/agent', + } + group { 'agent': + ensure => 'present', + system => true, + } + python::pyvenv { '/opt/agent/venv': + ensure => 'present', + systempkgs => false, + owner => 'agent', + group => 'agent', + mode => '0755', + pip_version => '<= 20.3.4', + python_path => '/usr/bin/mycustompython', + } + python::pip { 'agent' : + ensure => '0.1.2', + virtualenv => '/opt/agent/venv', + owner => 'agent', + group => 'agent', + } + PUPPET + + # Run it twice and test for idempotency + apply_manifest(pp, catch_failures: true) + apply_manifest(pp, catch_changes: true) + end + + describe command('/opt/agent/venv/bin/pip list') do + its(:exit_status) { is_expected.to eq 0 } + its(:stdout) { is_expected.to match %r{agent.* 0\.1\.2} } + end + end end From e7a9f7b0b8bcba1733af9f752dd7b48359d56d0f Mon Sep 17 00:00:00 2001 From: Wouter Mellema Date: Thu, 8 Feb 2024 13:03:21 +0100 Subject: [PATCH 2/4] Fixed whitespace issue --- spec/acceptance/pyvenv_spec.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/acceptance/pyvenv_spec.rb b/spec/acceptance/pyvenv_spec.rb index 774fc3e2..0b20e27f 100644 --- a/spec/acceptance/pyvenv_spec.rb +++ b/spec/acceptance/pyvenv_spec.rb @@ -196,7 +196,7 @@ class { 'python': context 'with versioned minimal python::pip and without systempkgs using custom python path' do it 'works with no errors' do pp = <<-PUPPET - + class { 'python': dev => 'present', venv => 'present', From 78891b76b257fbb31d6ea088ece987b4568dad00 Mon Sep 17 00:00:00 2001 From: Wouter Mellema Date: Thu, 8 Feb 2024 15:31:31 +0100 Subject: [PATCH 3/4] Update manifests/pyvenv.pp Co-authored-by: Tim Meusel --- manifests/pyvenv.pp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/manifests/pyvenv.pp b/manifests/pyvenv.pp index 98eb61e0..5bfc2103 100644 --- a/manifests/pyvenv.pp +++ b/manifests/pyvenv.pp @@ -35,7 +35,7 @@ Array $environment = [], Optional[String[1]] $prompt = undef, Python::Venv::PipVersion $pip_version = 'latest', - Optional[String[1]] $python_path = undef, + Optional[Stdlib::Absolutepath] $python_path = undef, ) { include python From 9d4c4ea017e81839593c10987c4a38960d825be8 Mon Sep 17 00:00:00 2001 From: Wouter Mellema Date: Thu, 8 Feb 2024 15:32:39 +0100 Subject: [PATCH 4/4] Updated reference.md --- REFERENCE.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/REFERENCE.md b/REFERENCE.md index bc53587b..f3a382e5 100644 --- a/REFERENCE.md +++ b/REFERENCE.md @@ -998,7 +998,7 @@ Default value: `undef` ##### `python_path` -Data type: `Optional[String[1]]` +Data type: `Optional[Stdlib::Absolutepath]` Optionally specify python path for creation of virtualenv