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.4-py3-none-any.whl (290.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for genie_lamp-26.4-py3-none-any.whl
Algorithm Hash digest
SHA256 1511d126ec542d9c07c0aa4e6985f0b633d4eb106f52bf8469b2a8f69ef1ada4
MD5 723b810833ed14da706efc13a3e4145e
BLAKE2b-256 4c51b3a4429caa982139c39528a61392ed1e861fb4d9e4781de6282c30dcb538

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