Skip to main content

A compliance utility reporting system for refget server implementations

Project description

Refget Compliance Suite

Repository for the refget API Compliance document and test suite.

Important URLS

Installing the compliance suite

pip3 install refget-compliance

Running the compliance suite

The following will generate a HTML report for your server and serve said HTML. It will also generate a tarball locally of the report

refget-compliance report -s https://refget.server.com/ --serve

The following will generate a JSON report of your server:

refget-compliance report -s https://refget.server.com/ --json server.json

Setting --json - will have the compliance suite write the JSON to STDOUT.

Additional components

Building and uploading the package to PyPI

First do your edits, test and update setup.py with your new version number. Then run the following and provide your user credentials before doing this. This will upload the compliance suite to the test PyPI server.

python3 setup.py sdist bdist_wheel
twine upload --repository-url https://test.pypi.org/legacy/ dist/*

Assuming this works then upload to live PyPI and provide your live login details.

twine upload dist/*

Compliance Documentation

To generate this documentation locally, follow these steps:

git clone https://github.com/ga4gh/refget-compliance.git

cd refget-compliance

pip3 install mkdocs

mkdocs serve

Compliance Test Suite

Compliance test suite is an API testing suite for refget servers.

To run the tests, follow these steps:

git clone https://github.com/ga4gh/refget-compliance.git

cd refget-compliance-suite/test_suite

pip3 install -r requirements.txt

If the server to be tested supports circular sequences then run

py.test --server <your-server-base-url-without-http://-prefix> --cir

and if it doesn't support circular sequences then run

py.test --server <your-server-base-url-without-http://-prefix>

If the server to be tested supports trunc512 algorithm then run

py.test --server <your-server-base-url-without-http://-prefix> --trunc512

and if it doesn't support trunc512 algorithm then run

py.test --server <your-server-base-url-without-http://-prefix>

If the server to be tested redirects success queries then run

py.test --server <your-server-base-url-without-http://-prefix> --redir

And if it doesn't redirects then run

py.test --server <your-server-base-url-without-http://-prefix>

You can try multiple combinations of these flags as per the server implementation for example

py.test --server <your-server-base-url-without-http://-prefix> --cir --trunc512

py.test --server <your-server-base-url-without-http://-prefix> --cir --redir

py.test --server <your-server-base-url-without-http://-prefix> --redir --trunc512

py.test --server <your-server-base-url-without-http://-prefix> --cir --trunc512 --redir

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

refget-compliance-1.2.6.tar.gz (204.5 kB view details)

Uploaded Source

Built Distributions

refget_compliance-1.2.6-py3.5.egg (230.3 kB view details)

Uploaded Source

refget_compliance-1.2.6-py3-none-any.whl (212.2 kB view details)

Uploaded Python 3

File details

Details for the file refget-compliance-1.2.6.tar.gz.

File metadata

  • Download URL: refget-compliance-1.2.6.tar.gz
  • Upload date:
  • Size: 204.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.1 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.5.2

File hashes

Hashes for refget-compliance-1.2.6.tar.gz
Algorithm Hash digest
SHA256 c787a2c6f435befdb1c06302a0bda17ed07dadd32833d68d8d9779ccf40d7a0c
MD5 2f5f0068c5c5959703c2141073016d87
BLAKE2b-256 f3d2c13d36f745f8a58db35ab6c78767d6cc61716851fca40560a82eccdeaffc

See more details on using hashes here.

File details

Details for the file refget_compliance-1.2.6-py3.5.egg.

File metadata

  • Download URL: refget_compliance-1.2.6-py3.5.egg
  • Upload date:
  • Size: 230.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.1 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.5.2

File hashes

Hashes for refget_compliance-1.2.6-py3.5.egg
Algorithm Hash digest
SHA256 baefc223f5a45ec602606c596a9d7459c5ed77ec2284f0285e5320864d2a034f
MD5 9332e40d39bfdf1d668f39f348222cab
BLAKE2b-256 c801b655d0d3d2dc58c3270877e34636a36d8ce8e58832609232c5e0014d4b0d

See more details on using hashes here.

File details

Details for the file refget_compliance-1.2.6-py3-none-any.whl.

File metadata

  • Download URL: refget_compliance-1.2.6-py3-none-any.whl
  • Upload date:
  • Size: 212.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.1 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.5.2

File hashes

Hashes for refget_compliance-1.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 fa1403922b26e52d444bc62b9029387894e1b045f22f79bf3573b81d1255090f
MD5 d5d5878761bdde4b09b29776468ce9f8
BLAKE2b-256 7f461739dad985f7f94c520af79103530acd34ee393f109f5beed5a3a43e5e95

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page