1
0
mirror of https://github.com/spaam/svtplay-dl.git synced 2024-11-24 04:05:39 +01:00
svtplay-dl/scripts/cibuild.py

121 lines
3.2 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
import subprocess
import argparse
import os
import logging
import sys
import glob
from datetime import datetime
root = os.path.normpath(os.path.join(os.path.dirname(__file__), ".."))
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger("cibuild")
parser = argparse.ArgumentParser(prog="cibuild")
general = parser.add_argument_group()
general.add_argument("-s", "--snapshots", action="store_true", dest="snapshot", default=False)
general.add_argument("-r", "--release", action="store_true", dest="release", default=False)
options = parser.parse_args()
twine_username = os.environ.get("TWINE_USERNAME")
twine_password = os.environ.get("TWINE_PASSWORD")
docker_username = os.environ.get("DOCKER_USERNAME")
docker_password = os.environ.get("DOCKER_PASSWORD")
aws_creds = os.environ.get("AWS_ACCESS_KEY_ID")
travis_tag = os.environ.get("TRAVIS_TAG", "")
travis_branch = os.environ.get("TRAVIS_BRANCH", "")
appveyor_tag = os.environ.get("APPVEYOR_REPO_TAG_NAME", "")
appveyor_branch = os.environ.get("APPVEYOR_REPO_BRANCH", "")
def tag():
return travis_tag or appveyor_tag
def branch():
return travis_branch or appveyor_branch
def docker_name():
if tag():
ver = tag()
else:
ver = "dev"
return "spaam/svtplay-dl:{}".format(ver)
def build_docker():
logger.info("Building docker")
subprocess.check_output([
"docker", "build", "-f", "dockerfile/Dockerfile", "-t", docker_name(), "."
])
subprocess.check_call([
"docker", "login", "-u", docker_username, "-p", docker_password
])
subprocess.check_call([
"docker", "push", docker_name()
])
def build_package():
logger.info("Building python package")
subprocess.check_output([
"python3", "setup.py", "-q", "sdist", "bdist_wheel"
])
def snapshot_folder():
"""
Use the commit date in UTC as folder name
"""
logger.info("Snapshot folder")
try:
stdout = subprocess.check_output(["git", "show", "-s", "--format=%cI", "HEAD"])
except subprocess.CalledProcessError as e:
logger.error("Error: {}".format(e.output.decode('ascii', 'ignore').strip()))
sys.exit(2)
except FileNotFoundError as e:
logger.error("Error: {}".format(e))
sys.exit(2)
ds = stdout.decode('ascii', 'ignore').strip()
dt = datetime.fromisoformat(ds)
utc = dt - dt.utcoffset()
return utc.strftime("%Y%m%d_%H%M%S")
def aws_upload():
if tag():
folder = "release"
version = tag()
else:
folder = "snapshots"
version = snapshot_folder()
logger.info("Upload to aws {}/{}".format(folder, version))
for file in ["svtplay-dl", "svtplay-dl.zip"]:
if os.path.isfile(file):
subprocess.check_call([
"aws", "s3", "cp", "{}".format(file), "s3://svtplay-dl/{}/{}/{}".format(folder, version, file)
])
def pypi_upload():
logger.info("Uploading to pypi")
sdist = glob.glob(os.path.join("dist/", 'svtplay_dl-*.tar.gz'))[0]
subprocess.check_call(["twine", "upload", sdist])
if branch() is not "master":
sys.exit(0)
build_package()
build_docker()
aws_upload()
if tag():
pypi_upload()