Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Restructure project to use pyproject.toml #712

Closed
wants to merge 32 commits into from
Closed
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
a6b5c50
adopt pyproject.toml
semuadmin Mar 31, 2023
b7e27d7
remove older python envs
semuadmin Apr 1, 2023
8d1fad3
update gitignore
semuadmin Apr 1, 2023
4f7755c
update Vagrant vm.box to ubuntu bionic
semuadmin Apr 1, 2023
91aa2bc
add PySocks dependency
semuadmin Apr 1, 2023
630ba78
fix existing typo in Manifest
semuadmin Apr 1, 2023
5c20bac
add EPL-2.0 license classifier
semuadmin Apr 1, 2023
8811046
add sdist build
semuadmin Apr 1, 2023
8c62f82
minor updates to build tasks & gitignore
semuadmin Apr 2, 2023
5315296
fix typo in pylint task
semuadmin Apr 16, 2023
05a9443
add blank lines to keep GitHub happy
semuadmin Apr 16, 2023
b9e9221
add blank line to keep GitHub happy
semuadmin Apr 16, 2023
f8bfd5a
update tox.yml
semuadmin Apr 16, 2023
2de3d69
update GHA tasks
semuadmin Apr 16, 2023
33d4d3b
update lint_python GHA
semuadmin Apr 18, 2023
36c3dc5
update lint-python GHA again
semuadmin Apr 18, 2023
fe77a34
update pyupgrade step to py37
semuadmin Apr 18, 2023
de6da51
update for PEP660 compatibility
semuadmin Apr 18, 2023
5816a97
update package order
semuadmin Apr 18, 2023
2307dd0
add pyproject.toml tool sections
semuadmin Apr 23, 2023
dd9d4b2
update gha and vscode task toml
semuadmin Apr 23, 2023
d2ac824
fix exit-zero value
semuadmin Apr 23, 2023
e1b3811
Update .github/workflows/lint-python.yml
semuadmin Apr 23, 2023
911a37e
use long args, remove requirements*.txt
semuadmin Apr 23, 2023
4269ba6
fix typo
semuadmin Apr 23, 2023
d266897
update comment
semuadmin Apr 23, 2023
da6403f
deploy deps
semuadmin Apr 23, 2023
f9ae001
add bandit to test deps
semuadmin Apr 23, 2023
bbfcd03
add pyversion to pylint task
semuadmin Apr 23, 2023
3040cc0
update lint gha to use discrete steps
semuadmin Apr 23, 2023
c2dba1a
remove exit-zero
semuadmin Apr 23, 2023
516bf4d
remove coverage options
semuadmin Apr 25, 2023
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
23 changes: 13 additions & 10 deletions .github/workflows/lint-python.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,21 @@ jobs:
lint_python:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/setup-python@v2
- run: pip install bandit black codespell flake8 isort mypy pytest pyupgrade safety
- run: bandit --recursive --skip B101,B105,B106,B110,B303,B404,B603 .
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
- run: pip install -r requirements_build.txt
- run: bandit -c pyproject.toml -r .
- run: black --check . || true
- run: codespell || true # --ignore-words-list="" --skip=""
- run: codespell || true
# flake8 doesn't currently support pyproject.toml config - there is a wrapper pflake8 which does
- run: flake8 . --count --select=E9,F63,F7,F82 --show-source --statistics
- run: flake8 . --count --exit-zero --max-complexity=29 --max-line-length=167 --show-source --statistics
- run: isort --check-only --profile black .
- run: pip install -e .
- run: mypy --ignore-missing-imports . || true
- run: mv setup.cfg setup.cfg.disabled
- run: isort -c .
semuadmin marked this conversation as resolved.
Show resolved Hide resolved
- run: pip install -editable . # will require build backend support for PEP660 (setuptools >= 64)
semuadmin marked this conversation as resolved.
Show resolved Hide resolved
- run: mypy . || true
- run: pytest .
- run: shopt -s globstar && pyupgrade --py36-plus **/*.py || true
# - run: pytest --ignore=tests/test_client.py --ignore=tests/test_websocket_integration.py
# - run: pytest tests/test_websocket_integration.py || true # Todo: Fix these failing tests
# - run: pytest tests/test_client.py || true # Todo: Fix these failing tests
- run: shopt -s globstar && pyupgrade --py37-plus **/*.py || true
- run: safety check
8 changes: 3 additions & 5 deletions .github/workflows/tox.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,14 @@ jobs:
fail-fast: false
max-parallel: 4
matrix:
python: [3.6, 3.7, 3.8, 3.9]
python: [3.7, 3.8, 3.9]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/setup-python@v2
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python }}
- run: pip install tox
- if: matrix.python == '3.6'
run: TOXENV=py36 tox
- if: matrix.python == '3.7'
run: TOXENV=py37 tox
- if: matrix.python == '3.8'
Expand Down
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
# Dropbox marker
.DS_Store

# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
Expand Down
10 changes: 10 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"python.testing.pytestEnabled": true,
"python.testing.unittestEnabled": false,
"python.formatting.provider": "black",
"python.defaultInterpreterPath": "python3",
"editor.formatOnSave": false,
"modulename": "paho_mqtt",
"distname": "${workspaceFolderBasename}",
"moduleversion": "1.6.1"
}
190 changes: 190 additions & 0 deletions .vscode/tasks.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,190 @@
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
// Use the Update Toolchain task to install the Python toolchain.
"version": "2.0.0",
"tasks": [
{
"label": "Install Build & Test Dependencies",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pip",
"install",
"--upgrade",
"-r",
"${workspaceFolder}/requirements_build.txt",
],
"problemMatcher": []
},
{
"label": "Install Code Dependencies",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pip",
"install",
"--upgrade",
"-r",
"${workspaceFolder}/requirements.txt",
],
"options": {
"cwd": "src"
},
"problemMatcher": []
},
{
"label": "Clean",
"type": "shell",
"command": "rm",
"args": [
"-rfvd",
"build",
"dist",
"htmlcov",
"docs/_build",
"src/${config:modulename}.egg-info",
],
"windows": {
"command": "Get-ChildItem",
"args": [
"-Path",
"build\\,",
"dist\\,",
"htmlcov\\,",
"docs\\_build,",
"src\\${config:modulename}.egg-info",
"-Recurse",
"|",
"Remove-Item",
"-Recurse",
"-Confirm:$false",
"-Force",
],
},
"options": {
"cwd": "${workspaceFolder}"
},
"problemMatcher": []
},
{
"label": "Bandit",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"bandit",
"-c",
"pyproject.toml",
"-r",
"."
],
"problemMatcher": []
},
{
"label": "iSort",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"isort",
"."
],
"problemMatcher": []
},
{
"label": "Codespell",
"type": "process",
"command": "codespell",
"args": [
"--toml",
"pyproject.toml",
"src"
],
"problemMatcher": []
},
{
"label": "Pylint",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pylint",
"--reports=y",
"src"
],
"problemMatcher": []
},
{
"label": "Pyflakes",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pyflakes",
"src"
],
"problemMatcher": []
},
{
"label": "Pylama",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pylama",
"src",
],
"problemMatcher": []
},
{
"label": "Build",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"build",
".",
"--wheel",
"--sdist",
],
"problemMatcher": []
},
{
"label": "Test",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pytest"
],
"problemMatcher": []
},
{
"label": "Install Locally",
"type": "process",
"command": "${config:python.defaultInterpreterPath}",
"args": [
"-m",
"pip",
"install",
"${workspaceFolder}/dist/paho-mqtt-${config:moduleversion}.tar.gz",
"--force-reinstall"
],
"dependsOrder": "sequence",
"dependsOn": [
"Clean",
"Install Build & Test Dependencies",
"Install Code Dependencies",
"iSort",
"Pylint",
"Bandit",
//"Test",
"Build",
],
"problemMatcher": []
},
]
}
6 changes: 4 additions & 2 deletions MANIFEST.in
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
include edl-v10 epl-v10
include edl-v10
include epl-v20
include README.rst
include CONTRIBUTING.md
include setup.py
include notice.html
include LICENSE.txt
include about.html

recursive-include src *.py
recursive-include examples *.py
global-exclude __pycache__
semuadmin marked this conversation as resolved.
Show resolved Hide resolved
global-exclude *.pyc
2 changes: 1 addition & 1 deletion README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ This document describes the source code for the `Eclipse Paho <http://eclipse.or

This code provides a client class which enable applications to connect to an `MQTT <http://mqtt.org/>`_ broker to publish messages, and to subscribe to topics and receive published messages. It also provides some helper functions to make publishing one off messages to an MQTT server very straightforward.

It supports Python 2.7.9+ or 3.6+.
It supports Python 3.7+.

The MQTT protocol is a machine-to-machine (M2M)/"Internet of Things" connectivity protocol. Designed as an extremely lightweight publish/subscribe messaging transport, it is useful for connections with remote locations where a small code footprint is required and/or network bandwidth is at a premium.

Expand Down
8 changes: 1 addition & 7 deletions Vagrantfile
Original file line number Diff line number Diff line change
@@ -1,17 +1,11 @@
Vagrant.configure("2") do |config|
# The base OS
config.vm.box = "ubuntu/trusty64"
config.vm.box = "ubuntu/bionic64"
config.vm.provision :shell, :inline => "sudo apt-get update"

# Install make
config.vm.provision :shell, :inline => "apt-get install -y make"

# Provision Python 2
config.vm.provision :shell, :inline => "apt-get upgrade -y python"
config.vm.provision :shell, :inline => "apt-get install -y python-pip"
config.vm.provision :shell, :inline => "python -m pip install --upgrade pip"
config.vm.provision :shell, :inline => "python -m pip install virtualenv"

# Provision Python 3
config.vm.provision :shell, :inline => "apt-get install -y python3"
config.vm.provision :shell, :inline => "apt-get install -y python3-pip"
Expand Down
Loading