Switch to modern PEP-517/PEP-518 build
- Add pyproject.toml - Remove setup.py - Adopt tox & CI to modern structure
This commit is contained in:
parent
b72fff5c23
commit
45436f1693
5 changed files with 31 additions and 48 deletions
46
Jenkinsfile
vendored
46
Jenkinsfile
vendored
|
@ -1,8 +1,8 @@
|
||||||
def pys = [
|
def pys = [
|
||||||
[name: 'Python 3.10', docker: 'python:3.10-buster', tox:'py310,flake8', main: true],
|
[name: 'Python 3.10', docker: 'python:3.10-bullseye', tox:'py310,flake8', main: true],
|
||||||
[name: 'Python 3.9', docker: 'python:3.9-buster', tox:'py39', main: false],
|
[name: 'Python 3.9', docker: 'python:3.9-bullseye', tox:'py39', main: false],
|
||||||
[name: 'Python 3.8', docker: 'python:3.8-buster', tox:'py38', main: false],
|
[name: 'Python 3.8', docker: 'python:3.8-bullseye', tox:'py38', main: false],
|
||||||
[name: 'Python 3.7', docker: 'python:3.7-buster', tox:'py37', main: false],
|
[name: 'Python 3.7', docker: 'python:3.7-bullseye', tox:'py37', main: false],
|
||||||
]
|
]
|
||||||
|
|
||||||
properties([
|
properties([
|
||||||
|
@ -15,35 +15,34 @@ Map tasks = [failFast: true]
|
||||||
pys.each { py ->
|
pys.each { py ->
|
||||||
tasks[py.name] = {
|
tasks[py.name] = {
|
||||||
node {
|
node {
|
||||||
def image
|
stage("Checkout $py.name") {
|
||||||
|
|
||||||
stage("Prepare docker $py.name") {
|
|
||||||
dir('dockerbuild') {
|
|
||||||
deleteDir()
|
|
||||||
docker.image(py.docker).pull()
|
|
||||||
buildDockerfile(py.docker)
|
|
||||||
image = docker.build("dosage-$py.docker")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
stage("Build $py.name") {
|
|
||||||
image.inside {
|
|
||||||
checkout scm
|
checkout scm
|
||||||
sh '''
|
sh '''
|
||||||
git clean -fdx
|
git clean -fdx
|
||||||
git fetch --tags
|
git fetch --tags
|
||||||
'''
|
'''
|
||||||
|
}
|
||||||
|
|
||||||
|
stage("Build $py.name") {
|
||||||
|
def image = docker.image(py.docker)
|
||||||
|
image.pull()
|
||||||
|
image.inside {
|
||||||
|
withEnv(['HOME=' + pwd(tmp: true)]) {
|
||||||
warnError('tox failed') {
|
warnError('tox failed') {
|
||||||
sh "tox -e $py.tox"
|
sh """
|
||||||
|
pip install --no-warn-script-location tox
|
||||||
|
python -m tox -e $py.tox
|
||||||
|
"""
|
||||||
}
|
}
|
||||||
|
|
||||||
if (py.main) {
|
if (py.main) {
|
||||||
sh """
|
sh """
|
||||||
python setup.py sdist bdist_wheel
|
pip install --no-warn-script-location build
|
||||||
|
python -m build
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (py.main) {
|
if (py.main) {
|
||||||
archiveArtifacts artifacts: 'dist/*', fingerprint: true
|
archiveArtifacts artifacts: 'dist/*', fingerprint: true
|
||||||
|
@ -80,15 +79,6 @@ stage('Allure report') {
|
||||||
processAllure()
|
processAllure()
|
||||||
}
|
}
|
||||||
|
|
||||||
def buildDockerfile(image) {
|
|
||||||
def uid = sh(returnStdout: true, script: 'id -u').trim()
|
|
||||||
writeFile file: 'Dockerfile', text: """
|
|
||||||
FROM $image
|
|
||||||
RUN pip install tox
|
|
||||||
RUN useradd -mu $uid dockerjenkins
|
|
||||||
"""
|
|
||||||
}
|
|
||||||
|
|
||||||
def windowsBuild() {
|
def windowsBuild() {
|
||||||
warnError('windows build failed') {
|
warnError('windows build failed') {
|
||||||
node {
|
node {
|
||||||
|
|
5
pyproject.toml
Normal file
5
pyproject.toml
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
[build-system]
|
||||||
|
requires = ["setuptools>=45", "wheel", "setuptools_scm>=6.2"]
|
||||||
|
build-backend = "setuptools.build_meta"
|
||||||
|
|
||||||
|
[tool.setuptools_scm]
|
|
@ -41,9 +41,6 @@ install_requires =
|
||||||
importlib_metadata;python_version<'3.8'
|
importlib_metadata;python_version<'3.8'
|
||||||
include_package_data = true
|
include_package_data = true
|
||||||
python_requires = >=3.7
|
python_requires = >=3.7
|
||||||
setup_requires =
|
|
||||||
setuptools>=38.3.0
|
|
||||||
setuptools_scm
|
|
||||||
|
|
||||||
[options.entry_points]
|
[options.entry_points]
|
||||||
console_scripts =
|
console_scripts =
|
||||||
|
|
10
setup.py
10
setup.py
|
@ -1,10 +0,0 @@
|
||||||
#!/usr/bin/env python3
|
|
||||||
# SPDX-License-Identifier: MIT
|
|
||||||
# Copyright (C) 2004-2008 Tristan Seligmann and Jonathan Jacobs
|
|
||||||
# Copyright (C) 2012-2014 Bastian Kleineidam
|
|
||||||
# Copyright (C) 2015-2019 Tobias Gruetzmacher
|
|
||||||
from setuptools import setup
|
|
||||||
|
|
||||||
setup(
|
|
||||||
use_scm_version=True,
|
|
||||||
)
|
|
1
tox.ini
1
tox.ini
|
@ -1,5 +1,6 @@
|
||||||
[tox]
|
[tox]
|
||||||
envlist = py37, py38, py39, py310, flake8
|
envlist = py37, py38, py39, py310, flake8
|
||||||
|
isolated_build = True
|
||||||
|
|
||||||
[gh-actions]
|
[gh-actions]
|
||||||
python =
|
python =
|
||||||
|
|
Loading…
Reference in a new issue