Moto. Weinen Sie AWS

Das Testen ist ein wesentlicher Bestandteil des Entwicklungsprozesses. Und manchmal müssen Entwickler Tests lokal ausführen, bis die Änderung festgeschrieben wird.
Wenn die Anwendung Amazon Web Services verwendet , ist die Python- Motobibliothek dafür ideal.


Eine vollständige Liste der Ressourcenabdeckung finden Sie hier .
Github hat eine Hugo Picado Rübe - Moto-Server . Ready Image, ausführen und verwenden. Die einzige Nuance ist, dass nach dem Start dort noch keine AWS- Ressourcen erstellt wurden.

Nun, das ist leicht zu beheben.

Da beim Start der Servicetyp ( env der Variablen MOTO_SERVICE ) angegeben werden muss, müssen wir die Erstellung der Ressource beschreiben.

Lassen Sie uns start.sh ein wenig ändern:

Stattdessen

moto_server $MOTO_SERVICE -H $MOTO_HOST -p $MOTO_PORT 

Einfügen:

 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 

Die resultierende Datei wird erhalten:

start.sh
 #!/bin/sh # validate required input if [ -z "$MOTO_SERVICE" ]; then echo "Please define AWS service to run with Moto Server (eg 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 


Erstellen Sie ein neues Image und verschieben Sie es in Ihre Registrierung.

Als Nächstes schreiben wir ein Ressourceninitialisierungsskript, z. B. eine SWF-Domäne , und verwenden die Bibliothek für die Arbeit mit 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' 


Die Logik ist folgende:

  • Hängen Sie beim Start unser Skript in /opt/init/bootstrap.py ein .
  • Wenn die Datei gemountet ist, wird sie ausgeführt.
  • Wenn keine Datei vorhanden ist, wird der nackte Moto-Server einfach gestartet.

Und Sie können eine ganze Ressource abtupfen, indem Sie einen Container starten:

 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 

Wir versuchen es im interaktiven Modus:



Es funktioniert!

Auf diese Weise können wir docker-compose.yml erstellen, um Zeit beim Testen von Änderungen zu sparen:

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 


Tatsächlich können Sie diesen Ansatz nicht nur auf dem Laptop des Entwicklers verwenden. Vorläufige Tests mit Moks nach dem Build helfen dabei, mögliche Probleme bei der Ausführung in dev * -Umgebungen zu beseitigen.

Referenzen:

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

Source: https://habr.com/ru/post/de454334/


All Articles