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

#128 migrate project to pyrpoject toml based package setup #145

Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
a86d51a
Add pyproject.toml
Nicoretti May 30, 2022
35e067a
Add basic project information to pyproject.toml
Nicoretti May 30, 2022
464f7bf
Add dependencies to pyproject.toml
Nicoretti May 30, 2022
e5d8348
Remove deprecated and unused configuration entries
Nicoretti May 30, 2022
ea3cd16
Update include list in pyproject.toml
Nicoretti May 31, 2022
79508ef
Add extension points required for sqlalchemy plugin(s)
Nicoretti May 31, 2022
39b06e8
Remove unused script
Nicoretti May 31, 2022
5de6bbe
Add sync support for project.toml based version
Nicoretti May 31, 2022
db10601
Add version check to ci/verifier action
Nicoretti Jun 1, 2022
96b9c70
Add justification why the pytest config still is part of setup.cfg
Nicoretti Jun 1, 2022
474b898
Remove condaforge reference in README
Nicoretti Jun 1, 2022
286305a
Fix error in setup.cfg
Nicoretti Jun 1, 2022
4ea0d5e
Replace version information mechansim
Nicoretti Jun 1, 2022
6bf3af5
Add poetry lock file
Nicoretti Jun 1, 2022
90c9ab4
Delete deprecated requirements*.txt files
Nicoretti Jun 1, 2022
d7cba05
Remove deprecated setup.py
Nicoretti Jun 1, 2022
55d17cb
Update comment in generated file according to code review
Nicoretti Jun 1, 2022
1485b86
Update CI workflow to use poetry
Nicoretti Jun 1, 2022
2ab87f8
Fix command invocation to use poetry
Nicoretti Jun 1, 2022
362c006
Fix import of version module
Nicoretti Jun 1, 2022
42a4914
Fix installation order
Nicoretti Jun 1, 2022
2309b94
Use python built in mock library
Nicoretti Jun 1, 2022
43c7093
Remove deprecated version parsing
Nicoretti Jun 1, 2022
2329c24
Add missing newline
Nicoretti Jun 1, 2022
7673702
Rename workflow step
Nicoretti Jun 1, 2022
d86bf11
Update .github/workflows/CI.yml
Nicoretti Jun 2, 2022
4d00df4
Update .github/workflows/CI.yml
Nicoretti Jun 2, 2022
ef89874
Add check-links workflow
Nicoretti Jun 2, 2022
8aea7ac
Add packaging dependency explicitly
Nicoretti Jun 2, 2022
d8c6dac
Update ci workflow to support caching
Nicoretti Jun 2, 2022
9cd2051
Fix github workflows to install poetry previous to the python setup
Nicoretti Jun 2, 2022
5065586
Fix check-links workflow
Nicoretti Jun 2, 2022
bad8906
Renamed workflow check-links to link-check
Nicoretti Jun 2, 2022
ce3aadd
Fix issue of wrong selected python version in github action
Nicoretti Jun 3, 2022
64ac386
Rework CI-CD workflow to use poetry
Nicoretti Jul 7, 2022
d50aa32
Remove version file from ignore list
Nicoretti Jul 7, 2022
aec032f
Remove MANIFEST.in file
Nicoretti Jul 7, 2022
d0dc285
Add dependabot updater to repository
Nicoretti Jul 7, 2022
7abe052
Update base python version to 3.8
Nicoretti Jul 7, 2022
c663056
Add pyupgrade commit hook to workspace
Nicoretti Jul 7, 2022
40ddcba
Update python version(s) in github actions
Nicoretti Jul 7, 2022
7aa9761
Bump version to 3.0.0
Nicoretti Jul 7, 2022
fcec34d
Removed verbose flag from pre commit hook
Nicoretti Jul 7, 2022
dd3b839
Show CI instead of CI-CD status in README
Nicoretti Jul 7, 2022
6609704
Update information about minimum python version
Nicoretti Jul 7, 2022
037f906
Update changelog
Nicoretti Jul 7, 2022
0e9455c
Update minimum required python version in developer guide
Nicoretti Jul 7, 2022
e5231dd
Update developer guide
Nicoretti Jul 7, 2022
ee24d9a
Add todo for updating turbodbc dependency
Nicoretti Jul 7, 2022
b6ed83c
Remove link check from test workflow
Nicoretti Jul 7, 2022
beed934
Update version check hook and script
Nicoretti Jul 7, 2022
e00c99b
Remove link check from CI - CD workflow
Nicoretti Jul 7, 2022
54f1a5f
Add git script/module to query available tags
Nicoretti Jul 7, 2022
1681f93
Add release support for new project format to noxfile and CI/CD
Nicoretti Jul 7, 2022
7b18c2b
Prepare 3.0.0 release
Nicoretti Jul 12, 2022
6d9135c
Fix missing check in verify step
Nicoretti Jul 12, 2022
397bfaa
Make sure no unnecessary virtual environments will be created
Nicoretti Jul 12, 2022
e7dd1f7
Update pytest dependency
Nicoretti Jul 12, 2022
a28c946
Address pytest compatibility issue
Nicoretti Jul 12, 2022
835647a
Adjust release task and action
Nicoretti Jul 13, 2022
3e1f196
Remove odbcinst.ini and replace with template
Nicoretti Jul 13, 2022
95d77a9
Harden relase mechanism
Nicoretti Jul 13, 2022
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
7 changes: 2 additions & 5 deletions .github/workflows/ci-cd.yml
Original file line number Diff line number Diff line change
Expand Up @@ -92,8 +92,5 @@ jobs:
with:
poetry-version: 1.1.13

