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
replaycommand 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1511d126ec542d9c07c0aa4e6985f0b633d4eb106f52bf8469b2a8f69ef1ada4
|
|
| MD5 |
723b810833ed14da706efc13a3e4145e
|
|
| BLAKE2b-256 |
4c51b3a4429caa982139c39528a61392ed1e861fb4d9e4781de6282c30dcb538
|