Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 21 additions & 0 deletions .github/workflows/ansible-deploy.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
name: Ansible Deployment

on:
push:
branches: [master, lab06]

jobs:
lint:
name: Ansible Lint
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: '3.12'
- name: Install Ansible and ansible-lint
run: pip install ansible ansible-lint
- name: Run ansible-lint
run: |
cd ansible
ansible-lint playbooks/provision.yml playbooks/deploy.yml playbooks/site.yml
206 changes: 103 additions & 103 deletions .github/workflows/python-ci.yml
Original file line number Diff line number Diff line change
@@ -1,103 +1,103 @@
name: Python CI (tests + docker)

on:
push:
branches: [ "master", "lab03" ]
paths:
- "app_python/**"
- ".github/workflows/python-ci.yml"
pull_request:
branches: [ "master" ]
paths:
- "app_python/**"
- ".github/workflows/python-ci.yml"

concurrency:
group: python-ci-${{ github.ref }}
cancel-in-progress: true

permissions:
contents: read

jobs:
test-and-lint:
runs-on: ubuntu-latest

strategy:
fail-fast: true
matrix:
python-version: ["3.12", "3.13"]

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: "pip"
cache-dependency-path: |
app_python/requirements.txt
app_python/requirements-dev.txt

- name: Install dependencies
working-directory: app_python
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
pip install -r requirements-dev.txt

- name: Lint (ruff)
working-directory: app_python
run: |
ruff check .

- name: Run tests (pytest)
working-directory: app_python
run: |
pytest -q

- name: Install Snyk CLI
run: npm install -g snyk

- name: Snyk scan (dependencies)
continue-on-error: true
env:
SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }}
run: |
cd app_python
snyk test --severity-threshold=high --file=requirements.txt

docker-build-and-push:
runs-on: ubuntu-latest
needs: test-and-lint

if: github.event_name == 'push' && (github.ref == 'refs/heads/master' || github.ref == 'refs/heads/lab03')

permissions:
contents: read

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Set version (CalVer)
run: |
echo "VERSION=$(date -u +%Y.%m.%d)" >> $GITHUB_ENV

- name: Log in to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Build and push
uses: docker/build-push-action@v6
with:
context: ./app_python
file: ./app_python/Dockerfile
push: true
tags: |
${{ secrets.DOCKERHUB_USERNAME }}/devops-info-service:${{ env.VERSION }}
${{ secrets.DOCKERHUB_USERNAME }}/devops-info-service:latest
name: Python CI (tests + docker)
on:
push:
branches: [ "master", "lab03" ]
paths:
- "app_python/**"
- ".github/workflows/python-ci.yml"
pull_request:
branches: [ "master" ]
paths:
- "app_python/**"
- ".github/workflows/python-ci.yml"
concurrency:
group: python-ci-${{ github.ref }}
cancel-in-progress: true
permissions:
contents: read
jobs:
test-and-lint:
runs-on: ubuntu-latest
strategy:
fail-fast: true
matrix:
python-version: ["3.12", "3.13"]
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: "pip"
cache-dependency-path: |
app_python/requirements.txt
app_python/requirements-dev.txt
- name: Install dependencies
working-directory: app_python
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
pip install -r requirements-dev.txt
- name: Lint (ruff)
working-directory: app_python
run: |
ruff check .
- name: Run tests (pytest)
working-directory: app_python
run: |
pytest -q
- name: Install Snyk CLI
run: npm install -g snyk
- name: Snyk scan (dependencies)
continue-on-error: true
env:
SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }}
run: |
cd app_python
snyk test --severity-threshold=high --file=requirements.txt
docker-build-and-push:
runs-on: ubuntu-latest
needs: test-and-lint
if: github.event_name == 'push' && (github.ref == 'refs/heads/master' || github.ref == 'refs/heads/lab03')
permissions:
contents: read
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set version (CalVer)
run: |
echo "VERSION=$(date -u +%Y.%m.%d)" >> $GITHUB_ENV
- name: Log in to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v6
with:
context: ./app_python
file: ./app_python/Dockerfile
push: true
tags: |
${{ secrets.DOCKERHUB_USERNAME }}/devops-info-service:${{ env.VERSION }}
${{ secrets.DOCKERHUB_USERNAME }}/devops-info-service:latest
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1 @@
test
test.vault_pass
Loading