[WIP] automating release

This commit is contained in:
ksamuel 2020-08-31 14:26:14 +02:00
parent b83f284b98
commit 2725cd10b4
7 changed files with 105 additions and 19 deletions

3
.gitignore vendored
View File

@ -7,12 +7,15 @@
*_index
*.orig
*.swp
*.old
# binaries
*.pyc
*.pyo
*.pyz
*.zip
__pycache__
.mypy*
*.db

View File

@ -1,5 +1,7 @@
#! /bin/bash
export PYTHONWARNINGS=ignore::FutureWarning # scss prints future warnings
python -c "import scss" || {
echo >&2 "Error: this script requires the scss python module. pip install -r dev-requirements.txt"
exit 1
@ -23,15 +25,12 @@ echo "Compressing CSS..."
echo $'\n''/* Prettify */' >>$CSS_OUTPUT
python -m scss $CSSDIR'prettify.css' >>$CSS_OUTPUT
rm $CSSDIR'prettify.min.css'
echo $'\n''/* Desert prettify theme */' >>$CSS_OUTPUT
python -m scss $CSSDIR'desert.css' >>$CSS_OUTPUT
rm $CSSDIR'desert.min.css'
echo $'\n''/* Bootswatch bootstrap theme */' >>$CSS_OUTPUT
python -m scss $CSSDIR'bootswatch.4.5.css' >>$CSS_OUTPUT
rm $CSSDIR'bootswatch.4.5.min.css'
echo $'\n''/* Our own CSS */' >>$CSS_OUTPUT
python -m scss $CSSDIR'style.css' >>$CSS_OUTPUT

View File

@ -1,2 +1,4 @@
doit==0.32.0
pyScss==1.3.7
twine==3.2.0
GitPython==3.1.7

107
dodo.py
View File

@ -1,37 +1,69 @@
import re
import sys
from pathlib import Path
from fnmatch import fnmatch
import doit
from doit.tools import PythonInteractiveAction
from git import Repo
import zerobin
try:
from local_dodo import *
except ImportError:
pass
ROOT = Path(__file__).absolute().parent
SOURCE_DIR = ROOT / "zerobin/"
DIST_DIR = ROOT / "dist"
ZEROBIN_VERSION = (SOURCE_DIR / "VERSION").read_text().strip()
def source_files(extensions=None):
DOIT_CONFIG = {
"default_tasks": ["task_compress"],
"action_string_formatting": "new",
}
REPO = Repo(".")
def source_files(extensions=None, exclude=()):
exclude_filter = ["*.pyc", ".*"]
exclude_filter.extend(exclude)
extensions = extensions or [".*"]
for ext in extensions:
for file in SOURCE_DIR.rglob(f"*{ext}"):
if (
not file.suffix.endswith("pyc")
and not file.is_dir()
and not "/." in str(file)
if not (
file.is_dir()
or any(fnmatch(file, pattern) for pattern in exclude_filter)
):
yield file
def generate_manifest():
extensions = " ".join(set(f"*{f.suffix}" for f in source_files()))
(ROOT / "MANIFEST.in").write_text(f"recursive-include zerobin {extensions}")
def task_generate_manifest():
def generate():
globs = " ".join(set(f"*{f.suffix}" for f in source_files()))
globs += " VERSION"
(ROOT / "MANIFEST.in").write_text(f"recursive-include zerobin {globs}")
return {
"targets": [ROOT / "MANIFEST.in"],
"actions": [generate],
}
def task_compress():
main_js = str(SOURCE_DIR / "static/js/main.min.js")
main_css = str(SOURCE_DIR / "static/css/style.min.css")
return {
"targets": [
str(SOURCE_DIR / "static/js/main.min.js"),
str(SOURCE_DIR / "static/css/style.min.css"),
],
"file_dep": list(str(f) for f in source_files([".css", ".js"])),
"targets": [main_js, main_css],
"file_dep": list(
str(f) for f in source_files([".css", ".js"], exclude=[main_css, main_js])
),
"actions": [str(ROOT / "compress.sh")],
}
@ -39,8 +71,53 @@ def task_compress():
def task_build():
return {
"targets": [DIST_DIR / f"zerobin-{zerobin.__version__}-py3-none-any.whl"],
"targets": [DIST_DIR / f"zerobin-{ZEROBIN_VERSION}-py3-none-any.whl"],
"file_dep": list(str(f) for f in source_files() if ".min." not in str(f)),
"actions": [task_compress, generate_manifest, "python setup.py bdist_wheel",],
"task_dep": ["compress", "generate_manifest"],
"actions": ["python setup.py bdist_wheel"],
}
def task_publish_to_pypi():
return {
"task_dep": ["build"],
"file_dep": [DIST_DIR / f"zerobin-{ZEROBIN_VERSION}-py3-none-any.whl"],
"actions": ["twine upload ./dist/*.whl"],
}
def task_release():
pass
def task_bump_version():
def bump():
if REPO.active_branch.name != "master":
sys.exit("You must be on the branch master to do that")
print("Current version is:", ZEROBIN_VERSION)
action = 0
while action not in "123":
print("What kind of version is it?\n")
print("1) Major")
print("2) Minor")
print("3) Fix")
action = input("Enter 1, 2 or 3 (Ctrl + C to quit): ")
new_version = list(ZEROBIN_VERSION.split("."))
action = int(action) - 1
new_version[action] += 1
new_version = ".".join(map(str, new_version))
print("The new version will be:", new_version)
if input("Ok? [y/N] ").strip().lower() != "y":
sys.exit("The version has NOT been bumped")
print(f"""REPO.create_tag("v" + {new_version})""")
return {
"actions": [PythonInteractiveAction(bump),],
}

4
setup.py Normal file
View File

@ -0,0 +1,4 @@
from setuptools import setup
setup()

1
zerobin/VERSION Normal file
View File

@ -0,0 +1 @@
1.0.3

View File

@ -1,5 +1,5 @@
from pathlib import Path
__version__ = "1.0.3"
__version__ = (Path(__file__).parent / "VERSION").read_text().strip()
ROOT_DIR = Path(__file__).absolute().parent