Skip to content

Latest commit

 

History

History
118 lines (84 loc) · 4.23 KB

README.md

File metadata and controls

118 lines (84 loc) · 4.23 KB

ADC API test suite

Bug Reporting

File issues at the top-level ADC API github repository.

Testing approach

  • Load test dataset into repository
  • Python code to run a single test
  • Bash script to run a suite of tests and report results.

Loading Test Dataset into Repository

The tests expect a specific dataset to be loaded into the repository. Queries are designed to return specific data records to test that query construction and operation is working as expected by the API service.

Test subdirectories

There are two subdirectories in the base level of this github repository, one each for tests against the /repertoire endpoint and the /rearrangement endpoint. In each subdirectory, files are named with respect to whether the test is expected to pass or fail, with the file name including a hint at what the test is testing against.

Running the Test Suite

Requirements

The python code requires the following python modules:

  • urllib
  • argparse
  • json
  • ssl
  • normal system modules (os, sys, time)

You can install these on your system or use the docker image.

Clone the repository

git clone https://github.com/airr-community/adc-api-tests.git
cd adc-api-tests

Docker

You can run the tests using the AIRR Standards docker image which has all of the necessary python libraries installed. You will need to map the local test suite directory into the docker container.

docker pull airrc/airr-standards
docker run -v $PWD:/work -it airrc/airr-standards bash
cd /work

Running multiple tests with ADCtest script

The bash script ADCtest uses the python code above to run a set of tests against a given API. The command line arguments to the code are similar, with the two following exceptions:

  • A list of files can be given as a suite of tests to run
  • The -v and -f command line arguments can be interspersed between the file to turn on and off the verbosity and force flags.
  • The -g command line argument can be used to disable the gold standard testing (see below).
$ src/ADCtest.sh https://localhost/airr/v1 repertoire repertoire/pass*.json

Running test repertoire/pass-all.json
PASS: Query file repertoire/pass-all.json to https://vdjserver.org/airr/v1/repertoire OK

Running test repertoire/pass-organism-id.json
PASS: Query file repertoire/pass-organism-id.json to https://vdjserver.org/airr/v1/repertoire OK

Running test repertoire/pass-pcr_target_locus.json
PASS: Query file repertoire/pass-pcr_target_locus.json to https://vdjserver.org/airr/v1/repertoire OK

Running test repertoire/pass-query2_repertoire.json
PASS: Query file repertoire/pass-query2_repertoire.json to https://vdjserver.org/airr/v1/repertoire OK

SUMMARY: All tests passed!!!

Running a single test with the python test application

The python code can be run as follows:

$ python3 src/test_airr_api.py https://localhost/airr/v1 repertoire repertoire/pass-all.json
PASS: Query file repertoire/pass-all.json to https://airr-api.ireceptor.org/airr/v1/repertoire OK

Required command line options consist of:

  • The base URL to test against
  • The entry point to test
  • The JSON query to execute

Optional command line arguments are:

  • -v: Run in verbose mode, provided more diagnostics as to what occurred.
  • -f: Force queries to run in error conditions. For example, the code tests for bad JSON on query file load, but in some instances you want to test that the service running the API can detect and handle the bad JSON code. -f will force the bad JSON to be sent to the service rather than detecting it as bad JSON and exiting.
  • -h Print a help message.
  • -g Disable query result testing against the gold standard. Useful when testing an API that does not have the gold standard data set loaded.
$ python test_airr_api.py -h
usage: test_airr_api.py [-h] [-f] [-v] base_url entry_point query_file

positional arguments:
  base_url
  entry_point
  query_file

optional arguments:
  -h, --help     show this help message and exit
  -f, --force    Force sending bad JSON even when the JSON can't be loaded.
  -v, --verbose  Run the program in verbose mode.
  -g, --golddisabled  Disable query result testing against the gold standard. Useful when testing an API that does not have the gold standard data set loaded.