diff options
author | Jürgen Ryannel <juergen@ryannel.org> | 2020-02-04 14:25:57 +0100 |
---|---|---|
committer | Dominik Holland <dominik.holland@googlemail.com> | 2022-01-27 13:50:04 +0100 |
commit | ab73d1eb69226fd6d0b88a48ea3a8ebafc6720c3 (patch) | |
tree | 02bbfe38c8cb8a0697ea319de07eee87d273ee67 | |
parent | 685f47902821ae66ba569c9917336dae861f5f7a (diff) | |
download | qtivi-qface-ab73d1eb69226fd6d0b88a48ea3a8ebafc6720c3.tar.gz |
freeze qface dependencies based on QtIVI input (#92)
* freeze qface dependencies based on QtIVI input
* upgrade version number to 2.0.1
* updated requirements and cli file
* fix cli test-ci naming
* was wrong fix
* fix travis ci script
-rw-r--r-- | .travis.yml | 2 | ||||
-rwxr-xr-x | cli.py | 95 | ||||
-rw-r--r-- | qface/__about__.py | 2 | ||||
-rw-r--r-- | requirements.txt | 26 | ||||
-rw-r--r-- | setup.py | 16 |
5 files changed, 24 insertions, 117 deletions
diff --git a/.travis.yml b/.travis.yml index 15c96ea..8b37141 100644 --- a/.travis.yml +++ b/.travis.yml @@ -2,4 +2,4 @@ language: python python: - "3.6" install: "pip install -r requirements.txt" -script: ./cli.py test-ci +script: ./cli.py test_ci @@ -11,7 +11,6 @@ import os import yaml import logging import logging.config -from livereload import Server, shell here = Path(__file__).abspath().dirname() @@ -53,100 +52,6 @@ def test_ci(): sh('python3 -m pytest --cov=qface -v -l tests/') -class RunTestChangeHandler(FileSystemEventHandler): - def __init__(self, clickContext): - super().__init__() - self.clickContext = clickContext - - def on_any_event(self, event): - if event.is_directory: - return - if Path(event.src_path).ext == '.py': - sh('python3 -m pytest') - - -@cli.command() -@click.pass_context -def test_monitor(ctx): - """run the tests and re-run on changes""" - sh('python3 -m pytest') - while True: - event_handler = RunTestChangeHandler(ctx) - observer = Observer() - observer.schedule(event_handler, './tests', recursive=True) - observer.schedule(event_handler, './qface', recursive=True) - observer.start() - try: - while True: - time.sleep(1) - except KeyboardInterrupt: - observer.stop() - observer.join() - - -class RunScriptChangeHandler(FileSystemEventHandler): - def __init__(self, script): - super().__init__() - self.script = script - self.is_running = False - - def on_modified(self, event): - if event.src_path.endswith('.cache'): - return - self.run() - - def run(self): - if self.is_running: - return - self.is_running = True - sh(self.script, cwd=Path.getcwd()) - self.is_running = False - - -@cli.command() -@click.argument('script', nargs=1, type=click.Path(exists=True)) -@click.argument('input', nargs=-1, type=click.Path(exists=True)) -@click.argument('output', nargs=1, type=click.Path(exists=True)) -def reload(script, input, output): - """ - reloads the generator script when the script files - or the input files changes - """ - script = Path(script).expand().abspath() - output = Path(output).expand().abspath() - input = input if isinstance(input, (list, tuple)) else [input] - output.makedirs_p() - _script_reload(script, input, output) - - -def _script_reload(script, input, output): - """run the named generator and monitor the input and generator folder""" - input = [Path(entry).expand().abspath() for entry in input] - output = Path(output).expand().abspath() - cmd = 'python3 {0} {1} {2}'.format(script, ' '.join(input), output) - event_handler = RunScriptChangeHandler(cmd) - event_handler.run() # run always once - observer = Observer() - path = script.dirname().expand().abspath() - click.secho('watch: {0}'.format(path), fg='blue') - observer.schedule(event_handler, path, recursive=True) - for entry in input: - entry = entry.dirname().expand().abspath() - click.secho('watch: {0}'.format(entry), fg='blue') - observer.schedule(event_handler, entry, recursive=True) - path = Path(__file__).parent / 'qface' - click.secho('watch: {0}'.format(path), fg='blue') - observer.schedule(event_handler, path, recursive=True) - observer.start() - - try: - while True: - time.sleep(1) - except KeyboardInterrupt: - observer.stop() - observer.join() - - @click.option('--editable/--no-editable', default=False, help='install editable package') @cli.command() def install(editable): diff --git a/qface/__about__.py b/qface/__about__.py index 0ed253d..ba588e4 100644 --- a/qface/__about__.py +++ b/qface/__about__.py @@ -9,7 +9,7 @@ except NameError: __title__ = "qface" __summary__ = "A generator framework based on a common modern IDL" __url__ = "https://pelagicore.github.io/qface/" -__version__ = "2.0.0" +__version__ = "2.0.1" __author__ = "JRyannel" __author_email__ = "" __copyright__ = "2019 Pelagicore" diff --git a/requirements.txt b/requirements.txt index d3aa418..309cb61 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,13 +1,15 @@ antlr4-python3-runtime==4.7.1 -typing -jinja2 -click -path.py -watchdog -livereload -pyyaml -pytest -coverage -pytest-cov -six -coloredlogs +argh==0.26.2 +click==6.7 +coloredlogs==10.0 +humanfriendly==4.15.1 +Jinja2==2.10 +MarkupSafe==1.0 +path.py==11.0.1 +pathtools==0.1.2 +PyYAML==5.1 +six==1.11.0 +typing==3.6.4 +watchdog==0.8.3 +pytest==5.3.5 +pytest-cov==2.8.1 @@ -44,15 +44,15 @@ setup( packages=find_packages(), include_package_data=True, install_requires=[ - 'click', + 'click==6.7', 'antlr4-python3-runtime==4.7.1', - 'jinja2', - 'path.py', - 'pyyaml', - 'typing', - 'watchdog', - 'six', - 'coloredlogs', + 'jinja2==2.10', + 'path.py==11.0.1', + 'pyyaml==5.1', + 'typing==3.6.4', + 'watchdog==0.8.3', + 'six==1.11.0', + 'coloredlogs==10.0', ], extras_require={ 'dev': [ |