Skip to main content

LAMP shell

Project description

LAMP

Overview

LAMP is an interactive command-line interface built on top of pyATS/Genie that enables users to connect to network devices and perform operations interactively. Think of it as a REPL (Read-Eval-Print Loop) for network automation—where you can execute commands, parse outputs, run APIs, and configure devices in real-time, all while LAMP automatically records your session into reusable Blitz YAML automation scripts.

LAMP bridges the gap between manual device interaction and automated testing. Instead of writing pyATS test scripts from scratch, you can work directly with your devices through LAMP's intuitive command interface. Every action you perform is automatically captured and can be replayed later, making it easy to convert exploratory work into production-ready automation.

Core Commands

  • execute - Run CLI commands on devices and capture output
  • configure - Apply configuration changes to devices
  • parse - Execute commands and parse output into structured data using Genie parsers
  • api - Execute Genie APIs for higher-level operations
  • bash_console - Interact with device bash/shell consoles
  • replay - Re-run previously recorded LAMP sessions (via Blitz YAML files)
  • sleep - Add delays between operations

Key Features

  • Interactive Shell Capabilities: Command history, autocompletion, and inline editing for smooth user experience
  • Automatic Recording: Every operation is automatically saved as Blitz YAML, turning interactive sessions into reusable automation scripts
  • Replay Workflows: Use the replay command to re-execute previously recorded sessions, enabling rapid iteration and workflow automation
  • Variables and Loops: Support for parameterized commands, variables, and loops to work with multiple devices efficiently
  • Include/Exclude Filters: Powerful filtering options for command outputs to focus on specific data

Installation

Prerequisites

  • Python >= 3.10
  • pyATS and Genie

For Development

git clone <repository-url>
cd genielamp
make develop

For Users

pip install genie

Starting LAMP

genie lamp

Developer's Guide

Code Quality Tools

When developing, ensure your code follows these standards:

  • black: Code formatting
  • isort: Import sorting
  • ruff: Linting
  • mypy: Type checking
  • lint-imports: Import linting

These checks are enforced in the CI pipeline.

Testing

Tests are written using pytest and located in the tests/ directory. Run tests with:

cd genielamp
pytest

Development Commands

# Setup development environment
make develop

# Format code
isort src/ tests/
black src/ tests/

# Check linting
ruff check src/ tests/

# Type checking
mypy src/

# Import linting
lint-imports --config importlinter.ini

# Run tests
pytest

How to Write a Changelog for Your Contribution

Every contribution to LAMP must include a changelog file describing the changes made. This helps maintain clear documentation of all modifications to the project.

1. Follow the Changelog Format

Familiarize yourself with the examples at changelogs/undistributed/template.rst. Changelogs must be written in the same style as the examples found there:

--------------------------------------------------------------------------------
                                New
--------------------------------------------------------------------------------
* <component>
    * <describe the changes>

--------------------------------------------------------------------------------
                                Fix
--------------------------------------------------------------------------------
* <component>
    * <describe the changes>

Example:

--------------------------------------------------------------------------------
                                New
--------------------------------------------------------------------------------
* UI
    * Added support for include/exclude filters with -i and -e flags

2. Create a Uniquely Named Changelog File

The changelog (singular) that accompanies a contribution must have a unique file name and be placed in changelogs/undistributed/.

To generate a unique file name, use the following bash/terminal command to generate a sufficiently unique timestamp (Linux and Mac):

$ date "+%Y%m%d%H%M%S"

Create your changelog file with a short description and the timestamp:

changelogs/undistributed/changelog_<short_description>_<timestamp>.rst

Example:

changelogs/undistributed/changelog_execute_filters_20200807212611.rst

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

genie_lamp-26.2-py3-none-any.whl (290.7 kB view details)

Uploaded Python 3

File details

Details for the file genie_lamp-26.2-py3-none-any.whl.

File metadata

  • Download URL: genie_lamp-26.2-py3-none-any.whl
  • Upload date:
  • Size: 290.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.10

File hashes

Hashes for genie_lamp-26.2-py3-none-any.whl
Algorithm Hash digest
SHA256 444f8b8a8bad754c7b0ed20936fc0cad53dabb32182fae29dddecd4abe26ee3e
MD5 d8cb94db8f5bb43811643110c722f897
BLAKE2b-256 f6ea4de272e5cf837e86261c501f1a6412e3174f57b86a2cbc1862a0d418104b

See more details on using hashes here.

Supported by

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