Major update to the WireMock Python library and new Testcontainers module
Read on to discover what's the hiss and step-by-step instructions
We have quite a lot of big updates to share about the Python WireMock library! After being dormant for a few years, it has just got a new release with a number of big changes:
- Enhanced support for WireMock Standalone instances and feature alignment
- Preview support for Testcontainers Python integration
- New documentation on ReadTheDocs, powered by MkDocs
Apart from the above, there has been a major effort behind the scenes to refresh the component and to align it with modern Python developer tooling, including new CI pipelines, test coverage, and release automation. The component is now fully ready for future maintenance ๐ช
Many thanks to Mike Waites for working on the listed changes! At WireMock Inc. weโve been happy to sponsor this work to enable thousands of Python developers to try out and adopt WireMock. Also, kudos to Cody Lee who is the original creator of the project, and who has supported us during the updates in recent months.
โ
So, WireMock for Python?
WireMock was started as an open source Java test library, but it is no longer a JVM-only project. The WireMock Ecosystem spans many technology stacks and frameworks; there are 50+ different implementations and adapters just on GitHub. Python is one of the most popular programming languages in the world, and so is naturally no exception.
WireMock on Python originally started as a Python implementation of an API Client by Cody Lee. He later added support for calling the JAR file directly on local machines to provision and manage the instances, hence providing similar capabilities to plain Java implementation of WireMock. There are also other projects that integrate other popular testing frameworks like the Robot Framework.
A few years ago, Python WireMock was donated by Cody to the WireMock community, and refreshing it has been on our roadmap for a long time. This May, the implementation started. Mike Waites, an experienced Python developer, joined the community as a contributor working on the library and expanding its functionality. In June we had a first release with the refresh for the new dependencies and development tooling, and now we are happy to present the new feature releases with one but very big change.
Please welcome the Testcontrainers integration!
โ
Testcontainers module - Preview
Testcontainers is a popular tool for integration testing with containers, eliminating the need for pre existing environments. It provides lightweight, throwaway container instances of common databases, web browsers, developer services, or anything that can run in a Docker container. The Testcontainers framework has many implementations, including Java, Golang and of course Python. You can find more information on its website.
A few months ago we announced the new WireMock module for Testcontainers Java, and it has been just the first stop. After validating the idea we started experimenting with other technology stacks to make WireMock available to more users. Last week, we announced the module for Golang. And now we are happy to announce the ready to fly module for Testcontainers Python!
The Testcontainers Python module is a part of the Python WireMock library, so a single library integrates both the CLI client and the Testcontainers module. See this page for all documentation and examples.
โ
Try out the Testcontainers module!
We are looking for more users to try out Python WireMock and the Testcontainers module and to share their feedback. Below you can find a step-by-step guide where we will use the pytest framework. If you do not want to follow it step-by-step, you can find the same examples within the projectโs repository.
Prerequisites
- Python 3.7 or above
- Pip 20.0.0 or above (use apt install python3-pip, for example)
- Pytest 7.3.0 or above (use pip install pytest)
- Testcontainers 3.5.0 or above (use pip install testcontainers)
Step 1. Install Python WireMock
Python WireMock is available on the PyPi public repository: https://pypi.org/project/wiremock/ . To install it, just use the Pip - a package installer for Python that uses PyPi by default:
pip install wiremock
Step 2. Create a Test fixture in your project
As a first step, we will need to provision a test WireMock server to be used in tests. We will define a test fixture that initializes the WireMock container and adds a mapping for the โ/helloโ endpoint that returns HTTP 200 with โhelloโ in the body:
- Create a new "test.py" file
- In this file, add a pytest fixture to manage the container life-cycle. Use fixture scope to control how often the container is created
- Set the WireMock SDK config URL to the URL exposed by the container. It will route all Admin API requests to the mock server.
- Create REST API stub mapping for the /hello endpoint using the Admin SDK.
โ
Step 3. Add a first unit test!
Use the wiremock_server fixture in your tests and make requests against the mock server. Add the following test to the test.py file:
โ
Step 4. Just run the test!
In your test directory, run the following command: pytest test.py -v. Sample output:
โ
โ
References
- Python WireMock repository: https://github.com/wiremock/python-wiremock
- The module on PyPi: https://pypi.org/project/wiremock
- Quickstart guide: https://wiremock.readthedocs.io/en/latest/quickstart/
- WireMock and Python solutions page: https://wiremock.org/docs/solutions/python/
- WireMock module for Testcontainers page: https://testcontainers.com/modules/wiremock/
- WireMock Community Slack: http://slack.wiremock.org/
/