Skip to content

Commit

Permalink
MODULES-1458 allow specifying mod_wsgi package and path/module name
Browse files Browse the repository at this point in the history
  • Loading branch information
jantman committed Dec 27, 2014
1 parent 0b0a226 commit 649cc79
Show file tree
Hide file tree
Showing 3 changed files with 83 additions and 1 deletion.
16 changes: 16 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -729,6 +729,22 @@ For customized parameters, which tell Apache how Python is currently configured
}
```

To specify an alternate mod\_wsgi package name to install and the name of the module .so it provides,
(e.g. a "python27-mod\_wsgi" package that provides "python27-mod_wsgi.so" in the default module directory):

```puppet
class { 'apache::mod::wsgi':
wsgi_socket_prefix => "\${APACHE_RUN_DIR}WSGI",
wsgi_python_home => '/path/to/venv',
wsgi_python_path => '/path/to/venv/site-packages',
package_name => 'python27-mod_wsgi',
mod_path => 'python27-mod_wsgi.so',
}
```

If ``mod_path`` does not contain "/", it will be prefixed by the default module path
for your OS; otherwise, it will be used literally.

More information about [WSGI](http://modwsgi.readthedocs.org/en/latest/).

####Class: `apache::mod::fcgid`
Expand Down
22 changes: 21 additions & 1 deletion manifests/mod/wsgi.pp
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,28 @@
$wsgi_socket_prefix = $::apache::params::wsgi_socket_prefix,
$wsgi_python_path = undef,
$wsgi_python_home = undef,
$package_name = undef,
$mod_path = undef,
){
::apache::mod { 'wsgi': }

if ($package_name != undef and $mod_path == undef) or ($package_name == undef and $mod_path != undef) {
fail('apache::mod::wsgi - both package_name and mod_path must be specified!')
}

if $package_name != undef {
if $mod_path =~ /\// {
$_mod_path = $mod_path
} else {
$_mod_path = "${::apache::params::lib_path}/${mod_path}"
}
::apache::mod { 'wsgi':
package => $package_name,
path => $_mod_path,
}
}
else {
::apache::mod { 'wsgi': }
}

# Template uses:
# - $wsgi_socket_prefix
Expand Down
46 changes: 46 additions & 0 deletions spec/classes/mod/wsgi_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,52 @@
end
it {is_expected.to contain_file('wsgi.conf').with_content(/^ WSGIPythonHome "\/path\/to\/virtenv"$/)}
end
describe "with custom package_name and mod_path" do
let :params do
{
:package_name => 'mod_wsgi_package',
:mod_path => '/foo/bar/baz',
}
end
it { is_expected.to contain_apache__mod('wsgi').with({
'package' => 'mod_wsgi_package',
'path' => '/foo/bar/baz',
})
}
it { is_expected.to contain_package("mod_wsgi_package") }
it { is_expected.to contain_file('wsgi.load').with_content(%r"LoadModule wsgi_module /foo/bar/baz") }
end
describe "with custom mod_path not containing /" do
let :params do
{
:package_name => 'mod_wsgi_package',
:mod_path => 'wsgi_mod_name.so',
}
end
it { is_expected.to contain_apache__mod('wsgi').with({
'path' => 'modules/wsgi_mod_name.so',
'package' => 'mod_wsgi_package',
})
}
it { is_expected.to contain_file('wsgi.load').with_content(%r"LoadModule wsgi_module modules/wsgi_mod_name.so") }

end
describe "with package_name but no mod_path" do
let :params do
{
:mod_path => '/foo/bar/baz',
}
end
it { expect { subject }.to raise_error Puppet::Error, /apache::mod::wsgi - both package_name and mod_path must be specified!/ }
end
describe "with mod_path but no package_name" do
let :params do
{
:package_name => '/foo/bar/baz',
}
end
it { expect { subject }.to raise_error Puppet::Error, /apache::mod::wsgi - both package_name and mod_path must be specified!/ }
end
end
context "on a FreeBSD OS" do
let :facts do
Expand Down

0 comments on commit 649cc79

Please sign in to comment.