Skip to content

Latest commit

 

History

History
157 lines (113 loc) · 4.28 KB

README.md

File metadata and controls

157 lines (113 loc) · 4.28 KB

API integration testing a Python Flask app on Travis CI

This repository contains an example app which uses Assertible to run automated API integration tests for a Python Flask app in a continuous integration build using Travis CI.

Assertible is web service testing tool for developers that focuses on creating simple and deterministic tests combined with flexible automation.

Basically, ngrok is used to create a dynamic localhost tunnel to your app which is built and run on CI. The dynamic ngrok URL is passed to an Assertible Trigger which will run the API tests when executed. This testing technique is not specific to Python, Flask, or Travis CI and can be used from any continuous integration system or web application framework.

The setup is 4 steps:

  1. Create a Flask app
  2. Create a Travis CI config
  3. Create an Assertible web service
  4. Copy the trigger URL to a Travis variable

Check out the full blog post

1. Create a Flask app

Create a new directory for the code repository:

mkdir myapp && cd myapp

Save the following code to a file named app.py:

from flask import Flask
app = Flask(__name__)

@app.route("/")
def hello():
    return "Hello Assertible!"

if __name__ == "__main__":
    app.run()

Save the code and push it to a GitHub repository:

git add app.py
git commit -a -m "Checkin app.py"
git push

The code above assumes you have a GitHub repository setup for this tutorial. If not, check here: https://docs.travis-ci.com/user/for-beginners

2. Create a Travis CI config

This steps assumes you have created a Travis account and enabled the repo.

Save this Travis configuration to .travis.yml file:

language: python
python:
  - "2.7"

addons:
  apt:
    packages:
      - ca-certificates

install: "pip install Flask"

script:
  - echo "Unit tests"

after_script:

  # start the web app
  - |
    python app.py &
    APP_PID=$!

  # download and install ngrok
  - curl -s https://bin.equinox.io/c/4VmDzA7iaHb/ngrok-stable-linux-amd64.zip > ngrok.zip
  - unzip ngrok.zip
  - ./ngrok http 5000 > /dev/null &

  # sleep to allow ngrok to initialize
  - sleep 2

  # extract the ngrok url
  - NGROK_URL=$(curl -s localhost:4040/api/tunnels/command_line | jq --raw-output .public_url)

  # execute the API tests
  - |
    curl -s $TRIGGER_URL -d'{
      "environment": "'"$TRAVIS_BRANCH-$TRAVIS_JOB_NUMBER"'",
      "url": "'"$NGROK_URL"'",
      "wait": true
    }'

  - kill $APP_PID
git add .travis.yml
git commit -a -m "Checkin .travis.yml"
git push

3. Create the Assertible web service

Next, you need to create an Assertible account and create a new web service. Simply sign-in to Assertible.

The first time you log-in, you will be prompted with a form to create a web service:

Configuring a web service in Assertible

4. Copy the trigger URL to a Travis variable

After creating a web service in the Assertible dashboard, navigate to your web service's Settings tab and click Trigger URL in the left side navigation. Copy the trigger URL to your clipboard.

In the Travis CI interface, navigate to your repository. On the left hand side, click the More options then click Settings.

Add a new variables named TRIGGER_URL and paste the trigger URL into the value input.

Travis CI environment variable form

Finally, click Restart build or push some changes to your app to initiate a build. Navigate back to the Assertible web service dashboard and click Results. You should now see a result for your API integration tests:

Assertible test results via dynamic trigger URL