Moto. Hånande AWS

Testning är en integrerad del av utvecklingsprocessen. Och ibland måste utvecklare köra tester lokalt innan de genomför ändringar.
Om applikationen använder Amazon Web Services, pytonorm библиотека moto perfekt för detta.
Moto. Hånande AWS

En komplett lista över resurstäckning kan ses här.
Det finns en kålrot på Github Hugo Picado - moto-server. Klar bild, lansering och användning. Den enda nyansen är att efter lanseringen, nej AWS resurser har ännu inte skapats där.

Tja, det är lätt nog att fixa.

Sedan när du startar måste du ange typen av tjänst (env variabel MOTO_SERVICE), måste vi bara beskriva skapandet av resursen.

Låt oss ändra det lite start.sh:

I stället för

moto_server $MOTO_SERVICE -H $MOTO_HOST -p $MOTO_PORT

Föra in:

if [ -f /opt/init/bootstrap.py ]; then
  moto_server $MOTO_SERVICE -H $MOTO_HOST -p $MOTO_PORT & (sleep 5 && echo "Executing bootstrap script." && python /opt/init/bootstrap.py)
else
  moto_server $MOTO_SERVICE -H $MOTO_HOST -p $MOTO_PORT
fi
wait

Den sista filen är:

start.sh

#!/bin/sh

# validate required input
if [ -z "$MOTO_SERVICE" ]; then
  echo "Please define AWS service to run with Moto Server (e.g. s3, ec2, etc)"
  exit 1
fi

# setting defaults for optional input
if [ -z "$MOTO_HOST" ]; then
  MOTO_HOST="0.0.0.0"
fi

if [ -z "$MOTO_PORT" ]; then
  MOTO_PORT="5000"
fi

echo "Starting service $MOTO_SERVICE at $MOTO_HOST:$MOTO_PORT"

if [ -f /opt/init/bootstrap.py ]; then
  moto_server $MOTO_SERVICE -H $MOTO_HOST -p $MOTO_PORT & (sleep 5 && echo "Executing bootstrap script." && python /opt/init/bootstrap.py)
else
  moto_server $MOTO_SERVICE -H $MOTO_HOST -p $MOTO_PORT
fi
# Prevent container from exiting when bootstrap.py finishing
wait

Vi bygger en ny bild och skjuter in den i vårt register.

Låt oss sedan skriva ett resursinitieringsskript, till exempel SWF-domän, använder biblioteket för att arbeta med AWS - boto3:

bootstrap_swf.py

import boto3
from botocore.exceptions import ClientError
import os

os.environ["AWS_ACCESS_KEY_ID"] = "fake"
os.environ["AWS_SECRET_ACCESS_KEY"] = "fake"

client = boto3.client('swf', region_name='us-west-2', endpoint_url='http://localhost:5000')

try:
    client.register_domain(
        name='test-swf-mock-domain',
        description="Test SWF domain",
        workflowExecutionRetentionPeriodInDays="10"
    )
except ClientError as e:
    print "Domain already exists: ", e.response.get("Error", {}).get("Code")

response = client.list_domains(
    registrationStatus='REGISTERED',
    maximumPageSize=123,
    reverseOrder=True|False
)

print 'Ready'

Logiken är denna:

  • När vi startar monterar vi vårt script in /opt/init/bootstrap.py.
  • Om filen är monterad kommer den att exekveras.
  • Om det inte finns någon fil kommer den blotta moto-servern helt enkelt att starta.

Och du kan håna en hel resurs genom att starta en behållare:

docker run --name swf -d 
    -e MOTO_SERVICE=swf 
    -e MOTO_HOST=0.0.0.0 
    -e MOTO_PORT=5000 
    -p 5001:5000 
    -v /tmp/bootstrap_swf.py:/opt/init/bootstrap.py 
    -i awesome-repo.com/moto-server:latest

Låt oss prova det interaktivt:

Moto. Hånande AWS

Det fungerar!

Så vi kan skapa docker-compose.yml, vilket kommer att spara tid på att testa ändringar:

docker-compose.yml

version: '3'
services:
  s3:
    image: picadoh/motocker
    environment:
      - MOTO_SERVICE=s3
      - MOTO_HOST=10.0.1.2
    ports:
      - "5002:5000"
    networks:
      motonet:
        ipv4_address: 10.0.1.2
    volumes:
      - /tmp/bootstrap_s3.py:/opt/init/bootstrap.py
  swf:
    image: picadoh/motocker
    environment:
      - MOTO_SERVICE=swf
      - MOTO_HOST=10.0.1.3
    ports:
      - "5001:5000"
    networks:
      motonet:
        ipv4_address: 10.0.1.3
    volumes:
      - /tmp/bootstrap_swf.py:/opt/init/bootstrap.py
  ec2:
    image: picadoh/motocker
    environment:
      - MOTO_SERVICE=ec2
      - MOTO_HOST=10.0.1.4
    ports:
      - "5003:5000"
    networks:
      motonet:
        ipv4_address: 10.0.1.4
    volumes:
      - /tmp/bootstrap_ec2.py:/opt/init/bootstrap.py
networks:                             
  motonet:                          
    driver: bridge                
    ipam:                         
      config:                       
        - subnet: 10.0.0.0/16

Egentligen kan detta tillvägagångssätt användas inte bara på en utvecklares bärbara dator. Preliminära tester med mockar efter montering hjälper till att bli av med eventuella problem när du kör på dev*-miljöer.

Länkar:

Motocker repo - github.com/picadoh/motocker
Moto repo - github.com/spulec/moto
Boto3 Dokument - boto3.amazonaws.com/v1/documentation/api/latest/index.html

Källa: will.com

Lägg en kommentar