commit 57e5e1e055282a94c3a89d84b2447fcc0fe9efcb Author: Paul Belanger Date: Tue Sep 8 16:10:12 2015 -0400 Initial commit Signed-off-by: Paul Belanger diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..e76944e --- /dev/null +++ b/.travis.yml @@ -0,0 +1,31 @@ +--- +language: python +python: "2.7" + +env: + global: + - ANSIBLE_CONFIG=tests/ansible.cfg + matrix: + - SITE=test001.yaml + - SITE=test002.yaml + +before_install: + - sudo apt-get update -qq + +install: + # Install Ansible. + - pip install ansible + +script: + # Check the role/playbook's syntax. + - "ansible-playbook -i tests/inventory tests/$SITE --syntax-check" + + # Run the role/playbook with ansible-playbook. + - "ansible-playbook -i tests/inventory tests/$SITE --connection=local --sudo" + + # Run the role/playbook again, checking to make sure it's idempotent. + - > + ansible-playbook -i tests/inventory tests/$SITE --connection=local --sudo + || grep -q 'changed=0.*failed=0' + && (echo 'Idempotence test: pass' && exit 0) + || (echo 'Idempotence test: fail' && exit 1) diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..d645695 --- /dev/null +++ b/LICENSE @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + 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. diff --git a/README.rst b/README.rst new file mode 100644 index 0000000..2bb40a1 --- /dev/null +++ b/README.rst @@ -0,0 +1,33 @@ +zuul +==== + +Requirements +------------ + +Role Variables +-------------- + +Dependencies +------------ + +Example Playbook +---------------- + +License +------- + Copyright 2015 Paul Belanger + + 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. + +Author Information +------------------ diff --git a/defaults/main.yaml b/defaults/main.yaml new file mode 100644 index 0000000..0fad875 --- /dev/null +++ b/defaults/main.yaml @@ -0,0 +1,34 @@ +--- +# tasks/config.yaml +zuul_config_gearman_port: 4730 +zuul_config_gearman_server: localhost + +zuul_config_gearman_server_start: true +zuul_config_gearman_server_listen_address: 0.0.0.0 +zuul_config_gearman_server_log_config: /etc/zuul/gearman-logging.conf + +zuul_config_gerrit_port: 29418 +zuul_config_gerrit_server: localhost +zuul_config_gerrit_sshkey: /var/lib/zuul/.ssh/id_rsa +zuul_config_gerrit_user: zuul + +zuul_config_merger_git_dir: /var/lib/zuul/git +zuul_config_merger_log_config: /etc/zuul/merger-logging.conf +zuul_config_merger_zuul_url: localhost + +zuul_config_zuul_log_config: /etc/zuul/server-logging.conf + +zuul_file_gearman_logging_conf: etc/zuul/gearman-logging.conf +zuul_file_merger_logging_conf: etc/zuul/merger-logging.conf +zuul_file_server_logging_conf: etc/zuul/server-logging.conf + +zuul_ssh_private_key: + +# tasks/install.yaml +zuul_git_dest: /opt/git/openstack-infra/zuul +zuul_git_uri: https://git.openstack.org/openstack-infra/zuul +zuul_git_version: master + +zuul_install_method: git + +zuul_pip_version: diff --git a/files/etc/zuul/gearman-logging.conf b/files/etc/zuul/gearman-logging.conf new file mode 100644 index 0000000..b613c8b --- /dev/null +++ b/files/etc/zuul/gearman-logging.conf @@ -0,0 +1,39 @@ +[loggers] +keys=root,gear + +[handlers] +keys=console,debug,normal + +[formatters] +keys=simple + +[logger_root] +level=WARNING +handlers=console + +[logger_gear] +level=DEBUG +handlers=debug,normal +qualname=gear + +[handler_console] +level=WARNING +class=StreamHandler +formatter=simple +args=(sys.stdout,) + +[handler_debug] +level=DEBUG +class=logging.handlers.WatchedFileHandler +formatter=simple +args=('/var/log/zuul/gearman-debug.log',) + +[handler_normal] +level=WARNING +class=logging.handlers.WatchedFileHandler +formatter=simple +args=('/var/log/zuul/gearman.log',) + +[formatter_simple] +format=%(asctime)s %(levelname)s %(name)s: %(message)s +datefmt= diff --git a/files/etc/zuul/merger-logging.conf b/files/etc/zuul/merger-logging.conf new file mode 100644 index 0000000..1807f2a --- /dev/null +++ b/files/etc/zuul/merger-logging.conf @@ -0,0 +1,49 @@ +[loggers] +keys=root,zuul,gerrit,gear + +[handlers] +keys=console,debug,normal + +[formatters] +keys=simple + +[logger_root] +level=WARNING +handlers=console + +[logger_zuul] +level=DEBUG +handlers=debug,normal +qualname=zuul + +[logger_gerrit] +level=INFO +handlers=debug,normal +qualname=gerrit + +[logger_gear] +level=WARNING +handlers=debug,normal +qualname=gear + +[handler_console] +level=WARNING +class=StreamHandler +formatter=simple +args=(sys.stdout,) + +[handler_debug] +level=DEBUG +class=logging.handlers.WatchedFileHandler +formatter=simple +args=('/var/log/zuul/merger-debug.log',) + +[handler_normal] +level=INFO +class=logging.handlers.WatchedFileHandler +formatter=simple +args=('/var/log/zuul/merger.log',) + +[formatter_simple] +format=%(asctime)s %(levelname)s %(name)s: %(message)s +datefmt= diff --git a/files/etc/zuul/server-logging.conf b/files/etc/zuul/server-logging.conf new file mode 100644 index 0000000..742ba13 --- /dev/null +++ b/files/etc/zuul/server-logging.conf @@ -0,0 +1,49 @@ +[loggers] +keys=root,zuul,gerrit,gear + +[handlers] +keys=console,debug,normal + +[formatters] +keys=simple + +[logger_root] +level=WARNING +handlers=console + +[logger_zuul] +level=DEBUG +handlers=debug,normal +qualname=zuul + +[logger_gerrit] +level=INFO +handlers=debug,normal +qualname=gerrit + +[logger_gear] +level=WARNING +handlers=debug,normal +qualname=gear + +[handler_console] +level=WARNING +class=StreamHandler +formatter=simple +args=(sys.stdout,) + +[handler_debug] +level=DEBUG +class=logging.handlers.WatchedFileHandler +formatter=simple +args=('/var/log/zuul/server-debug.log',) + +[handler_normal] +level=INFO +class=logging.handlers.WatchedFileHandler +formatter=simple +args=('/var/log/zuul/server.log',) + +[formatter_simple] +format=%(asctime)s %(levelname)s %(name)s: %(message)s +datefmt= diff --git a/files/zuul-merger.service b/files/zuul-merger.service new file mode 100644 index 0000000..2ed5fba --- /dev/null +++ b/files/zuul-merger.service @@ -0,0 +1,12 @@ +[Unit] +Description=Zuul Merger Service + +[Service] +Type=simple +User=zuul +Group=zuul +EnvironmentFile=-/etc/sysconfig/zuul +ExecStart=/usr/bin/zuul-merger -d + +StandardOutput=syslog +StandardError=syslog diff --git a/files/zuul-server.service b/files/zuul-server.service new file mode 100644 index 0000000..46e1c2c --- /dev/null +++ b/files/zuul-server.service @@ -0,0 +1,12 @@ +[Unit] +Description=Zuul Server Service + +[Service] +Type=simple +User=zuul +Group=zuul +EnvironmentFile=-/etc/sysconfig/zuul +ExecStart=/usr/bin/zuul-server -d + +StandardOutput=syslog +StandardError=syslog diff --git a/files/zuul.sysconfig b/files/zuul.sysconfig new file mode 100644 index 0000000..e69de29 diff --git a/handlers/main.yaml b/handlers/main.yaml new file mode 100644 index 0000000..e0d4934 --- /dev/null +++ b/handlers/main.yaml @@ -0,0 +1,12 @@ +--- +- name: Restart zuul-merger + service: + name: zuul-merger + state: restarted + sudo: yes + +- name: Restart zuul-server + service: + name: zuul-server + state: restarted + sudo: yes diff --git a/meta/main.yaml b/meta/main.yaml new file mode 100644 index 0000000..62c7d35 --- /dev/null +++ b/meta/main.yaml @@ -0,0 +1,139 @@ +--- +galaxy_info: + author: your name + description: + company: your company (optional) + # If the issue tracker for your role is not on github, uncomment the + # next line and provide a value + # issue_tracker_url: http://example.com/issue/tracker + # Some suggested licenses: + # - BSD (default) + # - MIT + # - GPLv2 + # - GPLv3 + # - Apache + # - CC-BY + license: license (GPLv2, CC-BY, etc) + min_ansible_version: 1.2 + # + # Below are all platforms currently available. Just uncomment + # the ones that apply to your role. If you don't see your + # platform on this list, let us know and we'll get it added! + # + #platforms: + #- name: EL + # versions: + # - all + # - 5 + # - 6 + # - 7 + #- name: GenericUNIX + # versions: + # - all + # - any + #- name: Fedora + # versions: + # - all + # - 16 + # - 17 + # - 18 + # - 19 + # - 20 + # - 21 + # - 22 + #- name: Windows + # versions: + # - all + # - 2012R2 + #- name: SmartOS + # versions: + # - all + # - any + #- name: opensuse + # versions: + # - all + # - 12.1 + # - 12.2 + # - 12.3 + # - 13.1 + # - 13.2 + #- name: Amazon + # versions: + # - all + # - 2013.03 + # - 2013.09 + #- name: GenericBSD + # versions: + # - all + # - any + #- name: FreeBSD + # versions: + # - all + # - 8.0 + # - 8.1 + # - 8.2 + # - 8.3 + # - 8.4 + # - 9.0 + # - 9.1 + # - 9.1 + # - 9.2 + #- name: Ubuntu + # versions: + # - all + # - lucid + # - maverick + # - natty + # - oneiric + # - precise + # - quantal + # - raring + # - saucy + # - trusty + # - utopic + # - vivid + #- name: SLES + # versions: + # - all + # - 10SP3 + # - 10SP4 + # - 11 + # - 11SP1 + # - 11SP2 + # - 11SP3 + #- name: GenericLinux + # versions: + # - all + # - any + #- name: Debian + # versions: + # - all + # - etch + # - jessie + # - lenny + # - squeeze + # - wheezy + # + # Below are all categories currently available. Just as with + # the platforms above, uncomment those that apply to your role. + # + #categories: + #- cloud + #- cloud:ec2 + #- cloud:gce + #- cloud:rax + #- clustering + #- database + #- database:nosql + #- database:sql + #- development + #- monitoring + #- networking + #- packaging + #- system + #- web +dependencies: [] + # List your role dependencies here, one per line. + # Be sure to remove the '[]' above if you add dependencies + # to this list. + diff --git a/tasks/config.yaml b/tasks/config.yaml new file mode 100644 index 0000000..aafad39 --- /dev/null +++ b/tasks/config.yaml @@ -0,0 +1,64 @@ +--- +- name: Create system user account. + user: + createhome: yes + home: /var/lib/zuul + name: zuul + +- name: Ensure .ssh directory exists. + file: + dest: /var/lib/zuul/.ssh + group: zuul + mode: 0700 + owner: zuul + state: directory + +- name: Create ssh known hosts. + copy: + content: "{{ zuul_ssh_known_hosts }}" + dest: /var/lib/zuul/.ssh/known_hosts + group: zuul + mode: 0600 + owner: zuul + +- name: Create ssh private key. + copy: + content: "{{ zuul_ssh_private_key }}" + dest: /var/lib/zuul/.ssh/id_rsa + group: zuul + mode: 0600 + owner: zuul + +- name: Create required directories. + file: + group: zuul + owner: zuul + path: "{{ item }}" + state: directory + with_items: + - /etc/zuul + - /var/log/zuul + +- name: Template zuul configuration file. + template: + dest: /etc/zuul/zuul.conf + src: zuul.conf.j2 + notify: Restart zuul-server + +- name: Copy gearman logging file. + copy: + dest: "{{ zuul_config_gearman_server_log_config }}" + src: "{{ zuul_file_gearman_logging_conf }}" + notify: Restart zuul-server + +- name: Copy merger logging file. + copy: + dest: "{{ zuul_config_merger_log_config }}" + src: "{{ zuul_file_merger_logging_conf }}" + notify: Restart zuul-merger + +- name: Copy server logging file. + copy: + dest: "{{ zuul_config_zuul_log_config }}" + src: "{{ zuul_file_server_logging_conf }}" + notify: Restart zuul-server diff --git a/tasks/install.yaml b/tasks/install.yaml new file mode 100644 index 0000000..f4e5554 --- /dev/null +++ b/tasks/install.yaml @@ -0,0 +1,17 @@ +--- +- name: Define zuul_build_depends. + set_fact: + zuul_build_depends: "{{ __zuul_build_depends | list }}" + when: zuul_build_depends is not defined + +- include: install/debian.yaml + when: ansible_os_family == 'Debian' + +- include: install/redhat.yaml + when: ansible_os_family == 'RedHat' + +- include: install/git.yaml + when: zuul_install_method == 'git' + +- include: install/pip.yaml + when: zuul_install_method == 'pip' diff --git a/tasks/install/debian.yaml b/tasks/install/debian.yaml new file mode 100644 index 0000000..c99e604 --- /dev/null +++ b/tasks/install/debian.yaml @@ -0,0 +1,5 @@ +--- +- name: Ensure build dependencies are installed. + apt: "pkg={{ item }} state=installed" + with_items: zuul_build_depends + when: zuul_install_method == 'git' or zuul_install_method == 'pip' diff --git a/tasks/install/git.yaml b/tasks/install/git.yaml new file mode 100644 index 0000000..ba065a7 --- /dev/null +++ b/tasks/install/git.yaml @@ -0,0 +1,10 @@ +--- +- name: Git clone zuul. + git: + dest: "{{ zuul_git_dest }}" + repo: "{{ zuul_git_uri }}" + version: "{{ zuul_git_version }}" + +- name: Pip install zuul from local git repo. + pip: + name: "file://{{ zuul_git_dest }}" diff --git a/tasks/install/pip.yaml b/tasks/install/pip.yaml new file mode 100644 index 0000000..8097496 --- /dev/null +++ b/tasks/install/pip.yaml @@ -0,0 +1,11 @@ +--- +- name: Install zuul using pip. + pip: + name: zuul + when: zuul_pip_version is none + +- name: Install zuul using pip. + pip: + name: zuul + version: "{{ zuul_pip_version }}" + when: zuul_pip_version is not none diff --git a/tasks/install/redhat.yaml b/tasks/install/redhat.yaml new file mode 100644 index 0000000..d38cb55 --- /dev/null +++ b/tasks/install/redhat.yaml @@ -0,0 +1,12 @@ +--- +# NOTE(pabelanger): This needs to be here for now, since we need python-pip. +- name: Ensure EPEL is enabled. + yum: + pkg: epel-release + state: installed + when: zuul_install_method == 'git' or zuul_install_method == 'pip' + +- name: Ensure build dependencies are installed. + yum: "pkg={{ item }} state=installed" + with_items: zuul_build_depends + when: zuul_install_method == 'git' or zuul_install_method == 'pip' diff --git a/tasks/main.yaml b/tasks/main.yaml new file mode 100644 index 0000000..342e42a --- /dev/null +++ b/tasks/main.yaml @@ -0,0 +1,15 @@ +--- +- name: Include OS-specific variables. + include_vars: "{{ ansible_os_family }}.yaml" + +- name: Include zuul configuration defaults. + include_vars: zuul.yaml + +- include: install.yaml + sudo: yes + +- include: config.yaml + sudo: yes + +- include: service.yaml + sudo: yes diff --git a/tasks/service.yaml b/tasks/service.yaml new file mode 100644 index 0000000..15177b1 --- /dev/null +++ b/tasks/service.yaml @@ -0,0 +1,3 @@ +--- +- include: service/redhat.yaml + when: ansible_os_family == 'RedHat' diff --git a/tasks/service/redhat.yaml b/tasks/service/redhat.yaml new file mode 100644 index 0000000..d80ca6e --- /dev/null +++ b/tasks/service/redhat.yaml @@ -0,0 +1,27 @@ +--- +- name: Copy systemd file into place for zuul-merger. + copy: + dest: /etc/systemd/system + src: ../../files/zuul-merger.service + +- name: Copy systemd file into place for zuul-server. + copy: + dest: /etc/systemd/system + src: ../../files/zuul-server.service + +- name: Copy sysconfig file into place. + copy: + dest: /etc/sysconfig/zuul + src: ../../files/zuul.sysconfig + +- name: Enable zuul-merger service. + service: + enabled: yes + name: zuul-merger + state: started + +- name: Enable zuul-server service. + service: + enabled: yes + name: zuul-server + state: started diff --git a/templates/zuul.conf.j2 b/templates/zuul.conf.j2 new file mode 100644 index 0000000..efc112b --- /dev/null +++ b/templates/zuul.conf.j2 @@ -0,0 +1,25 @@ +[gearman] +port = {{ zuul_config_gearman_port }} +server = {{ zuul_config_gearman_server }} + +[gearman_server] +listen_address = {{ zuul_config_gearman_server_listen_address }} +log_config = {{ zuul_config_gearman_server_log_config }} +start = {{ zuul_config_gearman_server_start }} + +[gerrit] +port = {{ zuul_config_gerrit_port }} +server = {{ zuul_config_gerrit_server }} +sshkey = {{ zuul_config_gerrit_sshkey }} +user = {{ zuul_config_gerrit_user }} + +[zuul] +log_config = {{ zuul_config_zuul_log_config }} +state_dir = /var/lib/zuul + +[merger] +git_dir = {{ zuul_config_merger_git_dir }} +log_config = {{ zuul_config_merger_log_config }} +zuul_url = {{ zuul_config_merger_zuul_url }} + +# {{ ansible_managed }} diff --git a/tests/ansible.cfg b/tests/ansible.cfg new file mode 100644 index 0000000..2d4c5f9 --- /dev/null +++ b/tests/ansible.cfg @@ -0,0 +1,2 @@ +[defaults] +roles_path = .. diff --git a/tests/inventory b/tests/inventory new file mode 100644 index 0000000..2fbb50c --- /dev/null +++ b/tests/inventory @@ -0,0 +1 @@ +localhost diff --git a/tests/test001.yaml b/tests/test001.yaml new file mode 100644 index 0000000..93620a1 --- /dev/null +++ b/tests/test001.yaml @@ -0,0 +1,4 @@ +--- +- hosts: localhost + roles: + - ansible-role-zuul diff --git a/tests/test002.yaml b/tests/test002.yaml new file mode 100644 index 0000000..b7be304 --- /dev/null +++ b/tests/test002.yaml @@ -0,0 +1,4 @@ +--- +- hosts: localhost + roles: + - { role: ansible-role-zuul, zuul_install_method: 'pip' } diff --git a/vars/Debian.yaml b/vars/Debian.yaml new file mode 100644 index 0000000..dfbb109 --- /dev/null +++ b/vars/Debian.yaml @@ -0,0 +1,5 @@ +--- +__zuul_build_depends: + - git + - python-dev + - python-pip diff --git a/vars/RedHat.yaml b/vars/RedHat.yaml new file mode 100644 index 0000000..7bba169 --- /dev/null +++ b/vars/RedHat.yaml @@ -0,0 +1,7 @@ +--- +__zuul_build_depends: + - gcc + - gcc-c++ + - git + - python-devel + - python-pip diff --git a/vars/zuul.yaml b/vars/zuul.yaml new file mode 100644 index 0000000..ed97d53 --- /dev/null +++ b/vars/zuul.yaml @@ -0,0 +1 @@ +---