mirror of
https://github.com/GeekOops/geekoops-pureftpd.git
synced 2024-05-19 22:12:23 +00:00
Add GitHub Actions
Add GitHub Actions as CI.
This commit is contained in:
parent
18e633881d
commit
d5050318cd
42
.github/workflows/CI.yml
vendored
Normal file
42
.github/workflows/CI.yml
vendored
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
---
|
||||||
|
name: Test deployment
|
||||||
|
'on':
|
||||||
|
pull_request:
|
||||||
|
push:
|
||||||
|
schedule:
|
||||||
|
# Run every Wednesday at 01:42
|
||||||
|
- cron: "42 1 * * 3"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lint:
|
||||||
|
name: Lint
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Check out codebase
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Set up Python
|
||||||
|
uses: actions/setup-python@v2
|
||||||
|
with:
|
||||||
|
python-version: '3.x'
|
||||||
|
- name: Install dependencies
|
||||||
|
run: pip3 install yamllint
|
||||||
|
- name: Lint repository
|
||||||
|
run: yamllint .
|
||||||
|
|
||||||
|
molecule:
|
||||||
|
name: Molecule
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Check out the codebase
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Set up Python
|
||||||
|
uses: actions/setup-python@v2
|
||||||
|
with:
|
||||||
|
python-version: '3.x'
|
||||||
|
- name: Install dependencies
|
||||||
|
run: pip3 install ansible molecule[docker] docker pytest testinfra
|
||||||
|
- name: Run Molecule
|
||||||
|
run: molecule test
|
||||||
|
env:
|
||||||
|
PY_COLORS: '1'
|
||||||
|
ANSIBLE_FORCE_COLOR: '1'
|
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
# Python cache
|
||||||
|
__pycache__
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
|
|
||||||
- name: restart pureftpd
|
- name: restart pureftpd
|
||||||
service:
|
systemd:
|
||||||
name: "{{pureftpd_service}}"
|
name: "{{pureftpd_service}}"
|
||||||
state: restarted
|
state: restarted
|
||||||
|
|
||||||
|
|
25
molecule/default/converge.yml
Normal file
25
molecule/default/converge.yml
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
---
|
||||||
|
- name: Converge
|
||||||
|
hosts: all
|
||||||
|
tasks:
|
||||||
|
- name: "Include geekoops-pureftpd"
|
||||||
|
include_role:
|
||||||
|
name: "geekoops-pureftpd"
|
||||||
|
## Setup test enviroment
|
||||||
|
# Test file 1 is accessible (0754), test file 2 not (0750)
|
||||||
|
- name: Deploy test file
|
||||||
|
copy:
|
||||||
|
content: |
|
||||||
|
Happy test file
|
||||||
|
dest: "{{ftp_dir}}/testfile.txt"
|
||||||
|
group: "root"
|
||||||
|
owner: "root"
|
||||||
|
mode: 0754
|
||||||
|
- name: Deploy secrets test file
|
||||||
|
copy:
|
||||||
|
content: |
|
||||||
|
Password: 12345
|
||||||
|
dest: "{{ftp_dir}}/secrets.txt"
|
||||||
|
group: "root"
|
||||||
|
owner: "root"
|
||||||
|
mode: 0750
|
30
molecule/default/molecule.yml
Normal file
30
molecule/default/molecule.yml
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
---
|
||||||
|
dependency:
|
||||||
|
name: galaxy
|
||||||
|
driver:
|
||||||
|
name: docker
|
||||||
|
platforms:
|
||||||
|
- name: leap15_2
|
||||||
|
image: grisu48/leap-ansible
|
||||||
|
pre_build_image: true
|
||||||
|
volumes:
|
||||||
|
- /sys/fs/cgroup:/sys/fs/cgroup:ro
|
||||||
|
capabilities:
|
||||||
|
- SYS_ADMIN
|
||||||
|
privileged: true
|
||||||
|
tmpfs:
|
||||||
|
- /run
|
||||||
|
- /tmp
|
||||||
|
provisioner:
|
||||||
|
name: ansible
|
||||||
|
inventory:
|
||||||
|
host_vars:
|
||||||
|
leap15_2:
|
||||||
|
ftp_dir: "/srv/ftp"
|
||||||
|
verifier:
|
||||||
|
name: testinfra
|
||||||
|
lint:
|
||||||
|
name: flake8
|
||||||
|
lint: |
|
||||||
|
set -e
|
||||||
|
yamllint .
|
17
molecule/default/tests/test_default.py
Executable file
17
molecule/default/tests/test_default.py
Executable file
|
@ -0,0 +1,17 @@
|
||||||
|
#!/usr/bin/python3
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
|
||||||
|
import testinfra.utils.ansible_runner
|
||||||
|
import os
|
||||||
|
|
||||||
|
testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(os.environ['MOLECULE_INVENTORY_FILE']).get_hosts('all')
|
||||||
|
|
||||||
|
def test_ftp(host):
|
||||||
|
cmd = host.run("curl -v ftp://127.0.0.1/testfile.txt")
|
||||||
|
assert cmd.succeeded
|
||||||
|
assert "Happy test file" in cmd.stdout
|
||||||
|
cmd = host.run("curl -v ftp://127.0.0.1/secrets.txt")
|
||||||
|
assert cmd.failed
|
||||||
|
assert "550" in cmd.stderr
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
---
|
---
|
||||||
# Configure firewall
|
# Configure firewall
|
||||||
|
|
||||||
- name: Ensure ftp service is enabled
|
- name: Ensure ftp is enabled in firewall
|
||||||
firewalld:
|
firewalld:
|
||||||
zone: "{{firewall_zone}}"
|
zone: "{{firewall_zone}}"
|
||||||
service: ftp
|
service: ftp
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
group: root
|
group: root
|
||||||
mode: 0744
|
mode: 0744
|
||||||
notify: restart pureftpd
|
notify: restart pureftpd
|
||||||
- name: Ensure PureFTPd service is enabled
|
- name: Ensure PureFTPd service is started and enabled
|
||||||
systemd:
|
systemd:
|
||||||
name: "{{pureftpd_service}}"
|
name: "{{pureftpd_service}}"
|
||||||
state: started
|
state: started
|
||||||
|
|
Loading…
Reference in a new issue