auxilium


Nameauxilium JSON
Version 0.2.8 PyPI version JSON
download
home_pagehttps://github.com/sonntagsgesicht/auxilium
SummaryPython project for an automated test and deploy toolkit.
upload_time2022-01-15 00:17:11
maintainer
docs_urlNone
authorsonntagsgesicht
requires_python
licenseApache License 2.0
keywords
VCS
bugtrack_url
requirements None bandit black coverage dulwich flake8 isort pycodestyle pydocstyle pylint pytest pytest-cov regtest safety Sphinx sphinx-math-dollar sphinx-rtd-theme karma-sphinx-theme sphinx-pytype-substitution sphinxcontrib_programoutput
Travis-CI No Travis.
coveralls test coverage No coveralls.
            

.. image:: https://raw.githubusercontent.com/sonntagsgesicht/auxilium/master/doc/pix/auxilium_logo.png

|codeship|_ |readthedocs|_ |license|_ |github_version|_ |pip_version|_
|py_version|_ |pypi_downloads|_

.. |codeship| image:: https://img.shields.io/codeship/5b8cc2e0-ac1d-0137-31a2-06d5e6117547/master.svg
.. _codeship: https://codeship.com//projects/362165

.. |readthedocs| image:: https://img.shields.io/readthedocs/auxilium
.. _readthedocs: https://auxilium.readthedocs.io/en/latest/intro.html

.. |license| image:: https://img.shields.io/github/license/sonntagsgesicht/auxilium
.. _license: https://github.com/sonntagsgesicht/auxilium/raw/master/LICENSE

.. |github_version| image:: https://img.shields.io/github/release/sonntagsgesicht/auxilium?label=github
.. _github_version: https://github.com/sonntagsgesicht/auxilium/releases

.. |pip_version| image:: https://img.shields.io/pypi/v/auxilium
.. _pip_version: https://pypi.org/project/auxilium/

.. |py_version| image:: https://img.shields.io/pypi/pyversions/auxilium
.. _py_version: https://pypi.org/project/auxilium/

.. |pypi_frequency| image:: https://img.shields.io/pypi/dm/auxilium
.. _pypi_frequency: https://pypi.org/project/auxilium/

.. |pypi_downloads| image:: https://pepy.tech/badge/auxilium
.. _pypi_downloads: https://pypi.org/project/auxilium/

A Python project for an automated test and deploy toolkit - 100% reusable.


Code, Documentation and Tests
-----------------------------

Modern software development comes as a triple of

.. image:: https://raw.githubusercontent.com/sonntagsgesicht/auxilium/master/doc/pix/code-test-doc.png

.. .. :alt: **code is for machines** // **tests links docs and code** // **docs are for humans**



* The **code** is the actual software program or library which can executed or
  invoked.

* The **documentation** should give an introducing the idea and mission,
  guide how to use it, describe functionality and features.

* Finally, intensive **tests** increases the confidence that the documented
  functionality is correctly implemented.


To support this **auxilium** is designed to build, to auto-doc, to test and
to deploy small to medium size Python projects in **3 simple steps**.

1. copy your **source code** into a boilerplate project structure

2. write useful **documentation** in your python source code doc strings

3. add as many as possible **test cases**
   in a designated test directory structure


What's in the box?
------------------

Once setup up, **auxilium** serves as a development and integration
workflow manager. It provides tools to run a ci/cd
(continuous integration/continuous deployment) framework with state-of-art
development and integration tools like

* source code management with `git <https://git-scm.com>`_

* python environment virtualization with
  `venv <https://docs.python.org/3/tutorial/venv.html>`_

* integrated dependency management with `pip <https://pip.pypa.io>`_

* source code quality and style validation with
  `flake8 <https://flake8.pycqa.org>`_

* source code security checks with `bandit <https://bandit.readthedocs.io>`_

* automated software testing with
  `unittest <https://docs.python.org/3/library/unittest.html>`_
  and `regtest <https://regtest.readthedocs.io>`_

