Skip to main content

A very simple GUI and CLI to manage environment variables.

Project description

env-switcher-gui
================

A very simple GUI and CLI to manage environment variables.

Project page : https://smarie.github.io/env-switcher-gui/

Developer memo for QtDesigner
-----------------------------

Architecture
~~~~~~~~~~~~

This is a kind of MVC pattern where

- the **View** is made of two parts: the static one ``UI_MainWindow``,
generated with qt designer, and the dynamic one ``EnvSwitcherView``.
It deals with the various widgets and popups.
- the **Model** is provided by ``EnvSwitcherState`` and deals with the
configuration files and persistence.
- the **Controller**, or the **Application**, is provided by
``EnvSwitcherApp`` and provides the Qt application boilerplate as
well as persistence of the application settings (recent edited
files).

.. figure:: docs/DesignOverview.png
:alt: EnvswitchDesign

EnvswitchDesign
.py code generation
~~~~~~~~~~~~~~~~~~~

*Prerequisite: install PyQt5, but warning: using pip to install pyqt in
anaconda root may compromise your global conda environment (see
`here <https://github.com/ContinuumIO/anaconda-issues/issues/1970>`__)*
\* Run ``designer``, save file as ``*.ui`` for example we use
``./ui/sprint2_dynamic.ui`` \* Generate equivalent python file with
``pyuic5 ui/sprint2_dynamic.ui -o envswitch/qt_design.py``

Want to contribute ?
--------------------

Contributions are welcome ! Simply fork this project on github, commit
your contributions, and create pull requests.

Here is a non-exhaustive list of interesting open topics:
https://github.com/smarie/env-switcher-gui/issues

Running the tests
-----------------

This project uses ``pytest``.

.. code:: bash

pytest -v envswitch/tests/

You may need to install requirements for tests beforehand, using

.. code:: bash

pip install -r ci_tools/requirements-test.txt

Packaging
---------

Python wheel
~~~~~~~~~~~~

This project uses ``setuptools_scm`` to synchronise the version number.
Therefore the following command should be used for development snapshots
as well as official releases:

.. code:: bash

python setup.py egg_info bdist_wheel rotate -m.whl -k3

You may need to install requirements for setup beforehand, using

.. code:: bash

pip install -r ci_tools/requirements-setup.txt

Standalone app
~~~~~~~~~~~~~~

To build the executable distribution there is a separate setup file for
cx\_freeze:

.. code:: bash

python setup_cx_app.py build

Generating the documentation page
---------------------------------

This project uses ``mkdocs`` to generate its documentation page.
Therefore building a local copy of the doc page may be done using:

.. code:: bash

mkdocs build

You may need to install requirements for doc beforehand, using

.. code:: bash

pip install -r ci_tools/requirements-doc.txt

Generating the test reports
---------------------------

The following commands generate the html test report and the associated
badge. Note that in order for the test to succeed, you should create an
environment variable named 'FOO' beforehand, with random content.

.. code:: bash

pytest --junitxml=junit.xml -v envswitch/tests/
ant -f ci_tools/generate-junit-html.xml
python ci_tools/generate-junit-badge.py

PyPI Releasing memo
~~~~~~~~~~~~~~~~~~~

This project is now automatically deployed to PyPI by Travis when a tag
is created. Anyway, for manual deployment we can use:

.. code:: bash

twine upload dist/* -r pypitest
twine upload dist/*



Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

envswitch-1.0.0.tar.gz (1.2 MB view hashes)

Uploaded Source

Built Distribution

envswitch-1.0.0-py3-none-any.whl (21.2 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page