Skip to main content

External test plugin for cmd2. Allows for external invocation of commands as if from a cmd2 pyscript

Project description

cmd2 External Test Plugin

Table of Contents

Overview

This plugin supports testing of a cmd2 application by exposing access cmd2 commands with the same context as from within a cmd2 pyscript. This allows for verification of an application's support for pyscripts.

Example cmd2 Application

The following short example shows how to mix in the external test plugin to create a fixture for testing your cmd2 application.

Define your cmd2 application

import cmd2
class ExampleApp(cmd2.Cmd):
    """An class to show how to use a plugin"""
    def __init__(self, *args, **kwargs):
        # gotta have this or neither the plugin or cmd2 will initialize
        super().__init__(*args, **kwargs)

    def do_something(self, arg):
        self.last_result = 5
        self.poutput('this is the something command')

Defining the test fixture

In your test, define a fixture for your cmd2 application

import cmd2_ext_test
import pytest

class ExampleAppTester(cmd2_ext_test.ExternalTestMixin, ExampleApp):
    def __init__(self, *args, **kwargs):
        # gotta have this or neither the plugin or cmd2 will initialize
        super().__init__(*args, **kwargs)

@pytest.fixture
def example_app():
    app = ExampleAppTester()
    app.fixture_setup()
    yield app
    app.fixture_teardown()

Writing Tests

Now write your tests that validate your application using the app_cmd function to access the cmd2 application's commands. This allows invocation of the application's commands in the same format as a user would type. The results from calling a command matches what is returned from running an python script with cmd2's pyscript command, which provides stdout, stderr, and the command's result data.

from cmd2 import CommandResult

def test_something(example_app):
    # execute a command
    out = example_app.app_cmd("something")

    # validate the command output and result data
    assert isinstance(out, CommandResult)
    assert str(out.stdout).strip() == 'this is the something command'
    assert out.data == 5

License

cmd2 uses the very liberal MIT license. We invite plugin authors to consider doing the same.

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

cmd2-ext-test-0.2.0.tar.gz (8.1 kB view details)

Uploaded Source

Built Distribution

cmd2_ext_test-0.2.0-py3-none-any.whl (3.8 kB view details)

Uploaded Python 3

File details

Details for the file cmd2-ext-test-0.2.0.tar.gz.

File metadata

  • Download URL: cmd2-ext-test-0.2.0.tar.gz
  • Upload date:
  • Size: 8.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.8.2

File hashes

Hashes for cmd2-ext-test-0.2.0.tar.gz
Algorithm Hash digest
SHA256 76c66fa914b9fdf9f5e9b4adb81783ffca925dc223dd40e8cb7bc01d13c49c47
MD5 c19c9082c6cbb19bfbb6bab11f8bfe10
BLAKE2b-256 dde2c9f0eeaf73e35222f31708f8d268d22b18bfcfaf6ab8747a132cc6df57c0

See more details on using hashes here.

File details

Details for the file cmd2_ext_test-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: cmd2_ext_test-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 3.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.8.2

File hashes

Hashes for cmd2_ext_test-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 20593396e6b67f1342e8498f61548712bcf6d5d4b03fb3acc2f00b2c15b001b0
MD5 4cdb9e0589713dcdc8f4aac697c82161
BLAKE2b-256 5fc9b7deeb46c67eb8ad4d578a9b5bc634974462a7bb315cab2e98326f88018a

See more details on using hashes here.

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