* test coverage measurement with `coverage <http://coverage.readthedocs.io>`_

* automated documentation generation with `sphinx <https://sphinx-doc.org>`_

* documentation templates base on
  `restructuredtext <https://docutils.sourceforge.io/rst.html>`_
  markup language

* designed to work even at online sites like
  `PyPi.com <https://pypi.org>`_ and `GitHub <https://github.com>`_

* standard python distribution packaging with
  `build <https://pypa-build.readthedocs.io/en/stable/index.html>`_
  and `twine <https://twine.readthedocs.io/en/latest/>`_

* remote `git` repo management for
  `BitBucket <https://bitbucket.com>`_,
  `GitHub <https://github.com>`_,
  `GitLab <https://gitlab.com>`_

* single command software release deployment to `PyPi <https://pypi.org>`_
  the Python Package Index database


How does it work?
-----------------

* conventions on how the project is structured,
  i.e. where to find source, test and doc files

* provides useful template structure of files
  which can be easy modified and extended

* keeps always a single source of truth
  for project information (like version number)

* sets up a clear and straight structure of the project
  as well as the corresponding documentation

* minimises the places to edit,
  by default there are only three documentation files to be edited

* comes with a shell script to trigger plenty test and analysis routines
  incl. drafting pushing on git remotes and distribute on pypi.org

* uses standard community tools
  like *unittest*, *flake8*, *coverage*, *sphinx* and more

* no detailed configurations of any tools are needed,
  so you can focus completely on coding your project

* demo of how to use the framework and various services to build true *ci/cd*;
  a full automated test and deploy pipeline for the rest of us.

* creates and uses *venv* virtual environment to test
  on clean python installation

Moreover, we recommend to use *pyenv* and *virtualenv*
to test different python installations, too.


Quick Start a Project
---------------------

Once installed simply invoke :code:`auxilium create`
and enter a few project details.

The whole project structure will be created.
Full functioning incl. documentation generation, testing, etc..


.. code-block:: bash

    $ auxilium create

     Please enter project details.

    Enter project name   : unicorn
    Enter project slogan : Always be a unicorn.
    Enter project author : dreamer
    Enter project email  : dreamer@home
    Enter project url    : www.dreamer.home/unicorn

    Created project unicorn with these files:

      unicorn/CHANGES.rst
      unicorn/HOWTO.rst
      unicorn/LICENSE
      unicorn/MANIFEST.in
      unicorn/README.rst
      unicorn/requirements.txt
      unicorn/setup.py
      unicorn/upgrade_requirements.txt

      unicorn/doc/sphinx/conf.py
      unicorn/doc/sphinx/doc.rst
      unicorn/doc/sphinx/index.rst
      unicorn/doc/sphinx/intro.rst
      unicorn/doc/sphinx/logo.png
      unicorn/doc/sphinx/releases.rst
      unicorn/doc/sphinx/tutorial.rst

      unicorn/test/__init__.py
      unicorn/test/unittests.py

      unicorn/unicorn/__init__.py


Default Structure of a Project
------------------------------

The top level of the directory structure consists of three sub-dirs for source,
doc and test files and some more or less standard project files.
Assume the project is called *unicorn*.

.. code-block:: bash

   /unicorn (project root dir)

      /.aux/venv (virtual python environment)

      /unicorn (python source files)
      /doc/sphinx (sphinx files)
      /test/unittests (unittest files)

      LICENSE (license to use)

      CHANGES.rst (change history)
      HOWTO.rst (user guide)
      README.rst (introduction)

      requirements.txt (pip dependencies)
      upgrade_requirements.txt (pip dependencies which always have to be upgraded)

      setup.py (configuration file to build a distribution)
      MANIFEST.in (configuration file to build a distribution)

      .gitignore (configuration file - files and folder which git should ignore)

On top level there ate the following files

* **LICENSE** is the license how to use, change or distribute the project.

* **CHANGES.rst** will contain the whole change and release history

