create local subversion server for tests (#49047)

* create local subversion server for tests

* fix sanity issues

* don't touch system config when bringing up site

* removed original setup files

* fix opensuse config

(cherry picked from commit 0420d606de)
pull/49623/head
Jordan Borean 6 years ago committed by Toshio Kuratomi
parent 35e02293d5
commit af03dd0463

@ -1,2 +1,4 @@
shippable/posix/group2 shippable/posix/group2
skip/osx skip/osx
destructive
needs/root

@ -0,0 +1,9 @@
---
apache_port: 11386 # cannot use 80 as httptester overrides this
subversion_test_dir: '{{ output_dir }}/svn-test'
subversion_server_dir: /tmp/ansible-svn # cannot use a path in the home dir without userdir or granting exec permission to the apache user
subversion_repo_name: ansible-test-repo
subversion_repo_url: http://127.0.0.1:{{ apache_port }}/svn/{{ subversion_repo_name }}
subversion_repo_auth_url: http://127.0.0.1:{{ apache_port }}/svnauth/{{ subversion_repo_name }}
subversion_username: subsvn_user'''
subversion_password: Password123!

@ -0,0 +1,6 @@
#!/usr/bin/env bash
svnadmin create "$1"
svn mkdir "file://$PWD/$1/trunk" -m "make trunk"
svn mkdir "file://$PWD/$1/tags" -m "make tags"
svn mkdir "file://$PWD/$1/branches" -m "make branches"

@ -1,2 +1,3 @@
dependencies: dependencies:
- prepare_tests - prepare_tests
- setup_passlib

@ -1,123 +1,27 @@
# test code for the svn module ---
# (c) 2014, Michael DeHaan <michael.dehaan@gmail.com> - name: clean out the checkout dir
file:
# This file is part of Ansible path: '{{ subversion_test_dir }}'
# state: '{{ item }}'
# Ansible is free software: you can redistribute it and/or modify loop:
# it under the terms of the GNU General Public License as published by - absent
# the Free Software Foundation, either version 3 of the License, or - directory
# (at your option) any later version.
# - name: setup subversion server
# Ansible is distributed in the hope that it will be useful, include_tasks: setup.yml
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - block:
# GNU General Public License for more details. - name: verify that subversion is installed so this test can continue
# shell: which svn
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>. - name: run tests
include_tasks: tests.yml
- name: set where to extract the repo
set_fact: checkout_dir={{ output_dir }}/svn always:
- name: stop apache after tests
- name: set what repo to use command: apachectl -k stop -f {{ subversion_server_dir }}/subversion.conf
set_fact: repo=https://github.com/jimi-c/test_role
- name: remove tmp subversion server dir
- name: clean out the output_dir file:
shell: rm -rf {{ output_dir }}/* path: '{{ subversion_server_dir }}'
state: absent
- name: install subversion
package:
name: subversion
when: ansible_distribution != "MacOSX"
- name: verify that subversion is installed so this test can continue
shell: which svn
# checks out every branch so using a small repo
- name: initial checkout
subversion: repo={{ repo }} dest={{ checkout_dir }}
register: subverted
- debug: var=subverted
- shell: ls {{ checkout_dir }}
# FIXME: the before/after logic here should be fixed to make them hashes, see GitHub 6078
# looks like this: {
# "after": [
# "Revision: 9",
# "URL: https://github.com/jimi-c/test_role"
# ],
# "before": null,
# "changed": true,
# "item": ""
# }
- name: verify information about the initial clone
assert:
that:
- "'after' in subverted"
- "subverted.after.1 == 'URL: https://github.com/jimi-c/test_role'"
- "not subverted.before"
- "subverted.changed"
- name: repeated checkout
subversion: repo={{ repo }} dest={{ checkout_dir }}
register: subverted2
- name: verify on a reclone things are marked unchanged
assert:
that:
- "not subverted2.changed"
- name: check for tags
stat: path={{ checkout_dir }}/tags
register: tags
- name: check for trunk
stat: path={{ checkout_dir }}/trunk
register: trunk
- name: check for branches
stat: path={{ checkout_dir }}/branches
register: branches
- name: assert presence of tags/trunk/branches
assert:
that:
- "tags.stat.isdir"
- "trunk.stat.isdir"
- "branches.stat.isdir"
- name: checkout with quotes in username
subversion: repo={{ repo }} dest={{ checkout_dir }} username="quoteme'''"
register: subverted3
- debug: var=subverted3
- name: checkout with export
subversion: repo={{ repo }} dest={{ output_dir }}/svn-export export=True
register: subverted4
- name: check for tags
stat: path={{ output_dir }}/svn-export/tags
register: export_tags
- name: check for trunk
stat: path={{ output_dir }}/svn-export/trunk
register: export_trunk
- name: check for branches
stat: path={{ output_dir }}/svn-export/branches
register: export_branches
- name: assert presence of tags/trunk/branches in export
assert:
that:
- "export_tags.stat.isdir"
- "export_trunk.stat.isdir"
- "export_branches.stat.isdir"
- "subverted4.changed"
# TBA: test for additional options or URL variants welcome

@ -0,0 +1,61 @@
---
- name: load OS specific vars
include_vars: '{{ ansible_os_family }}.yml'
- name: install SVN pre-reqs
package:
name: '{{ subversion_packages }}'
state: present
- name: create SVN home folder
file:
path: '{{ subversion_server_dir }}'
state: directory
- name: set SELinux security context for SVN folder
sefcontext:
target: '{{ subversion_server_dir }}(/.*)?'
setype: '{{ item }}'
state: present
when: ansible_selinux.status == "enabled"
with_items:
- httpd_sys_content_t
- httpd_sys_rw_content_t
- name: apply new SELinux context to filesystem
command: restorecon -irv {{ subversion_server_dir | quote }}
when: ansible_selinux.status == "enabled"
- name: template out configuration file
template:
src: subversion.conf.j2
dest: '{{ subversion_server_dir }}/subversion.conf'
- name: create a test repository
script: create_repo.sh {{ subversion_repo_name }}
args:
chdir: '{{ subversion_server_dir }}'
creates: '{{ subversion_server_dir }}/{{ subversion_repo_name }}'
- name: apply ownership for all SVN directories
file:
path: '{{ subversion_server_dir }}'
owner: '{{ apache_user }}'
group: '{{ apache_group }}'
recurse: True
- name: add test user to htpasswd for Subversion site
htpasswd:
path: '{{ subversion_server_dir }}/svn-auth-users'
name: '{{ subversion_username }}'
password: '{{ subversion_password }}'
state: present
- name: start test Apache SVN site - non Red Hat
command: apachectl -k start -f {{ subversion_server_dir }}/subversion.conf
when: not ansible_os_family == 'RedHat'
# On Red Hat based OS', we can't use apachectl to start up own instance, just use the raw httpd
- name: start test Apache SVN site - Red Hat
command: httpd -k start -f {{ subversion_server_dir }}/subversion.conf
when: ansible_os_family == 'RedHat'

@ -0,0 +1,133 @@
# test code for the svn module
# (c) 2014, Michael DeHaan <michael.dehaan@gmail.com>
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
# checks out every branch so using a small repo
- name: initial checkout
subversion:
repo: '{{ subversion_repo_url }}'
dest: '{{ subversion_test_dir }}/svn'
register: subverted
- name: check if dir was checked out
stat:
path: '{{ subversion_test_dir }}/svn'
register: subverted_result
# FIXME: the before/after logic here should be fixed to make them hashes, see GitHub 6078
# looks like this: {
# "after": [
# "Revision: 9",
# "URL: https://github.com/jimi-c/test_role"
# ],
# "before": null,
# "changed": true,
# "item": ""
# }
- name: verify information about the initial clone
assert:
that:
- "'after' in subverted"
- "subverted.after.1 == 'URL: ' ~ subversion_repo_url"
- "not subverted.before"
- "subverted.changed"
- subverted_result.stat.exists
- name: repeated checkout
subversion:
repo: '{{ subversion_repo_url }}'
dest: '{{ subversion_test_dir }}/svn'
register: subverted2
- name: verify on a reclone things are marked unchanged
assert:
that:
- "not subverted2.changed"
- name: check for tags
stat: path={{ subversion_test_dir }}/svn/tags
register: tags
- name: check for trunk
stat: path={{ subversion_test_dir }}/svn/trunk
register: trunk
- name: check for branches
stat: path={{ subversion_test_dir }}/svn/branches
register: branches
- name: assert presence of tags/trunk/branches
assert:
that:
- "tags.stat.isdir"
- "trunk.stat.isdir"
- "branches.stat.isdir"
- name: remove checked out repo
file:
path: '{{ subversion_test_dir }}/svn'
state: absent
- name: checkout with quotes in username
subversion:
repo: '{{ subversion_repo_auth_url }}'
dest: '{{ subversion_test_dir }}/svn'
username: '{{ subversion_username }}'
password: '{{ subversion_password }}'
register: subverted3
- name: get result of checkout with quotes in username
stat:
path: '{{ subversion_test_dir }}/svn'
register: subverted3_result
- name: assert checkout with quotes in username
assert:
that:
- subverted3 is changed
- subverted3_result.stat.exists
- subverted3_result.stat.isdir
- name: checkout with export
subversion:
repo: '{{ subversion_repo_url }}'
dest: '{{ subversion_test_dir }}/svn-export'
export: True
register: subverted4
- name: check for tags
stat: path={{ subversion_test_dir }}/svn-export/tags
register: export_tags
- name: check for trunk
stat: path={{ subversion_test_dir }}/svn-export/trunk
register: export_trunk
- name: check for branches
stat: path={{ subversion_test_dir }}/svn-export/branches
register: export_branches
- name: assert presence of tags/trunk/branches in export
assert:
that:
- "export_tags.stat.isdir"
- "export_trunk.stat.isdir"
- "export_branches.stat.isdir"
- "subverted4.changed"
# TBA: test for additional options or URL variants welcome

@ -0,0 +1,66 @@
{% if ansible_os_family == "Debian" %}
{% if ansible_distribution_version == "14.04" %}
{# Ubuntu 14.04 conflicts with existing port 80 so we can't include the default #}
Timeout 300
KeepAlive On
MaxKeepAliveRequests 100
KeepAliveTimeout 5
User ${APACHE_RUN_USER}
Group ${APACHE_RUN_GROUP}
HostnameLookups Off
LogLevel warn
LogFormat "%v:%p %h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" vhost_combined
LogFormat "%h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %O" common
LogFormat "%{Referer}i -> %U" referer
LogFormat "%{User-agent}i" agent
IncludeOptional mods-enabled/*.load
IncludeOptional mods-enabled/*.conf
IncludeOptional conf-enabled/*.conf
IncludeOptional sites-enabled/*conf
<FilesMatch "^\.ht">
Require all denied
</FilesMatch>
{% else %}
Include /etc/apache2/apache2.conf
{% endif %}
{% elif ansible_os_family == "FreeBSD" %}
Include /usr/local/etc/apache24/httpd.conf
LoadModule dav_module libexec/apache24/mod_dav.so
LoadModule dav_svn_module libexec/apache24/mod_dav_svn.so
LoadModule authz_svn_module libexec/apache24/mod_authz_svn.so
{% elif ansible_os_family == "Suse" %}
Include /etc/apache2/httpd.conf
LoadModule dav_module /usr/lib64/apache2/mod_dav.so
LoadModule dav_svn_module /usr/lib64/apache2/mod_dav_svn.so
{% elif ansible_os_family == "RedHat" %}
Include /etc/httpd/conf/httpd.conf
{% endif %}
PidFile {{ subversion_server_dir }}/apache.pid
Listen 127.0.0.1:{{ apache_port }}
ErrorLog {{ subversion_server_dir }}/apache2-error.log
<Location /svn>
DAV svn
SVNParentPath {{ subversion_server_dir }}
{% if ansible_distribution == "CentOS" and ansible_distribution_version.startswith("6") %}
Allow from all
{% else %}
Require all granted
{% endif %}
</Location>
<Location /svnauth>
DAV svn
SVNParentPath {{ subversion_server_dir }}
AuthType Basic
AuthName "Subversion repositories"
AuthUserFile {{ subversion_server_dir }}/svn-auth-users
Require valid-user
</Location>

@ -0,0 +1,6 @@
---
subversion_packages:
- subversion
- libapache2-svn
apache_user: www-data
apache_group: www-data

@ -0,0 +1,7 @@
---
subversion_packages:
- apache24
- mod_dav_svn
- subversion
apache_user: www
apache_group: www

@ -0,0 +1,6 @@
---
subversion_packages:
- mod_dav_svn
- subversion
apache_user: apache
apache_group: apache

@ -0,0 +1,6 @@
---
subversion_packages:
- subversion
- subversion-server
apache_user: wwwrun
apache_group: www
Loading…
Cancel
Save