Skip to main content

Schul-Cloud Search API

Project description

Build Status Python Package Index Dockerhub Automated Build Status First Timers

These are the tests for the Schul-Cloud search API. You can read motivation blog post about

  • common tests for all search engines

  • testing during live deployment

Installation

You can install the tests by installing Python version 3 and pip. Then, you run the installation from the command line:

pip install --user schul-cloud-search-tests

Installation for Development

If you would like to contribute code to this repository, you can clone it first.

git clone https://github.com/schul-cloud/schul_cloud_search_tests.git
cd schul_cloud_search_tests

Install the required packages for Python:

pip3 install --user -r requirements.txt pip-tools==1.6.5

Note that if you would like to change the requirements, please edit the requirements.in file and run this command to update the dependencies:

pip-compile --output-file requirements.txt requirements.in

Specification

The idea is that these tests run in between your search client and your search engine or search adapter. You use the test interface instead of your search engine interface to run checks on every request the client makes:

  • Is the client request formulated correctly?

  • Is the server response folmulated correctly?

These cases can be defined and are defined:

  • When the client issues a successful request and the server responds correctly, the request is forwarded, optionally including a note that the tests passed.

  • When the client issues a malformed request, HTTP error 400 is returned including the information which tests did not pass. The request is forwarded to the server and the response is expected to be 400, too.

  • When the client issues a correct request, and the server response is malformed, then HTTP error 409 is returned including a list of error descriptions of the mistakes made by the server.

To make the decisions transparent, the client request and the server response are included in the error reponses.

Usage as Proxy

Suppose you have a server running on http://localhost:1234/v1/search/. You can tun the search engine tests as a proxy on port 8080 like this:

python3 -m schul_cloud_search_tests.proxy 8080 /endpoint/ http://localhost:1234/v1/search/

Now, all your requests to http://localhost:8080/endpoint/ will be forwarded to http://localhost:1234/v1/search/.

When you are done, you can visit http://localhost:8080/stop to stop the server or run this command:

python3 -m schul_cloud_search_tests.stop 8080

The return code is zero (success) if all tests of all requests passed. If one test fails, it is a number greater than zero.

Usage as Tests

In case you have a search engine which should be tested at the URL, you can run tests against it with the following command

python3 -m schul_cloud_search_tests.search http://loalhost:8080/v1/search \
           --query "Q=einstein" --query "Q=test&page[offset]=20"

The tests test the following:

  • There is a search engine running at http://loalhost:8080/v1/search

  • These queries Q=einstein and Q=test&page[offset]=20 are handled correctly.

  • Additional tests are run wich test correct and malformed queries, see Issue 6.

The return status of the tests is zero if all tests passed, otherwise a positive number.

Development Process

The idea is stated in the motivation blog post. We can use the tests to test the search engines. However, the tests can become complex and must be tested themselves. Therefore, the following development process is proposed.

  1. Have a look at the specification:

    The specification is the most important document. It determines what needs to be tested.

  2. Implement tests according to examples of the specification. These tests are located in the schul_cloud_search_tests/tests folder. They test how you would like to have the search proxy respond to the different valid and invalid requests.

  3. Make the tests run.

Further Reading


You can edit this document on Github and check it with this editor.

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

schul_cloud_search_tests-1.0.57.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

schul_cloud_search_tests-1.0.57-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

Details for the file schul_cloud_search_tests-1.0.57.tar.gz.

File metadata

File hashes

Hashes for schul_cloud_search_tests-1.0.57.tar.gz
Algorithm Hash digest
SHA256 72374268e1d33e64f86ed054012c9f19ca8c5b7e4a6a9e93f68d4f9c6b605fb3
MD5 e662d3d14fbe00dd2183b435c74b9e3a
BLAKE2b-256 c0527bab6c10c8019aa662a2979f2bfb4b93c52c03f6bf0a00e9b1a110ff226e

See more details on using hashes here.

File details

Details for the file schul_cloud_search_tests-1.0.57-py3-none-any.whl.

File metadata

File hashes

Hashes for schul_cloud_search_tests-1.0.57-py3-none-any.whl
Algorithm Hash digest
SHA256 08c63959c8de1d617eea96459f648da67d732277eb9da970fe6f456ef8997db4
MD5 e801c82ce817a87fbdc1e70e0f077ceb
BLAKE2b-256 4da1a7c6d11cd29e2adbc72436f12859872c2b380b82d23ff8565d83f9518bbc

See more details on using hashes here.

Supported by

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