-
Notifications
You must be signed in to change notification settings - Fork 8
97 lines (82 loc) · 3.57 KB
/
ci.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
name: Build Pipeline
on: [ push ]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
# This allows the pipeline to be run against multiple Python versions. eg. [3.6, 3.7, 3.8, 3.9, 3.10]. This results
# in linting and unit tests running for all listed versions as well as the creation of packages and wheels on
# creation of a tag in Git.
python-version: [ "3.8", "3.9", "3.10", "3.11", "3.12" ]
steps:
# Get the code from the repository to be packaged
- name: Get Repo
uses: actions/checkout@v3
# Setup the Python environment (currently Python 2.7). This will need to be
# updated when the project is upgraded to Python 3.x
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
# Install the packages to build the SQLite Dissect package
- name: Prepare Build Environment
run: |
sudo apt install python3-setuptools
python -m pip install -q --upgrade pip
pip install .
pip install -q flake8 pytest pytest-cov build twine wheel
# Lint the Python code to check for syntax errors
- name: Lint with Flake8
run: |
# stop the build if there are Python syntax errors or undefined names
flake8 . --count --select=E9,F63,F7,F82 --show-source --statistics
# exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics
# Test the Python unit tests
- name: PyTest
run: |
# Create the directory for the test output
mkdir output
# Run the test suite
pytest --cov-report term-missing --cov-report html --cov=sqlite_dissect --cov-config=.coveragerc
# Run the CASE validation job to confirm the output is valid
- name: CASE Export Validation
uses: kchason/case-validation-action@v2.5
with:
case-path: ./output/case.json
case-version: "case-1.1.0"
# Upload the PyTest HTML coverage report for review
- name: Upload PyTest Coverage
uses: actions/upload-artifact@v3
with:
name: code-coverage-report
path: htmlcov
# Build the Sphinx documentation into a PDF for easier distribution
- name: Build Documentation
run: |
pip install -q sphinx
pip install -q sphinx-rtd-theme
sphinx-build -b html ./docs/source/ ./docs/build/
# Upload the HTML documentation for distribution
- name: Upload HTML Docs
uses: actions/upload-artifact@v3
with:
name: html-docs
path: ./docs/build/
# Build the binary wheel as well as the source tar
- name: Build Objects
if: startsWith(github.ref, 'refs/tags')
run: python setup.py sdist bdist_wheel
env:
TAG_VERSION: "${GITHUB_REF#refs/*/}"
# Ensure the objects were packaged correctly and there wasn't an issue with
# the compilation or packaging process.
- name: Check Objects
if: startsWith(github.ref, 'refs/tags')
run: twine check dist/*
# If this commit is the result of a Git tag, push the wheel and tar packages
# to the PyPi registry
- name: Publish to PyPI
if: startsWith(github.ref, 'refs/tags')
run: twine upload --repository-url https://upload.pypi.org/legacy/ -u __token__ -p ${{ secrets.PYPI_API_TOKEN }} --skip-existing --verbose dist/*