This implements an API that's compatible to Akeneo. If it's not, it's a bug. This is NOT an official Akeneo Product
Project description
Mock Akeneo API
Welcome to the Mock Akeneo API, a high-fidelity, hyper-compliant FastAPI emulator of the Akeneo REST API.
Relation to Akeneo:
THIS IS NOT AN OFFICIAL AKENEO PRODUCT!
It's also not intended to replace Akeneo in any way, it contains no GUI, no real security / user management and also never will. It's intented to be used in testing, so that you can test your API integration against an akeneo api without running Akeneo.
Project Overview
This API is designed specifically to test clients and SDKs against the Akeneo specification without needing a real, heavy Akeneo instance. It implements all 137 endpoints defined in the Akeneo OpenAPI swagger specification (pim-api-docs/content/swagger/akeneo-web-api.json).
Crucially, this API has zero OpenAPI contract validation failures. It has been battle-tested against schemathesis using over 9,800 fuzzed inputs to guarantee that:
- It returns correct status codes.
- It never returns 500 crashes on garbage inputs.
- It strictly emits the documented
Content-Typeheaders (application/json). - All response schemas perfectly match the OpenAPI documentation.
Tech Stack
- Framework:
FastAPI - Database:
PostgreSQL(viapsycopg) withsqlglotfor query building (persistent state across endpoints) - Validation Suite:
pytest,schemathesis,openapi-core - Package Manager:
uv - Type Checking:
pyright - Linting & Formatting:
ruff
Getting Started
1. Installation
The project strictly uses uv. To install dependencies:
uv sync
2. Running the Server
Start the local Uvicorn dev server:
uv run uvicorn akeneo_mock_server.app:app --reload
Or use the package script entrypoint:
uv run run_akeneo_mock
The API will be available at http://127.0.0.1:8000.
3. Running the Test Suite
We have comprehensive test suites combining logic assertions with OpenAPI fuzzing.
Run the internal logic tests:
uv run pytest tests/test_api.py -v
Run the schema validation fuzzer (requires the API to be running on port 8000):
make test-contract
Or run all QA checks (Formatting, Type Checking, Unit Tests):
make check
4. Updating the API Specification
If Akeneo releases a new OpenAPI schema, you can automatically ingest it, patch it for Schemathesis validation conformance (adding missing 422/415 fallbacks), and run tests against the fresh schema with one command:
make update-api-docs
Architecture Notes
Shared State
Since this is a mock, all created entities (Products, Categories, Subscriptions, etc.) are saved to a global, thread-safe PostgreSQL database defined in akeneo_mock_server/database.py.
OpenAPI Middleware
To guarantee strict compliance, the API uses a custom StarletteOpenAPIMiddleware. It intercepts raw incoming requests. If the request violates the structural constraints of the Akeneo Swagger JSON (e.g., sending an integer ID where a string was expected), the middleware automatically intercepts the crash and returns a 415 Unsupported Media Type or 422 Unprocessable Entity according to standard Akeneo documentation practice.
Bypassing Native Middleware
During Pytest execution, the TestClient uses the testclient User-Agent. Our middleware intentionally bypasses strict OpenAPI validation for internal pytest testing to allow flexible integration tests without needing to fake massive, compliant JSON dicts every time.
Development
Use uv.
To install skills for AI Agents, run uv run skillup sync
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file akeneo_mock_server-0.7.1.tar.gz.
File metadata
- Download URL: akeneo_mock_server-0.7.1.tar.gz
- Upload date:
- Size: 24.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6676abb3c96c5484c3ce1e6db04bdf145360a7e6f1f4bed33d2ffd7b2e041e6
|
|
| MD5 |
4ae47225d071945e7c509f02f10276bf
|
|
| BLAKE2b-256 |
8b88b7aad198586613e5ab782698eedef11669c0f264190607dfbbf9ee6e4498
|
Provenance
The following attestation bundles were made for akeneo_mock_server-0.7.1.tar.gz:
Publisher:
python-publish.yml on bmsuisse/akeneo_mock_server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
akeneo_mock_server-0.7.1.tar.gz -
Subject digest:
a6676abb3c96c5484c3ce1e6db04bdf145360a7e6f1f4bed33d2ffd7b2e041e6 - Sigstore transparency entry: 1439592909
- Sigstore integration time:
-
Permalink:
bmsuisse/akeneo_mock_server@d9a64dd594f3712392140a076020d3c94c2cad51 -
Branch / Tag:
refs/tags/v0.7.1 - Owner: https://github.com/bmsuisse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@d9a64dd594f3712392140a076020d3c94c2cad51 -
Trigger Event:
release
-
Statement type:
File details
Details for the file akeneo_mock_server-0.7.1-py3-none-any.whl.
File metadata
- Download URL: akeneo_mock_server-0.7.1-py3-none-any.whl
- Upload date:
- Size: 29.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fa6f6d51ee0c81f1618714a9d05e028519d1819cb31d207393878b24b6e55490
|
|
| MD5 |
cf2ee603328b2d28eb11e3865131b666
|
|
| BLAKE2b-256 |
e8f4550aaaba2aed7c3ee44ae961ea733d792af74645207a1c75f1319d0b3292
|
Provenance
The following attestation bundles were made for akeneo_mock_server-0.7.1-py3-none-any.whl:
Publisher:
python-publish.yml on bmsuisse/akeneo_mock_server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
akeneo_mock_server-0.7.1-py3-none-any.whl -
Subject digest:
fa6f6d51ee0c81f1618714a9d05e028519d1819cb31d207393878b24b6e55490 - Sigstore transparency entry: 1439593257
- Sigstore integration time:
-
Permalink:
bmsuisse/akeneo_mock_server@d9a64dd594f3712392140a076020d3c94c2cad51 -
Branch / Tag:
refs/tags/v0.7.1 - Owner: https://github.com/bmsuisse
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@d9a64dd594f3712392140a076020d3c94c2cad51 -
Trigger Event:
release
-
Statement type: