From 496256e21ef1ea45266374288b8aa3a222c4ea89 Mon Sep 17 00:00:00 2001 From: Tom Schierenbeck <60885903+tomsch420@users.noreply.github.com> Date: Tue, 24 Oct 2023 10:38:26 +0200 Subject: [PATCH 1/6] Update README --- README | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/README b/README index abbbffa..0b378df 100644 --- a/README +++ b/README @@ -1,5 +1,5 @@ -Welcome to Random Events' documentation! -========================================= +# Welcome to the Random Events package! + Probabilistic Machine Learning frequently requires descriptions of random variables and events that are shared among many packages. @@ -8,6 +8,4 @@ usable and easily extensible classes. Install the package via -.. code-block:: bash - - pip install random-events + `pip install random-events` From c5db07b62cec3fc7cc047c10ee4cd9b780cd2ab7 Mon Sep 17 00:00:00 2001 From: Tom Schierenbeck <60885903+tomsch420@users.noreply.github.com> Date: Tue, 24 Oct 2023 10:42:39 +0200 Subject: [PATCH 2/6] Update README --- README | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/README b/README index 0b378df..1820f74 100644 --- a/README +++ b/README @@ -1,6 +1,5 @@ # Welcome to the Random Events package! - Probabilistic Machine Learning frequently requires descriptions of random variables and events that are shared among many packages. This package provides a common interface for describing random variables and events, using @@ -8,4 +7,6 @@ usable and easily extensible classes. Install the package via - `pip install random-events` +``` +pip install random-events +``` From baec3f6dc26dabbdec92056260342bf535993240 Mon Sep 17 00:00:00 2001 From: Tom Schierenbeck <60885903+tomsch420@users.noreply.github.com> Date: Tue, 24 Oct 2023 10:44:10 +0200 Subject: [PATCH 3/6] Create python-package.yml --- .github/workflows/python-package.yml | 40 ++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 .github/workflows/python-package.yml diff --git a/.github/workflows/python-package.yml b/.github/workflows/python-package.yml new file mode 100644 index 0000000..17a6911 --- /dev/null +++ b/.github/workflows/python-package.yml @@ -0,0 +1,40 @@ +# This workflow will install Python dependencies, run tests and lint with a variety of Python versions +# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python + +name: Python package + +on: + push: + branches: [ "master" ] + pull_request: + branches: [ "master" ] + +jobs: + build: + + runs-on: ubuntu-latest + strategy: + fail-fast: false + matrix: + python-version: ["3.6", "3.7", "3.8", "3.9", "3.10", "3.11"] + + steps: + - uses: actions/checkout@v3 + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v3 + with: + python-version: ${{ matrix.python-version }} + - name: Install dependencies + run: | + python -m pip install --upgrade pip + python -m pip install flake8 pytest + if [ -f requirements.txt ]; then pip install -r requirements.txt; fi + - 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 + - name: Test with pytest + run: | + pytest From 5d65bee4e25abdd1356bef9a4a4ef7308abc5809 Mon Sep 17 00:00:00 2001 From: Tom Schierenbeck <60885903+tomsch420@users.noreply.github.com> Date: Tue, 24 Oct 2023 10:46:56 +0200 Subject: [PATCH 4/6] Update python-package.yml --- .github/workflows/python-package.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/python-package.yml b/.github/workflows/python-package.yml index 17a6911..26d0fa9 100644 --- a/.github/workflows/python-package.yml +++ b/.github/workflows/python-package.yml @@ -16,7 +16,7 @@ jobs: strategy: fail-fast: false matrix: - python-version: ["3.6", "3.7", "3.8", "3.9", "3.10", "3.11"] + python-version: ["3.8"] steps: - uses: actions/checkout@v3 @@ -37,4 +37,4 @@ jobs: flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics - name: Test with pytest run: | - pytest + python -m unittest discover -s random-events/test -t random-events/test From 9b3f704b6c1dfd4263cd5e7197b8c75b539277d9 Mon Sep 17 00:00:00 2001 From: Tom Schierenbeck <60885903+tomsch420@users.noreply.github.com> Date: Tue, 24 Oct 2023 11:41:23 +0200 Subject: [PATCH 5/6] Update python-package.yml --- .github/workflows/python-package.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/python-package.yml b/.github/workflows/python-package.yml index 26d0fa9..613891c 100644 --- a/.github/workflows/python-package.yml +++ b/.github/workflows/python-package.yml @@ -29,6 +29,7 @@ jobs: python -m pip install --upgrade pip python -m pip install flake8 pytest if [ -f requirements.txt ]; then pip install -r requirements.txt; fi + python setup.py install - name: Lint with flake8 run: | # stop the build if there are Python syntax errors or undefined names @@ -37,4 +38,5 @@ jobs: flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics - name: Test with pytest run: | - python -m unittest discover -s random-events/test -t random-events/test + python -m pytest test + From c8ea4c6fca744c8afd629a8853909da5bc876083 Mon Sep 17 00:00:00 2001 From: Tom Schierenbeck <60885903+tomsch420@users.noreply.github.com> Date: Tue, 24 Oct 2023 11:50:45 +0200 Subject: [PATCH 6/6] Update and rename python-package.yml to test-and-build.yml --- .github/workflows/python-package.yml | 42 --------------- .github/workflows/test-and-build.yml | 81 ++++++++++++++++++++++++++++ 2 files changed, 81 insertions(+), 42 deletions(-) delete mode 100644 .github/workflows/python-package.yml create mode 100644 .github/workflows/test-and-build.yml diff --git a/.github/workflows/python-package.yml b/.github/workflows/python-package.yml deleted file mode 100644 index 613891c..0000000 --- a/.github/workflows/python-package.yml +++ /dev/null @@ -1,42 +0,0 @@ -# This workflow will install Python dependencies, run tests and lint with a variety of Python versions -# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python - -name: Python package - -on: - push: - branches: [ "master" ] - pull_request: - branches: [ "master" ] - -jobs: - build: - - runs-on: ubuntu-latest - strategy: - fail-fast: false - matrix: - python-version: ["3.8"] - - steps: - - uses: actions/checkout@v3 - - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v3 - with: - python-version: ${{ matrix.python-version }} - - name: Install dependencies - run: | - python -m pip install --upgrade pip - python -m pip install flake8 pytest - if [ -f requirements.txt ]; then pip install -r requirements.txt; fi - python setup.py install - - 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 - - name: Test with pytest - run: | - python -m pytest test - diff --git a/.github/workflows/test-and-build.yml b/.github/workflows/test-and-build.yml new file mode 100644 index 0000000..2229f3f --- /dev/null +++ b/.github/workflows/test-and-build.yml @@ -0,0 +1,81 @@ +name: Run tests and build the Python distribution + +on: + push: + branches: + - master + + # -------------------------------------------------------------------------------------------------------------------- + + workflow_call: + inputs: + version: + required: true + type: string + + python-versions: + required: true + type: string + default: "cp38-cp38" + +# ---------------------------------------------------------------------------------------------------------------------- + +defaults: + run: + shell: bash + working-directory: . + +# ---------------------------------------------------------------------------------------------------------------------- + +concurrency: + group: 'random-events-building-and-deployment' + cancel-in-progress: true + +# ---------------------------------------------------------------------------------------------------------------------- + +jobs: + test-and-build: + name: Build and Test the Python distribution + runs-on: ubuntu-22.04 + + steps: + + - name: Checkout 🛎 + uses: actions/checkout@v3 + + # ---------------------------------------------------------------------------------------------------------------- + + - name: Setup python 🐍 + uses: actions/setup-python@v4 + with: + python-version: 3.8 + cache: pip + + # ---------------------------------------------------------------------------------------------------------------- + + - name: Install user dependencies 🍼 + uses: py-actions/py-dependency-install@v4 + with: + path: "requirements.txt" + + # ---------------------------------------------------------------------------------------------------------------- + + - name: Run Tests 🎓 + run: | + cd test + PYTHONPATH=../src python -m unittest discover + + # ---------------------------------------------------------------------------------------------------------------- + + - name: Install Sphinx dependencies 📚 + uses: py-actions/py-dependency-install@v4 + with: + path: "doc/requirements.txt" + + # ---------------------------------------------------------------------------------------------------------------- + + - name: Build Sphinx documentation 📝 + working-directory: ./doc + run: | + sudo apt install pandoc + make html