- name: Build sdist and wheel packages
run: poetry build

- name: Push package to PYPI
run: poetry publish --username=__token__ --password=${{ secrets.pypi_token }}
- name: Build and push package to PYPI
run: poetry run nox -s release -- --username=__token__ --password=${{ secrets.pypi_token }}
Nicoretti marked this conversation as resolved.
Show resolved Hide resolved
56 changes: 48 additions & 8 deletions noxfile.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import os
import sys
from argparse import ArgumentParser
from contextlib import contextmanager
from pathlib import Path
from tempfile import TemporaryDirectory
Expand All @@ -11,10 +12,12 @@
sys.path.append(f"{SCRIPTS}")

import nox
from git import tags
from links import check as _check
from links import documentation as _documentation
from links import urls as _urls
from pyodbc import connect
from version_check import version_from_poetry, version_from_python_module, version_from_string

# default actions to be run if nothing is explicitly specified with the -s option
nox.options.sessions = ["verify(connector='pyodbc')"]
Expand Down Expand Up @@ -83,20 +86,57 @@ def temporary_odbc_config(config):
@contextmanager
def odbcconfig():
with temporary_odbc_config(
ODBCINST_INI_TEMPLATE.format(driver=Settings.ODBC_DRIVER)
ODBCINST_INI_TEMPLATE.format(driver=Settings.ODBC_DRIVER)
) as cfg:
env_vars = {"ODBCSYSINI": f"{cfg.parent.resolve()}"}
with environment(env_vars) as env:
yield cfg, env


@nox.session(name="check-version", reuse_venv=True)
def check_version(session):
@nox.session(python=False)
def release(session: nox.Session):
def create_parser():
p = ArgumentParser(
"Release a pypi package",
usage="nox -s release -- [-h] [-d] [-l LOGIN] [-p PASSWORD]",
)
p.add_argument("-d", "--dry-run", action="store_true", help="just do a dry run")
p.add_argument("-u", "--username", help="pypi login/username")
p.add_argument("-p", "--password", help="password/token for the pypi account")
return p

args = []
parser = create_parser()
cli_args = parser.parse_args(session.posargs)
if cli_args.dry_run:
args.append("--dry-run")
if cli_args.username:
args.append("--username")
args.append(cli_args.username)
if cli_args.password:
Nicoretti marked this conversation as resolved.
Show resolved Hide resolved
args.append("--password")
args.append(cli_args.password)

version_file = version_from_python_module(PROJECT_ROOT / 'sqlalchemy_exasol' / 'version.py')
module_version = version_from_poetry()
git_version = version_from_string(tags()[-1])

if not (module_version == git_version == version_file):
Nicoretti marked this conversation as resolved.
Show resolved Hide resolved
session.error(
f"Versions out of sync, version file: {version_file}, poetry: {module_version}, tag: {git_version}."
)

session.run(
"poetry",
"build",
external=True,
)

session.run(
"python",
f"{SCRIPTS / 'version_check.py'}",
"--check",
f"{PROJECT_ROOT / 'sqlalchemy_exasol' / 'version.py'}",
"poetry",
"publish",
*args,
external=True,
)


Expand Down Expand Up @@ -242,7 +282,7 @@ def check_links(session):
if errors:
session.error(
"\n"
+ "\n".join((f"Url: {e[1]}, File: {e[0]}, Error: {e[3]}" for e in errors))
+ "\n".join(f"Url: {e[1]}, File: {e[0]}, Error: {e[3]}" for e in errors)
)


Expand Down
14 changes: 5 additions & 9 deletions scripts/version_check.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,7 @@ def version_from_poetry():
if not poetry:
raise CommitHookError("Couldn't find poetry executable")

result = subprocess.run(
[poetry, "version"], capture_output=True)
result = subprocess.run([poetry, "version"], capture_output=True)
version = result.stdout.decode().split()[1]
return version_from_string(version)

Expand Down Expand Up @@ -101,20 +100,17 @@ def _main_debug(args):
module_version = version_from_python_module(args.version_module)
poetry_version = version_from_poetry()

def are_versions_equal(lhs, rhs):
return (
lhs.major == rhs.major and lhs.minor == rhs.minor and lhs.patch == rhs.patch
)

if args.fix:
write_version_module(poetry_version, args.version_module)

if not are_versions_equal(module_version, poetry_version):
if not module_version == poetry_version:
print(
f"Version in pyproject.toml {poetry_version} and {args.version_module} {module_version} do not match!"
)
if args.fix:
print(f"Updating version in file ({args.version_module}) from {module_version} to {poetry_version}")
print(
f"Updating version in file ({args.version_module}) from {module_version} to {poetry_version}"
)
return _FAILURE

return _SUCCESS
Expand Down