* **HOWTO.rst** gives a intro how to use your project.
  This will show up in your documentation as tutorial.

* **README.rst** is this page which
  shows up on repository homepage at first.
  Moreover, this will show up in your documentation as introduction, too.

* **requirements.txt** are additional python packages,
  which are required for development and/or testing

* **upgrade_requirements.txt** are additional python packages
  (same as *requirements.txt*), which have to be upgraded,
  i.e. installed by :code:`pip` with the *--upgrade* option.
  Usually used for dev repos.

* **setup.py** configs the installation procedure with pip
  and the meta keywords of your project on pypi.org.
  Most of the entries are found in the project **__init__.py** file.

* **MANIFEST.in** configs the files
  which will be part of the final distribution.

* **.gitignore** configs git which files and folder to ignore

and subdirectories

* **.aux/venv** which contains the virtual python environment

* **unicorn/** as the actual python source directory
  (place to put the python scripts)
  **Note, project root dir and python source dir must have the same name!**


* **doc/sphinx/** file read by sphinx to build documentation sites
  which can be extended, e.g. by :code:`auxilium doc --api`,
  but also manually.

* **test/** to contain all test scripts and data
  (by default there will be two:
  :code:`unittests.py` and :code:`regtests.py`)


As the actual python source files can be structured as you like inside

.. code-block:: bash

    unicorn/unicorn/

only few information on your project are required and should be found in

.. code-block:: bash

   unicorn/unicorn/__init__.py

Most of them are needed to setup the *pip* installation (using *setuptools*),
deployment to `PyPi.org <https://pypi.org>`_
as well as the sphinx configuration for generation a documentation.
See here how :code:`unicorn/unicorn/__init__.py` looks like.

.. code-block:: python

   # -*- coding: utf-8 -*-

   # unicorn
   # -------
   # Always be a unicorn.
   #
   # Author:   dreamer
   # Version:  0.1, copyright Thursday, 29 August 2019
   # Website:  https://github.com/dreamer/unicorn
   # License:  Apache License 2.0 (see LICENSE file)


   import logging

   logging.getLogger(__name__).addHandler(logging.NullHandler())

   __doc__ = 'Always be a unicorn.'
   __license__ = 'Apache License 2.0'

   __author__ = 'dreamer'
   __email__ = 'unicorn@home'
   __url__ = 'https://www.dreamer.home/unicorn'

   __date__ = 'Thursday, 29 August 2019'
   __version__ = '0.1'
   __dev_status__ = '3 - Alpha'

   __dependencies__ = ()
   __dependency_links__ = ()
   __data__ = ()
   __scripts__ = ()
   __theme__ = ''

Once setup up, update file headers of all new and modified files
and adding them to the project source code repository simply by
:code:`auxilium update`.


Automated Documentation Generation
----------------------------------

The documentation is generated by sphinx_
and the main documentation files is located at

.. code-block:: bash

   /auxilium (project root dir)

      /doc/sphinx (sphinx files)

**auxilium** extracts all docs from the source code file and links
to some top level *rst* files.

So usually no file under :code:`/doc/sphinx` requires to be edited.

The site-map of a documentation will look like this

.. code-block:: bash

   /index.rst
      /intro.rst     -> README.rst
      /tutorial.rst  -> HOWTO.rst
      /doc.rst       -> api/* (generated by *sphinx-apidoc* via :code:`auxilium doc --api`)
      /releases.rst  -> CHANGES.rst

The project has a configuration (*conf.py*) to build *html* and *latex* resp.
*pdf* documentation. The later requires a latex installation to work.

And **auxilium** will run and check *code-blocks* of code examples
of your documentation during doc build (*doctest*).

All this is executed by just one command :code:`auxilium doc`.

Since only **doc.rst** will not refer to a top level doc file of the project
it is generated from the source code.
So here the work starts to write good python doc strings
in your source code files.

But if a more *sphinx* specific file reps. documentation is preferred.
May be in order to provide detailed insights into the project:
Simply delete :code:`api/*` (if existing) and replace the contents
of **doc.rst**.

More on documentation can be found in the
`documentation <https://auxilium.readthedocs.io/en/latest/doc.html>`_.


Automated Test and Test Coverage Framework
------------------------------------------

Test are invoked by
`unittest discovery <https://docs.python.org/3/library/unittest.html#test-discovery>`_
which searches by default for files
containing :code:`unittest.TestCase` classes and process them.

Same for measuring the test coverage
using coverage_
source code security and quality
using bandit_
and flake8_.

.. code-block:: bash

   /unicorn (project root dir)

      /test/unittests (unittest files)

Run all tests and checks with :code:`auxilium test`.

More on testing can be found in the documentation_.


Automated Build and Deployment Framework
----------------------------------------

Once a project milestone is reached, docs are written
and all tests are successfully passed,
it is ready for deployment.

The default deployment platform is `PyPi.org <https://pypi.org>`_.
Before deploying a distribution package is build.
Moreover, it's time to update (*push* to) the project state to
a git remote repo like on
GitHub_, GitLab_ anf BitBucket_

Invoke this with :code:`auxilium build`.
To *push* and *deploy* add options :code:`--push` and :code:`--deploy`.

More on build and deployment can be found in the documentation_.


Installation
------------

The latest stable version can always be installed or updated via pip:

.. code-block:: bash

    $ pip install auxilium



Development Version
-------------------

The latest development version can be installed directly from GitHub:

.. code-block:: bash

    $ pip install --upgrade git+https://github.com/sonntagsgesicht/auxilium.git


Contributions
-------------

.. _issues: https://github.com/sonntagsgesicht/auxilium/issues
.. __: https://github.com/sonntagsgesicht/auxilium/pulls

Issues_ and `Pull Requests`__ are always welcome.


License
-------

.. __: https://github.com/sonntagsgesicht/auxilium/raw/master/LICENSE

Code and documentation are available according
to the Apache Software License (see LICENSE__).





            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/sonntagsgesicht/auxilium",
    "name": "auxilium",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "",
    "author": "sonntagsgesicht",
    "author_email": "sonntagsgesicht@icloud.com",
    "download_url": "https://files.pythonhosted.org/packages/84/59/954581d234cee2e723ca98b13332ffbfd27e480b058b50f72ec476105d58/auxilium-0.2.8.zip",
    "platform": "any",
    "description": "\n\n.. image:: https://raw.githubusercontent.com/sonntagsgesicht/auxilium/master/doc/pix/auxilium_logo.png\n\n|codeship|_ |readthedocs|_ |license|_ |github_version|_ |pip_version|_\n|py_version|_ |pypi_downloads|_\n\n.. |codeship| image:: https://img.shields.io/codeship/5b8cc2e0-ac1d-0137-31a2-06d5e6117547/master.svg\n.. _codeship: https://codeship.com//projects/362165\n\n.. |readthedocs| image:: https://img.shields.io/readthedocs/auxilium\n.. _readthedocs: https://auxilium.readthedocs.io/en/latest/intro.html\n\n.. |license| image:: https://img.shields.io/github/license/sonntagsgesicht/auxilium\n.. _license: https://github.com/sonntagsgesicht/auxilium/raw/master/LICENSE\n\n.. |github_version| image:: https://img.shields.io/github/release/sonntagsgesicht/auxilium?label=github\n.. _github_version: https://github.com/sonntagsgesicht/auxilium/releases\n\n.. |pip_version| image:: https://img.shields.io/pypi/v/auxilium\n.. _pip_version: https://pypi.org/project/auxilium/\n\n.. |py_version| image:: https://img.shields.io/pypi/pyversions/auxilium\n.. _py_version: https://pypi.org/project/auxilium/\n\n.. |pypi_frequency| image:: https://img.shields.io/pypi/dm/auxilium\n.. _pypi_frequency: https://pypi.org/project/auxilium/\n\n.. |pypi_downloads| image:: https://pepy.tech/badge/auxilium\n.. _pypi_downloads: https://pypi.org/project/auxilium/\n\nA Python project for an automated test and deploy toolkit - 100% reusable.\n\n\nCode, Documentation and Tests\n-----------------------------\n\nModern software development comes as a triple of\n\n.. image:: https://raw.githubusercontent.com/sonntagsgesicht/auxilium/master/doc/pix/code-test-doc.png\n\n.. .. :alt: **code is for machines** // **tests links docs and code** // **docs are for humans**\n\n\n\n* The **code** is the actual software program or library which can executed or\n  invoked.\n\n* The **documentation** should give an introducing the idea and mission,\n  guide how to use it, describe functionality and features.\n\n* Finally, intensive **tests** increases the confidence that the documented\n  functionality is correctly implemented.\n\n\nTo support this **auxilium** is designed to build, to auto-doc, to test and\nto deploy small to medium size Python projects in **3 simple steps**.\n\n1. copy your **source code** into a boilerplate project structure\n\n2. write useful **documentation** in your python source code doc strings\n\n3. add as many as possible **test cases**\n   in a designated test directory structure\n\n\nWhat's in the box?\n------------------\n\nOnce setup up, **auxilium** serves as a development and integration\nworkflow manager. It provides tools to run a ci/cd\n(continuous integration/continuous deployment) framework with state-of-art\ndevelopment and integration tools like\n\n* source code management with `git <https://git-scm.com>`_\n\n* python environment virtualization with\n  `venv <https://docs.python.org/3/tutorial/venv.html>`_\n\n* integrated dependency management with `pip <https://pip.pypa.io>`_\n\n* source code quality and style validation with\n  `flake8 <https://flake8.pycqa.org>`_\n\n* source code security checks with `bandit <https://bandit.readthedocs.io>`_\n\n* automated software testing with\n  `unittest <https://docs.python.org/3/library/unittest.html>`_\n  and `regtest <https://regtest.readthedocs.io>`_\n\n* test coverage measurement with `coverage <http://coverage.readthedocs.io>`_\n\n* automated documentation generation with `sphinx <https://sphinx-doc.org>`_\n\n* documentation templates base on\n  `restructuredtext <https://docutils.sourceforge.io/rst.html>`_\n  markup language\n\n* designed to work even at online sites like\n  `PyPi.com <https://pypi.org>`_ and `GitHub <https://github.com>`_\n\n* standard python distribution packaging with\n  `build <https://pypa-build.readthedocs.io/en/stable/index.html>`_\n  and `twine <https://twine.readthedocs.io/en/latest/>`_\n\n* remote `git` repo management for\n  `BitBucket <https://bitbucket.com>`_,\n  `GitHub <https://github.com>`_,\n  `GitLab <https://gitlab.com>`_\n\n* single command software release deployment to `PyPi <https://pypi.org>`_\n  the Python Package Index database\n\n\nHow does it work?\n-----------------\n\n* conventions on how the project is structured,\n  i.e. where to find source, test and doc files\n\n* provides useful template structure of files\n  which can be easy modified and extended\n\n* keeps always a single source of truth\n  for project information (like version number)\n\n* sets up a clear and straight structure of the project\n  as well as the corresponding documentation\n\n* minimises the places to edit,\n  by default there are only three documentation files to be edited\n\n* comes with a shell script to trigger plenty test and analysis routines\n  incl. drafting pushing on git remotes and distribute on pypi.org\n\n* uses standard community tools\n  like *unittest*, *flake8*, *coverage*, *sphinx* and more\n\n* no detailed configurations of any tools are needed,\n  so you can focus completely on coding your project\n\n* demo of how to use the framework and various services to build true *ci/cd*;\n  a full automated test and deploy pipeline for the rest of us.\n\n* creates and uses *venv* virtual environment to test\n  on clean python installation\n\nMoreover, we recommend to use *pyenv* and *virtualenv*\nto test different python installations, too.\n\n\nQuick Start a Project\n---------------------\n\nOnce installed simply invoke :code:`auxilium create`\nand enter a few project details.\n\nThe whole project structure will be created.\nFull functioning incl. documentation generation, testing, etc..\n\n\n.. code-block:: bash\n\n    $ auxilium create\n\n     Please enter project details.\n\n    Enter project name   : unicorn\n    Enter project slogan : Always be a unicorn.\n    Enter project author : dreamer\n    Enter project email  : dreamer@home\n    Enter project url    : www.dreamer.home/unicorn\n\n    Created project unicorn with these files:\n\n      unicorn/CHANGES.rst\n      unicorn/HOWTO.rst\n      unicorn/LICENSE\n      unicorn/MANIFEST.in\n      unicorn/README.rst\n      unicorn/requirements.txt\n      unicorn/setup.py\n      unicorn/upgrade_requirements.txt\n\n      unicorn/doc/sphinx/conf.py\n      unicorn/doc/sphinx/doc.rst\n      unicorn/doc/sphinx/index.rst\n      unicorn/doc/sphinx/intro.rst\n      unicorn/doc/sphinx/logo.png\n      unicorn/doc/sphinx/releases.rst\n      unicorn/doc/sphinx/tutorial.rst\n\n      unicorn/test/__init__.py\n      unicorn/test/unittests.py\n\n      unicorn/unicorn/__init__.py\n\n\nDefault Structure of a Project\n------------------------------\n\nThe top level of the directory structure consists of three sub-dirs for source,\ndoc and test files and some more or less standard project files.\nAssume the project is called *unicorn*.\n\n.. code-block:: bash\n\n   /unicorn (project root dir)\n\n      /.aux/venv (virtual python environment)\n\n      /unicorn (python source files)\n      /doc/sphinx (sphinx files)\n      /test/unittests (unittest files)\n\n      LICENSE (license to use)\n\n      CHANGES.rst (change history)\n      HOWTO.rst (user guide)\n      README.rst (introduction)\n\n      requirements.txt (pip dependencies)\n      upgrade_requirements.txt (pip dependencies which always have to be upgraded)\n\n      setup.py (configuration file to build a distribution)\n      MANIFEST.in (configuration file to build a distribution)\n\n      .gitignore (configuration file - files and folder which git should ignore)\n\nOn top level there ate the following files\n\n* **LICENSE** is the license how to use, change or distribute the project.\n\n* **CHANGES.rst** will contain the whole change and release history\n\n* **HOWTO.rst** gives a intro how to use your project.\n  This will show up in your documentation as tutorial.\n\n* **README.rst** is this page which\n  shows up on repository homepage at first.\n  Moreover, this will show up in your documentation as introduction, too.\n\n* **requirements.txt** are additional python packages,\n  which are required for development and/or testing\n\n* **upgrade_requirements.txt** are additional python packages\n  (same as *requirements.txt*), which have to be upgraded,\n  i.e. installed by :code:`pip` with the *--upgrade* option.\n  Usually used for dev repos.\n\n* **setup.py** configs the installation procedure with pip\n  and the meta keywords of your project on pypi.org.\n  Most of the entries are found in the project **__init__.py** file.\n\n* **MANIFEST.in** configs the files\n  which will be part of the final distribution.\n\n* **.gitignore** configs git which files and folder to ignore\n\nand subdirectories\n\n* **.aux/venv** which contains the virtual python environment\n\n* **unicorn/** as the actual python source directory\n  (place to put the python scripts)\n  **Note, project root dir and python source dir must have the same name!**\n\n\n* **doc/sphinx/** file read by sphinx to build documentation sites\n  which can be extended, e.g. by :code:`auxilium doc --api`,\n  but also manually.\n\n* **test/** to contain all test scripts and data\n  (by default there will be two:\n  :code:`unittests.py` and :code:`regtests.py`)\n\n\nAs the actual python source files can be structured as you like inside\n\n.. code-block:: bash\n\n    unicorn/unicorn/\n\nonly few information on your project are required and should be found in\n\n.. code-block:: bash\n\n   unicorn/unicorn/__init__.py\n\nMost of them are needed to setup the *pip* installation (using *setuptools*),\ndeployment to `PyPi.org <https://pypi.org>`_\nas well as the sphinx configuration for generation a documentation.\nSee here how :code:`unicorn/unicorn/__init__.py` looks like.\n\n.. code-block:: python\n\n   # -*- coding: utf-8 -*-\n\n   # unicorn\n   # -------\n   # Always be a unicorn.\n   #\n   # Author:   dreamer\n   # Version:  0.1, copyright Thursday, 29 August 2019\n   # Website:  https://github.com/dreamer/unicorn\n   # License:  Apache License 2.0 (see LICENSE file)\n\n\n   import logging\n\n   logging.getLogger(__name__).addHandler(logging.NullHandler())\n\n   __doc__ = 'Always be a unicorn.'\n   __license__ = 'Apache License 2.0'\n\n   __author__ = 'dreamer'\n   __email__ = 'unicorn@home'\n   __url__ = 'https://www.dreamer.home/unicorn'\n\n   __date__ = 'Thursday, 29 August 2019'\n   __version__ = '0.1'\n   __dev_status__ = '3 - Alpha'\n\n   __dependencies__ = ()\n   __dependency_links__ = ()\n   __data__ = ()\n   __scripts__ = ()\n   __theme__ = ''\n\nOnce setup up, update file headers of all new and modified files\nand adding them to the project source code repository simply by\n:code:`auxilium update`.\n\n\nAutomated Documentation Generation\n----------------------------------\n\nThe documentation is generated by sphinx_\nand the main documentation files is located at\n\n.. code-block:: bash\n\n   /auxilium (project root dir)\n\n      /doc/sphinx (sphinx files)\n\n**auxilium** extracts all docs from the source code file and links\nto some top level *rst* files.\n\nSo usually no file under :code:`/doc/sphinx` requires to be edited.\n\nThe site-map of a documentation will look like this\n\n.. code-block:: bash\n\n   /index.rst\n      /intro.rst     -> README.rst\n      /tutorial.rst  -> HOWTO.rst\n      /doc.rst       -> api/* (generated by *sphinx-apidoc* via :code:`auxilium doc --api`)\n      /releases.rst  -> CHANGES.rst\n\nThe project has a configuration (*conf.py*) to build *html* and *latex* resp.\n*pdf* documentation. The later requires a latex installation to work.\n\nAnd **auxilium** will run and check *code-blocks* of code examples\nof your documentation during doc build (*doctest*).\n\nAll this is executed by just one command :code:`auxilium doc`.\n\nSince only **doc.rst** will not refer to a top level doc file of the project\nit is generated from the source code.\nSo here the work starts to write good python doc strings\nin your source code files.\n\nBut if a more *sphinx* specific file reps. documentation is preferred.\nMay be in order to provide detailed insights into the project:\nSimply delete :code:`api/*` (if existing) and replace the contents\nof **doc.rst**.\n\nMore on documentation can be found in the\n`documentation <https://auxilium.readthedocs.io/en/latest/doc.html>`_.\n\n\nAutomated Test and Test Coverage Framework\n------------------------------------------\n\nTest are invoked by\n`unittest discovery <https://docs.python.org/3/library/unittest.html#test-discovery>`_\nwhich searches by default for files\ncontaining :code:`unittest.TestCase` classes and process them.\n\nSame for measuring the test coverage\nusing coverage_\nsource code security and quality\nusing bandit_\nand flake8_.\n\n.. code-block:: bash\n\n   /unicorn (project root dir)\n\n      /test/unittests (unittest files)\n\nRun all tests and checks with :code:`auxilium test`.\n\nMore on testing can be found in the documentation_.\n\n\nAutomated Build and Deployment Framework\n----------------------------------------\n\nOnce a project milestone is reached, docs are written\nand all tests are successfully passed,\nit is ready for deployment.\n\nThe default deployment platform is `PyPi.org <https://pypi.org>`_.\nBefore deploying a distribution package is build.\nMoreover, it's time to update (*push* to) the project state to\na git remote repo like on\nGitHub_, GitLab_ anf BitBucket_\n\nInvoke this with :code:`auxilium build`.\nTo *push* and *deploy* add options :code:`--push` and :code:`--deploy`.\n\nMore on build and deployment can be found in the documentation_.\n\n\nInstallation\n------------\n\nThe latest stable version can always be installed or updated via pip:\n\n.. code-block:: bash\n\n    $ pip install auxilium\n\n\n\nDevelopment Version\n-------------------\n\nThe latest development version can be installed directly from GitHub:\n\n.. code-block:: bash\n\n    $ pip install --upgrade git+https://github.com/sonntagsgesicht/auxilium.git\n\n\nContributions\n-------------\n\n.. _issues: https://github.com/sonntagsgesicht/auxilium/issues\n.. __: https://github.com/sonntagsgesicht/auxilium/pulls\n\nIssues_ and `Pull Requests`__ are always welcome.\n\n\nLicense\n-------\n\n.. __: https://github.com/sonntagsgesicht/auxilium/raw/master/LICENSE\n\nCode and documentation are available according\nto the Apache Software License (see LICENSE__).\n\n\n\n\n",
    "bugtrack_url": null,
    "license": "Apache License 2.0",
    "summary": "Python project for an automated test and deploy toolkit.",
    "version": "0.2.8",
    "project_urls": {
        "Homepage": "https://github.com/sonntagsgesicht/auxilium"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8459954581d234cee2e723ca98b13332ffbfd27e480b058b50f72ec476105d58",
                "md5": "8ad9144f8936ad6f50f62d72a5554680",
                "sha256": "3fea80cc073e87622182e7f8c829cce1fc1816ad5a228674ad169f0433ddc174"
            },
            "downloads": -1,
            "filename": "auxilium-0.2.8.zip",
            "has_sig": false,
            "md5_digest": "8ad9144f8936ad6f50f62d72a5554680",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 86940,
            "upload_time": "2022-01-15T00:17:11",
            "upload_time_iso_8601": "2022-01-15T00:17:11.646768Z",
            "url": "https://files.pythonhosted.org/packages/84/59/954581d234cee2e723ca98b13332ffbfd27e480b058b50f72ec476105d58/auxilium-0.2.8.zip",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2022-01-15 00:17:11",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "sonntagsgesicht",
    "github_project": "auxilium",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": null,
            "specs": []
        },
        {
            "name": "bandit",
            "specs": []
        },
        {
            "name": "black",
            "specs": []
        },
        {
            "name": "coverage",
            "specs": []
        },
        {
            "name": "dulwich",
            "specs": []
        },
        {
            "name": "flake8",
            "specs": []
        },
        {
            "name": "isort",
            "specs": []
        },
        {
            "name": "pycodestyle",
            "specs": []
        },
        {
            "name": "pydocstyle",
            "specs": []
        },
        {
            "name": "pylint",
            "specs": []
        },
        {
            "name": "pytest",
            "specs": []
        },
        {
            "name": "pytest-cov",
            "specs": []
        },
        {
            "name": "regtest",
            "specs": []
        },
        {
            "name": "safety",
            "specs": []
        },
        {
            "name": "Sphinx",
            "specs": []
        },
        {
            "name": "sphinx-math-dollar",
            "specs": []
        },
        {
            "name": "sphinx-rtd-theme",
            "specs": []
        },
        {
            "name": "karma-sphinx-theme",
            "specs": []
        },
        {
            "name": "sphinx-pytype-substitution",
            "specs": []
        },
        {
            "name": "sphinxcontrib_programoutput",
            "specs": []
        }
    ],
    "lcname": "auxilium"
}
        
Elapsed time: 0.36731s