Skip to main content

A Python CLI library for automated cloud deployment to Azure (ACI + ACR)

Project description

☁️ cloud_auto_deployor

PyPI version

cloud_auto_deployor is a Python package that simplifies end-to-end deployment of test automation projects to Azure using Docker and Azure Container Instances (ACI).
Ideal for local developers, QA teams, and CI/CD use cases.


Features

  • Auto-builds Docker image from your automation project
  • Pushes the image to Azure Container Registry (ACR)
  • Deploys the container to Azure Container Instance (ACI)
  • Automatically runs your test suite (e.g. Pytest) in the container
  • No manual Azure Portal steps required

Installation

pip install cloud-auto-deployor

Make sure you have Docker and Azure CLI installed and logged in (az login).


Setup

Your test automation project should include:

demo_project/
├── Dockerfile
├── requirements.txt
├── tests/
│   └── test_example.py
├── run_tests.py           # Triggers pytest
└── config.json            # Azure details (see below)

Example config.json

{
  "resource_group": "demo-deploy-group",
  "acr_name": "myacrdeploymentdemo",
  "image_name": "demo_project",
  "image_tag": "v1",
  "container_name": "demo-container",
  "location": "eastus"
}

Usage

From your test project root (where config.json lives), run:

python -m cloud_auto_deployor.main

What happens:

  1. Reads config.json
  2. Builds Docker image using your Dockerfile
  3. Pushes to ACR (auto-creates if needed)
  4. Deploys container instance (ACI)
  5. Automatically triggers run_tests.py to run your tests
  6. ✅ Results appear in Azure Portal Logs

Sample run_tests.py

import pytest
import os
import sys

def run_tests():
    sys.path.insert(0, os.getcwd())
    exit_code = pytest.main(["-vv", "tests/"])
    return exit_code

if __name__ == "__main__":
    run_tests()

Uninstall / Clean Up

To remove the container:

az container delete --name demo-container --resource-group demo-deploy-group --yes

To remove the image from ACR:

az acr repository delete --name myacrdeploymentdemo --image demo_project:v1 --yes

Author

Developed by Raja Periyasamy – Automation Lead | Azure DevOps Follower
📧 cloudautodeployer@gmail.com


License

MIT License


Release Notes

v1.0.2

  • Initial open-source release
  • Supports end-to-end Docker → ACR → ACI automation
  • Auto-triggers test execution from run_tests.py
  • Removed tracked config.json, now properly gitignored
  • Minor cleanup and security best practices applied

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

cloud_auto_deployor-1.0.2.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

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

cloud_auto_deployor-1.0.2-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file cloud_auto_deployor-1.0.2.tar.gz.

File metadata

  • Download URL: cloud_auto_deployor-1.0.2.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.1

File hashes

Hashes for cloud_auto_deployor-1.0.2.tar.gz
Algorithm Hash digest
SHA256 463be1b0f9d69935ad6c3c09dfbff65f25dbec34a2e4e90305b0af13831243b2
MD5 7ecdeb64671e3535eeda02a9ffbb3f2f
BLAKE2b-256 f17ca0d09c18078f8a29ab7e3e16d88fca996e3615a724db3091c6a9561d1973

See more details on using hashes here.

File details

Details for the file cloud_auto_deployor-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for cloud_auto_deployor-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0104e5249add3de369f2e449d974a1ee60b54e97107af165e98f148c28f38c3b
MD5 b4bff53ef7a14378eb8090cb0eeea260
BLAKE2b-256 b7f5241dbac75e850a94b8cfd19febea4dc5c2e6be17bc999fa0ace3b5eca609

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