2020-08-21 10:39:43 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
from invoke import task
|
2020-08-21 11:08:04 +00:00
|
|
|
from shutil import copyfile
|
2020-08-21 10:39:43 +00:00
|
|
|
|
2020-08-21 11:08:04 +00:00
|
|
|
import random
|
|
|
|
import string
|
2020-08-21 10:39:43 +00:00
|
|
|
import os
|
|
|
|
|
2020-08-21 11:08:04 +00:00
|
|
|
def apps():
|
|
|
|
"""
|
|
|
|
Returns a list of installed apps
|
|
|
|
"""
|
|
|
|
|
|
|
|
return [
|
|
|
|
'barcode',
|
|
|
|
'build',
|
|
|
|
'common',
|
|
|
|
'company',
|
|
|
|
'label',
|
|
|
|
'order',
|
|
|
|
'part',
|
|
|
|
'report',
|
|
|
|
'stock',
|
|
|
|
'InvenTree'
|
|
|
|
]
|
|
|
|
|
2020-08-21 10:39:43 +00:00
|
|
|
def localDir():
|
|
|
|
"""
|
|
|
|
Returns the directory of *THIS* file.
|
|
|
|
Used to ensure that the various scripts always run
|
|
|
|
in the correct directory.
|
|
|
|
"""
|
|
|
|
return os.path.dirname(os.path.abspath(__file__))
|
|
|
|
|
|
|
|
def managePyDir():
|
|
|
|
"""
|
|
|
|
Returns the directory of the manage.py file
|
|
|
|
"""
|
|
|
|
|
|
|
|
return os.path.join(localDir(), 'InvenTree')
|
|
|
|
|
|
|
|
def managePyPath():
|
|
|
|
"""
|
|
|
|
Return the path of the manage.py file
|
|
|
|
"""
|
|
|
|
|
2020-08-21 11:08:04 +00:00
|
|
|
return os.path.join(managePyDir(), 'manage.py')
|
2020-08-21 10:39:43 +00:00
|
|
|
|
|
|
|
def manage(c, cmd):
|
|
|
|
"""
|
|
|
|
Runs a given command against django's "manage.py" script.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
c - Command line context
|
|
|
|
cmd - django command to run
|
|
|
|
"""
|
|
|
|
|
|
|
|
c.run('cd {path} && python3 manage.py {cmd}'.format(
|
|
|
|
path=managePyDir(),
|
|
|
|
cmd=cmd
|
|
|
|
))
|
|
|
|
|
2020-08-21 11:08:04 +00:00
|
|
|
@task(help={'length': 'Length of secret key (default=50)'})
|
|
|
|
def key(c, length=50, force=False):
|
|
|
|
"""
|
|
|
|
Generates a SECRET_KEY file which InvenTree uses for generating security hashes
|
|
|
|
"""
|
|
|
|
|
|
|
|
SECRET_KEY_FILE = os.path.join(localDir(), 'InvenTree', 'secret_key.txt')
|
|
|
|
|
|
|
|
# If a SECRET_KEY file does not exist, generate a new one!
|
|
|
|
if force or not os.path.exists(SECRET_KEY_FILE):
|
|
|
|
print("Generating SECRET_KEY file - " + SECRET_KEY_FILE)
|
|
|
|
with open(SECRET_KEY_FILE, 'w') as key_file:
|
|
|
|
options = string.digits + string.ascii_letters + string.punctuation
|
|
|
|
|
|
|
|
key = ''.join([random.choice(options) for i in range(length)])
|
|
|
|
|
|
|
|
key_file.write(key)
|
|
|
|
|
|
|
|
else:
|
|
|
|
print("SECRET_KEY file already exists - skipping")
|
|
|
|
|
|
|
|
|
|
|
|
@task(post=[key])
|
|
|
|
def install(c):
|
|
|
|
"""
|
|
|
|
Installs required python packages, and runs initial setup functions.
|
|
|
|
"""
|
|
|
|
|
|
|
|
# Install required Python packages with PIP
|
|
|
|
#c.run('pip3 install -U -r requirements.txt')
|
|
|
|
|
|
|
|
# If a config.yaml file does not exist, copy from the template!
|
|
|
|
CONFIG_FILE = os.path.join(localDir(), 'InvenTree', 'config.yaml')
|
|
|
|
CONFIG_TEMPLATE_FILE = os.path.join(localDir(), 'InvenTree', 'config_template.yaml')
|
|
|
|
|
|
|
|
if not os.path.exists(CONFIG_FILE):
|
|
|
|
print("Config file 'config.yaml' does not exist - copying from template.")
|
|
|
|
copyfile(CONFIG_TEMPLATE_FILE, CONFIG_FILE)
|
|
|
|
|
2020-08-21 10:39:43 +00:00
|
|
|
@task
|
|
|
|
def migrate(c):
|
|
|
|
"""
|
|
|
|
Performs database migrations.
|
|
|
|
This is a critical step if the database schema have been altered!
|
|
|
|
"""
|
|
|
|
|
|
|
|
print("Running InvenTree database migrations...")
|
|
|
|
print("========================================")
|
|
|
|
|
|
|
|
manage(c, "makemigrations")
|
|
|
|
manage(c, "migrate")
|
|
|
|
manage(c, "migrate --run-syncdb")
|
|
|
|
manage(c, "check")
|
|
|
|
|
|
|
|
print("========================================")
|
|
|
|
print("InvenTree database migrations completed!")
|
|
|
|
|
2020-08-21 11:08:04 +00:00
|
|
|
|
2020-08-21 10:39:43 +00:00
|
|
|
@task
|
2020-08-21 11:08:04 +00:00
|
|
|
def static(c):
|
|
|
|
"""
|
|
|
|
Copies required static files to the STATIC_ROOT directory,
|
|
|
|
as per Django requirements.
|
|
|
|
"""
|
|
|
|
|
|
|
|
manage(c, "collectstatic")
|
|
|
|
|
|
|
|
|
|
|
|
@task(pre=[install, migrate, static])
|
|
|
|
def update(c):
|
|
|
|
"""
|
|
|
|
Update InvenTree installation.
|
|
|
|
|
|
|
|
This command should be invoked after source code has been updated,
|
|
|
|
e.g. downloading new code from GitHub.
|
|
|
|
|
|
|
|
The following tasks are performed, in order:
|
|
|
|
|
|
|
|
- install
|
|
|
|
- migrate
|
|
|
|
- static
|
|
|
|
"""
|
|
|
|
pass
|
|
|
|
|
2020-08-21 11:12:05 +00:00
|
|
|
@task
|
|
|
|
def style(c):
|
|
|
|
"""
|
|
|
|
Run PEP style checks against InvenTree sourcecode
|
|
|
|
"""
|
|
|
|
|
|
|
|
print("Running PEP style checks...")
|
|
|
|
c.run('flake8 InvenTree')
|
|
|
|
|
2020-08-21 11:10:14 +00:00
|
|
|
@task
|
|
|
|
def test(c):
|
|
|
|
"""
|
|
|
|
Run unit-tests for InvenTree codebase.
|
|
|
|
"""
|
|
|
|
|
|
|
|
# Run sanity check on the django install
|
|
|
|
manage(c, 'check')
|
|
|
|
|
|
|
|
# Run coverage tests
|
|
|
|
manage(c, 'test {apps}'.format(
|
|
|
|
apps=' '.join(apps())
|
|
|
|
))
|
|
|
|
|
2020-08-21 11:08:04 +00:00
|
|
|
@task
|
|
|
|
def coverage(c):
|
|
|
|
"""
|
|
|
|
Run code-coverage of the InvenTree codebase,
|
|
|
|
using the 'coverage' code-analysis tools.
|
|
|
|
|
|
|
|
Generates a code coverage report (available in the htmlcov directory)
|
|
|
|
"""
|
|
|
|
|
|
|
|
# Run sanity check on the django install
|
|
|
|
manage(c, 'check')
|
|
|
|
|
|
|
|
# Run coverage tests
|
|
|
|
c.run('coverage run {manage} test {apps}'.format(
|
|
|
|
manage=managePyPath(),
|
|
|
|
apps=' '.join(apps())
|
|
|
|
))
|
|
|
|
|
|
|
|
# Generate coverage report
|
|
|
|
c.run('coverage html')
|