A Chef cookbook to provide a unified interface for installing Python, managing Python packages, and creating virtualenvs.
This is a fork of the "poise" version. PR's will be reviewed and accepted on this fork. Publishing back to supermarket is not planned, as we do not have access to the "poise-python" package. Maybe we will rename this later so we can publish to supermarket.
This fork is mostly focused on Red Hat/CentOS Linux, and in particular, supporting both base and SCL versions of python.
To install the latest available version of Python 2 and then use it to create a virtualenv and install some packages:
python_runtime '2'
python_virtualenv '/opt/myapp/.env'
python_package 'Django' do
version '1.8'
end
pip_requirements '/opt/myapp/requirements.txt'
While using python_package 'git+https://github.com/example/mypackage.git'
will
sometimes work, this approach is not recommended. Unfortunately pip's support
for installing directly from URI sources is limited and cannot support the API
used for the python_package
resource. You can run the install either directly
from the URI or through an intermediary git
resource:
# Will re-install on every converge unless you add a not_if/only_if.
python_execute '-m pip install git+https://github.com/example/mypackage.git'
# Will only re-install when the git repository updates.
python_execute 'install mypackage' do
action :nothing
command '-m pip install .'
cwd '/opt/mypackage'
end
git '/opt/mypackage' do
repository 'https://github.com/example/mypackage.git'
notifies :run, 'python_execute[install mypackage]', :immediately
end
This cookbook can install at least Python 2.7, Python 3, and PyPy on all supported platforms (Debian, Ubuntu, RHEL, CentOS, Fedora).
This cookbook includes basic support for managing Python on Windows. This does not support Python 3.5. Everything was working at some point, but there are no active CI pipelines to keep this current. Consider this untested and experimental at this time.
Chef 12.1 or newer is required.
Attributes are used to configure the default recipe.
node['poise-python']['install_python2']
– Install a Python 2.x runtime. (default: true)node['poise-python']['install_python3']
– Install a Python 3.x runtime. (default: false)node['poise-python']['install_pypy']
– Install a PyPy runtime. (default: false)
The default recipe installs Python 2, 3, and/or PyPy based on the node
attributes. It is entirely optional and can be ignored in favor of direct use
of the python_runtime
resource.
The python_runtime
resource installs a Python interpreter.
python_runtime '2'
:install
– Install the Python interpreter. (default):uninstall
– Uninstall the Python interpreter.
version
– Version of Python to install. If a partial version is given, use the latest available version matching that prefix. (name property)get_pip_url
– URL to download theget-pip.py
bootstrap script from. (default: https://bootstrap.pypa.io/get-pip.py)pip_version
– Version of pip to install. If set totrue
, use the latest. If set tofalse
, do not install pip. For backward compatibility, can also be set to a URL instead ofget_pip_url
. (default: true)setuptools_version
– Version of Setuptools to install. If set totrue
, use the latest. If set tofalse
, do not install Setuptools. (default: true)virtualenv_version
– Version of virtualenv to install. If set totrue
, use the latest. If set tofalse
, do not install virtualenv. Will never be installed if thevenv
module is already available, such as on Python 3. (default: true)wheel_version
– Version of wheel to install. If set totrue
, use the latest. If set tofalse
, do not install wheel.environment
- Hash of a additional environment variables for this runtime. This is a good place to set pip variables, likePIP_INDEX_URL
andPIP_EXTRA_INDEX_URL
.
The poise-python
library offers an additional way to pass configuration
information to the final provider called "options". Options are key/value pairs
that are passed down to the python_runtime
provider and can be used to control how it
installs Python. These can be set in the python_runtime
resource using the options
method, in node attributes or via the
python_runtime_options
resource. The options from all sources are merged
together in to a single hash.
When setting options in the resource you can either set them for all providers:
python_runtime 'myapp' do
version '2.7'
options pip_version: false
end
or for a single provider (in this case the system
provider):
python_runtime 'myapp' do
version '2.7'
options :system, dev_package: false
end
Setting options via node attributes is generally how an end-user or application cookbook will customize installations in the library cookbooks they are using. You can set options for all installations or for a single runtime:
# Global, for all installations.
override['poise-python']['options']['pip_version'] = false
# Single installation.
override['poise-python']['myapp']['version'] = 'pypy'
The python_runtime_options
resource is also available to set node attributes
for a specific installation in a DSL-friendly way:
python_runtime_options 'myapp' do
version '3'
end
Unlike resource attributes, provider options can be different for each provider. Not all providers support the same options so make sure to the check the documentation for each provider to see what options the use.
The python_runtime_options
resource allows setting provider options in a
DSL-friendly way. See the Provider Options section for more
information about provider options overall.
python_runtime_options 'myapp' do
version '3'
end
:run
– Apply the provider options. (default)
resource
– Name of thepython_runtime
resource. (name property)for_provider
– Provider to set options for.
All other attribute keys will be used as options data.
The python_execute
resource executes a Python script using the configured runtime.
python_execute 'myapp.py' do
user 'myuser'
end
This uses the built-in execute
resource and supports all the same properties.
:run
– Execute the script. (default)
command
– Script and arguments to run. Must not include thepython
. (name attribute)python
– Name of thepython_runtime
resource to use. If not specified, the most recently declaredpython_runtime
will be used. Can also be set to the full path to apython
binary.virtualenv
– Name of thepython_virtualenv
resource to use. This is mutually exclusive with thepython
property.
For other properties see the Chef documentation.
The python_package
resource installs Python packages using
pip.
python_package 'Django' do
version '1.8'
end
This uses the built-in package
resource and supports the same actions and
properties. Multi-package installs are supported using the standard syntax.
:install
– Install the package. (default):upgrade
– Install using the--upgrade
flag.:remove
– Uninstall the package.
The :purge
and :reconfigure
actions are not supported.
group
– System group to install the package.package_name
– Package or packages to install. (name property)version
– Version or versions to install.python
– Name of thepython_runtime
resource to use. If not specified, the most recently declaredpython_runtime
will be used. Can also be set to the full path to apython
binary.user
– System user to install the package.virtualenv
– Name of thepython_virtualenv
resource to use. This is mutually exclusive with thepython
property.options
– Options to pass topip
.install_options
– Options to pass topip install
(and similar commands).list_options
– Options to pass topip list
(and similar commands).
For other properties see the Chef documentation.
The response_file
, response_file_variables
, and source
properties are not
supported.
The python_virtualenv
resource creates Python virtual environments.
python_virtualenv '/opt/myapp'
This will use the venv
module if available, or virtualenv
otherwise.
:create
– Create the virtual environment. (default):delete
– Delete the virtual environment.
group
– System group to create the virtualenv.path
– Path to create the environment at. (name property)pip_version
– Version of pip to install. If set totrue
, use the latest. If set tofalse
, do not install pip. Can also be set to a URL to a copy of theget-pip.py
script. (default: true)python
– Name of thepython_runtime
resource to use. If not specified, the most recently declaredpython_runtime
will be used. Can also be set to the full path to apython
binary.setuptools_version
– Version of Setuptools to install. If set totrue
, use the latest. If set tofalse
, do not install Setuptools. (default: true)system_site_packages
– Enable or disable visibilty of system packages in the environment. (default: false)user
– System user to create the virtualenv.wheel_version
– Version of wheel to install. If set totrue
, use the latest. If set tofalse
, do not install wheel.
The pip_requirements
resource installs packages based on a requirements.txt
file.
pip_requirements '/opt/myapp/requirements.txt'
The underlying pip install
command will run on every converge, but
notifications will only be triggered if a package is actually installed.
:install
– Install the requirements. (default):upgrade
– Install using the--upgrade
flag.
path
– Path to the requirements file, or a folder containing the requirements file. (name property)cwd
– Directory to runpip
from. (default: directory containing therequirements.txt
)group
– System group to install the packages.options
– Command line options for use withpip install
.python
– Name of thepython_runtime
resource to use. If not specified, the most recently declaredpython_runtime
will be used. Can also be set to the full path to apython
binary.user
– System user to install the packages.virtualenv
– Name of thepython_virtualenv
resource to use. This is mutually exclusive with thepython
property.
These provider options are supported by all providers.
pip_version
– Override the pip version.setuptools_version
– Override the Setuptools version.version
– Override the Python version.virtualenv_version
– Override the virtualenv version.wheel_version
– Override the wheel version.
The system
provider installs Python using system packages. This is currently
only tested on platforms using apt-get
and yum
(Debian, Ubuntu, RHEL, CentOS
Amazon Linux, and Fedora) and is a default provider on those platforms. It may
work on other platforms but is untested.
python_runtime 'myapp' do
provider :system
version '2.7'
end
dev_package
– Install the package with the headers and other development files. Can be set to a string to select the dev package specifically. (default: true)package_name
– Override auto-detection of the package name.package_upgrade
– Install using action:upgrade
. (default: false)package_version
– Override auto-detection of the package version.
The scl
provider installs Python using the Software Collections
packages. This is only available on RHEL, CentOS, and Fedora. SCL offers more
recent versions of Python than the system packages for the most part. If an SCL
package exists for the requested version, it will be used in preference to the
system
provider.
python_runtime 'myapp' do
provider :scl
version '3.4'
end
The portable_pypy
provider installs Python using the Portable PyPy
packages. These are only available for Linux, but should work on any Linux OS.
python_runtime 'myapp' do
provider :portable_pypy
version 'pypy'
end
The portable_pypy3
provider installs Python 3 using the Portable PyPy
packages. These are only available for Linux, but should work on any Linux OS.
python_runtime 'myapp' do
provider :portable_pypy3
version 'pypy3'
end
folder
– Folder to install PyPy in. (default: /opt/)url
– URL to download the package from. (default: automatic)
This project is not sponsored.
Copyright 2018-2020, NDP LLC
Copyright 2015-2017, Noah Kantrowitz
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.