aurornis


Nameaurornis JSON
Version 1.5.0 PyPI version JSON
download
home_pagehttps://github.com/Deuchnord/Aurornis
SummaryA command line program test helper
upload_time2023-07-21 08:10:45
maintainer
docs_urlNone
authorJérôme Deuchnord
requires_python>=3.7,<4.0
licenseAGPL-3.0-or-later
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            # Aurornis - A command line program test helper

[![Coverage Status](https://coveralls.io/repos/github/Deuchnord/Aurornis/badge.svg?branch=main)](https://coveralls.io/github/Deuchnord/Aurornis?branch=main)

Aurornis is a small, yet powerful library designed to help testing command line programs.
The name is a reference to the [_aurornis xui_](https://en.wikipedia.org/wiki/Aurornis), a prehistoric bird that lived 10 million years ago.

## Installation

Aurornis is available in PyPI, so all you need is to install it with PIP:

```bash
pip install --user aurornis
```

If you are using Pipenv or Poetry, it is recommended to install it as a development dependency:

```bash
pipenv install --dev aurornis
poetry add --dev aurornis
```

**Important note:** this library has not been tested on a production environment. For security reasons, it recommended to use it for development tests only.
This might evolve in the future.

## Main features

- One simple function: give it the command, and it will take care of all the complexity for you
- Supports the standard input, output and error
- Computes the execution time of the command, so you can test its global performance directly
- Provides a way to clean the colors to make testing simpler (with native support of the [`NO_COLOR` standard](https://no-color.org/))
- Supports Linux, macOS and Windows. Probably also works on FreeBSD.

## Basic usage

Aurornis provides a package with only one function to run a command, that returns an object with the result of the command:

```python
import aurornis

command_result = aurornis.run(["ls", "-la", "/"])
# <CommandResult command="ls -la /" return_code=0 stdout="total 68 ..." stderr="">
```

For better security and reproducibility, the environment variables of your system are not reproduced, with the exception of `$PATH` on UNIX and `SystemRoot` on Windows.

If you need to specify environment variables (or even overwrite some of them) before you run the command, add them to the `run` function:

```python
import aurornis

command_result = aurornis.run(["env"], environment={"HOME": "/home/deuchnord"})
```

By default, the `LANG` environment variable (used for internationalization) is reset to `C` (default system language, commonly English). You can change it if you want to test with another locale.

Once you get the result, all you need to do is to use your favorite unit test framework to check it returned what you expected it to return:

```python
import aurornis
import unittest

class CommandTest(unittest.TestCase):
    def test_ls_home(self):
        command_result = aurornis.run(["ls", "-l", "$HOME"], environment={"HOME": "/home/deuchnord"})
        # You can check quickly the command was successful:
        self.assertTrue(command_result.successful)
        # Or if you expected a more specific return value:
        self.assertEqual(2, command_result.return_code) # ls returns 2 if the file does not exist
        
        # Then, check the text returned in standard output and standard error:
        self.assertEqual("""total 6
drwxr-xr-x 1 deuchnord deuchnord 40 27 May 13:19 Desktop
drwxr-xr-x 1 deuchnord deuchnord 40 14 Oct 18:08 Documents
drwxr-xr-x 1 deuchnord deuchnord 40  1 Sep 16:52 Downloads
drwxr-xr-x 1 deuchnord deuchnord 40 29 Sep 09:11 Pictures
drwxr-xr-x 1 deuchnord deuchnord 40 11 Jun  2020 Music
drwxr-xr-x 1 deuchnord deuchnord 40 10 Nov 11:32 Videos""", command_result.stdout)
        self.assertEqual("", command_result.stderr)
```

If your command returns colors in your standard output or standard error, you can ask Aurornis to automatically remove them:

```python
import aurornis

aurornis.run(["echo", "-e", r'\e[0;32mHello World!\e[0m'], remove_colors=True)
```

This option also automatically sets [the standard `NO_COLOR` environment variable](https://no-color.org). If your application shows colors, you may want to handle this environment variable to facilitate their deactivation by end users.

## FAQ/Troubleshooting

### How to handle correctly the return lines when my tests are executed on both Windows and non-Windows systems? 

The `run()` function provides a way to handle it for you.
Just set the `normalize_carriage_return` argument to `True`, and any `\r\n` will be replaced with `\n`.
This will become the default behavior in the version 2.0.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/Deuchnord/Aurornis",
    "name": "aurornis",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.7,<4.0",
    "maintainer_email": "",
    "keywords": "",
    "author": "J\u00e9r\u00f4me Deuchnord",
    "author_email": "jerome@deuchnord.fr",
    "download_url": "https://files.pythonhosted.org/packages/46/1f/4d988aedee6b44607eab83754355f30852d15f3f2a2b4db1128045b7004c/aurornis-1.5.0.tar.gz",
    "platform": null,
    "description": "# Aurornis - A command line program test helper\n\n[![Coverage Status](https://coveralls.io/repos/github/Deuchnord/Aurornis/badge.svg?branch=main)](https://coveralls.io/github/Deuchnord/Aurornis?branch=main)\n\nAurornis is a small, yet powerful library designed to help testing command line programs.\nThe name is a reference to the [_aurornis xui_](https://en.wikipedia.org/wiki/Aurornis), a prehistoric bird that lived 10 million years ago.\n\n## Installation\n\nAurornis is available in PyPI, so all you need is to install it with PIP:\n\n```bash\npip install --user aurornis\n```\n\nIf you are using Pipenv or Poetry, it is recommended to install it as a development dependency:\n\n```bash\npipenv install --dev aurornis\npoetry add --dev aurornis\n```\n\n**Important note:** this library has not been tested on a production environment. For security reasons, it recommended to use it for development tests only.\nThis might evolve in the future.\n\n## Main features\n\n- One simple function: give it the command, and it will take care of all the complexity for you\n- Supports the standard input, output and error\n- Computes the execution time of the command, so you can test its global performance directly\n- Provides a way to clean the colors to make testing simpler (with native support of the [`NO_COLOR` standard](https://no-color.org/))\n- Supports Linux, macOS and Windows. Probably also works on FreeBSD.\n\n## Basic usage\n\nAurornis provides a package with only one function to run a command, that returns an object with the result of the command:\n\n```python\nimport aurornis\n\ncommand_result = aurornis.run([\"ls\", \"-la\", \"/\"])\n# <CommandResult command=\"ls -la /\" return_code=0 stdout=\"total 68 ...\" stderr=\"\">\n```\n\nFor better security and reproducibility, the environment variables of your system are not reproduced, with the exception of `$PATH` on UNIX and `SystemRoot` on Windows.\n\nIf you need to specify environment variables (or even overwrite some of them) before you run the command, add them to the `run` function:\n\n```python\nimport aurornis\n\ncommand_result = aurornis.run([\"env\"], environment={\"HOME\": \"/home/deuchnord\"})\n```\n\nBy default, the `LANG` environment variable (used for internationalization) is reset to `C` (default system language, commonly English). You can change it if you want to test with another locale.\n\nOnce you get the result, all you need to do is to use your favorite unit test framework to check it returned what you expected it to return:\n\n```python\nimport aurornis\nimport unittest\n\nclass CommandTest(unittest.TestCase):\n    def test_ls_home(self):\n        command_result = aurornis.run([\"ls\", \"-l\", \"$HOME\"], environment={\"HOME\": \"/home/deuchnord\"})\n        # You can check quickly the command was successful:\n        self.assertTrue(command_result.successful)\n        # Or if you expected a more specific return value:\n        self.assertEqual(2, command_result.return_code) # ls returns 2 if the file does not exist\n        \n        # Then, check the text returned in standard output and standard error:\n        self.assertEqual(\"\"\"total 6\ndrwxr-xr-x 1 deuchnord deuchnord 40 27 May 13:19 Desktop\ndrwxr-xr-x 1 deuchnord deuchnord 40 14 Oct 18:08 Documents\ndrwxr-xr-x 1 deuchnord deuchnord 40  1 Sep 16:52 Downloads\ndrwxr-xr-x 1 deuchnord deuchnord 40 29 Sep 09:11 Pictures\ndrwxr-xr-x 1 deuchnord deuchnord 40 11 Jun  2020 Music\ndrwxr-xr-x 1 deuchnord deuchnord 40 10 Nov 11:32 Videos\"\"\", command_result.stdout)\n        self.assertEqual(\"\", command_result.stderr)\n```\n\nIf your command returns colors in your standard output or standard error, you can ask Aurornis to automatically remove them:\n\n```python\nimport aurornis\n\naurornis.run([\"echo\", \"-e\", r'\\e[0;32mHello World!\\e[0m'], remove_colors=True)\n```\n\nThis option also automatically sets [the standard `NO_COLOR` environment variable](https://no-color.org). If your application shows colors, you may want to handle this environment variable to facilitate their deactivation by end users.\n\n## FAQ/Troubleshooting\n\n### How to handle correctly the return lines when my tests are executed on both Windows and non-Windows systems? \n\nThe `run()` function provides a way to handle it for you.\nJust set the `normalize_carriage_return` argument to `True`, and any `\\r\\n` will be replaced with `\\n`.\nThis will become the default behavior in the version 2.0.\n",
    "bugtrack_url": null,
    "license": "AGPL-3.0-or-later",
    "summary": "A command line program test helper",
    "version": "1.5.0",
    "project_urls": {
        "Homepage": "https://github.com/Deuchnord/Aurornis",
        "Repository": "https://github.com/Deuchnord/Aurornis"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "41d990ba9d9b6f208c0da4538bfb6914f8d9c2434a4547bcc49f49e105a6a316",
                "md5": "7bb2385adbf07e4a8625fb21eeb88fef",
                "sha256": "565376bc5cec9f7f6797accc24e614fb43fc2bfb18d0b5576f2102a7c3be790d"
            },
            "downloads": -1,
            "filename": "aurornis-1.5.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "7bb2385adbf07e4a8625fb21eeb88fef",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7,<4.0",
            "size": 17687,
            "upload_time": "2023-07-21T08:10:42",
            "upload_time_iso_8601": "2023-07-21T08:10:42.656366Z",
            "url": "https://files.pythonhosted.org/packages/41/d9/90ba9d9b6f208c0da4538bfb6914f8d9c2434a4547bcc49f49e105a6a316/aurornis-1.5.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "461f4d988aedee6b44607eab83754355f30852d15f3f2a2b4db1128045b7004c",
                "md5": "843d93300ed1db51aaf249b8e62f4710",
                "sha256": "2cf67b43d480caeee60bbb99ba3d3139db47386347dace5dc77d7e3885e3993f"
            },
            "downloads": -1,
            "filename": "aurornis-1.5.0.tar.gz",
            "has_sig": false,
            "md5_digest": "843d93300ed1db51aaf249b8e62f4710",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7,<4.0",
            "size": 16568,
            "upload_time": "2023-07-21T08:10:45",
            "upload_time_iso_8601": "2023-07-21T08:10:45.387523Z",
            "url": "https://files.pythonhosted.org/packages/46/1f/4d988aedee6b44607eab83754355f30852d15f3f2a2b4db1128045b7004c/aurornis-1.5.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-07-21 08:10:45",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "Deuchnord",
    "github_project": "Aurornis",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "lcname": "aurornis"
}
        
Elapsed time: 0.10974s