# The National Archives: Find Case Law
This repository is part of the [Find Case Law](https://caselaw.nationalarchives.gov.uk/) project at [The National Archives](https://www.nationalarchives.gov.uk/). For more information on the project, check [the documentation](https://github.com/nationalarchives/ds-find-caselaw-docs).
# MarkLogic API Client
[](https://pypi.org/project/ds-caselaw-marklogic-api-client/)


This is an API Client for connecting to Marklogic for The National Archive's Caselaw site.
This package is published on PyPI: https://pypi.org/project/ds-caselaw-marklogic-api-client/
## Usage
You can find documentation of the client class and available methods [here](https://nationalarchives.github.io/ds-caselaw-custom-api-client).
## Testing
To run the test suite:
```bash
poetry install
poetry run pytest
```
There are also some smoketests in `smoketests.py` which run against a MarkLogic database but do not run in CI currently.
To run them locally you can set the environment variables as detailed in the file in a `.env` file or just hardcode them in, as long as you don't commit those changes to the repo.
And then run
```bash
poetry run pytest smoketest.py
```
To start with when running this, we have been choosing to point to the staging MarkLogic to have more confidence that the setup is a good representation of production as opposed to a local MarkLogic instance but that can work too.
Eventually we will make it so that we run these tests in CI and probably point to a dedicated testing MarkLogic instance so we don't get conflicts with people using staging for manual testing.
## Making changes
When making a change, update the [changelog](CHANGELOG.md) using the
[Keep a Changelog 1.0.0](https://keepachangelog.com/en/1.0.0/) format. Pull
requests should not be merged before any relevant updates are made.
## Releasing
When making a new release, update the [changelog](CHANGELOG.md) in the release
pull request.
The package will **only** be released to PyPI if the branch is tagged. A merge
to main alone will **not** trigger a release to PyPI.
To create a release:
0. Update the version number in `pyproject.toml`
1. Create a branch `release/v{major}.{minor}.{patch}`
2. Update `CHANGELOG.md` for the release
3. Commit and push
4. Open a PR from that branch to main
5. Get approval on the PR
6. Merge the PR to main and push
7. Tag the merge commit on `main` with `v{major}.{minor}.{patch}` and push the tag
8. Create a release in [Github releases](https://github.com/nationalarchives/ds-caselaw-custom-api-client/releases)
using the created tag
If the release fails to push to PyPI, you can delete the tag with `git pull`, `git push --delete origin v1.2.3` and try again.
Raw data
{
"_id": null,
"home_page": null,
"name": "ds-caselaw-marklogic-api-client",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0.0,>=3.12.0",
"maintainer_email": null,
"keywords": "national archives, caselaw",
"author": "The National Archives",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/bd/57/e0a3b8215d203763e3eb11b57e6961667216ee015acbb66ce5dd1ed88b5b/ds_caselaw_marklogic_api_client-41.1.1.tar.gz",
"platform": null,
"description": "# The National Archives: Find Case Law\n\nThis repository is part of the [Find Case Law](https://caselaw.nationalarchives.gov.uk/) project at [The National Archives](https://www.nationalarchives.gov.uk/). For more information on the project, check [the documentation](https://github.com/nationalarchives/ds-find-caselaw-docs).\n\n# MarkLogic API Client\n\n[](https://pypi.org/project/ds-caselaw-marklogic-api-client/)\n\n\n\nThis is an API Client for connecting to Marklogic for The National Archive's Caselaw site.\n\nThis package is published on PyPI: https://pypi.org/project/ds-caselaw-marklogic-api-client/\n\n## Usage\n\nYou can find documentation of the client class and available methods [here](https://nationalarchives.github.io/ds-caselaw-custom-api-client).\n\n## Testing\n\nTo run the test suite:\n\n```bash\npoetry install\npoetry run pytest\n```\n\nThere are also some smoketests in `smoketests.py` which run against a MarkLogic database but do not run in CI currently.\n\nTo run them locally you can set the environment variables as detailed in the file in a `.env` file or just hardcode them in, as long as you don't commit those changes to the repo.\n\nAnd then run\n\n```bash\npoetry run pytest smoketest.py\n```\n\nTo start with when running this, we have been choosing to point to the staging MarkLogic to have more confidence that the setup is a good representation of production as opposed to a local MarkLogic instance but that can work too.\n\nEventually we will make it so that we run these tests in CI and probably point to a dedicated testing MarkLogic instance so we don't get conflicts with people using staging for manual testing.\n\n## Making changes\n\nWhen making a change, update the [changelog](CHANGELOG.md) using the\n[Keep a Changelog 1.0.0](https://keepachangelog.com/en/1.0.0/) format. Pull\nrequests should not be merged before any relevant updates are made.\n\n## Releasing\n\nWhen making a new release, update the [changelog](CHANGELOG.md) in the release\npull request.\n\nThe package will **only** be released to PyPI if the branch is tagged. A merge\nto main alone will **not** trigger a release to PyPI.\n\nTo create a release:\n\n0. Update the version number in `pyproject.toml`\n1. Create a branch `release/v{major}.{minor}.{patch}`\n2. Update `CHANGELOG.md` for the release\n3. Commit and push\n4. Open a PR from that branch to main\n5. Get approval on the PR\n6. Merge the PR to main and push\n7. Tag the merge commit on `main` with `v{major}.{minor}.{patch}` and push the tag\n8. Create a release in [Github releases](https://github.com/nationalarchives/ds-caselaw-custom-api-client/releases)\n using the created tag\n\nIf the release fails to push to PyPI, you can delete the tag with `git pull`, `git push --delete origin v1.2.3` and try again.\n\n",
"bugtrack_url": null,
"license": null,
"summary": "An API client for interacting with the underlying data in Find Caselaw.",
"version": "41.1.1",
"project_urls": {
"Homepage": "https://github.com/nationalarchives/ds-caselaw-custom-api-client"
},
"split_keywords": [
"national archives",
" caselaw"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "7aaa2a8fd93448c9ee873204d58d2062904635b3e392691d3eaa9978d3190812",
"md5": "f0549bb30855359cc5a4ce27b3cbbc7b",
"sha256": "d8901c9cdebac90d2d3a73cff16cd79f6edb5f00aeab8dd96df70371882a0ba5"
},
"downloads": -1,
"filename": "ds_caselaw_marklogic_api_client-41.1.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "f0549bb30855359cc5a4ce27b3cbbc7b",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0.0,>=3.12.0",
"size": 91916,
"upload_time": "2025-09-10T10:16:04",
"upload_time_iso_8601": "2025-09-10T10:16:04.606721Z",
"url": "https://files.pythonhosted.org/packages/7a/aa/2a8fd93448c9ee873204d58d2062904635b3e392691d3eaa9978d3190812/ds_caselaw_marklogic_api_client-41.1.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "bd57e0a3b8215d203763e3eb11b57e6961667216ee015acbb66ce5dd1ed88b5b",
"md5": "a3c3f25b3770d964fbbc3e7646f8d7ac",
"sha256": "d859d3bf45fb0c03b05b39b11f17efd4cdee573b6300fbf8aaad80e2a709dd09"
},
"downloads": -1,
"filename": "ds_caselaw_marklogic_api_client-41.1.1.tar.gz",
"has_sig": false,
"md5_digest": "a3c3f25b3770d964fbbc3e7646f8d7ac",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0.0,>=3.12.0",
"size": 59801,
"upload_time": "2025-09-10T10:16:06",
"upload_time_iso_8601": "2025-09-10T10:16:06.285553Z",
"url": "https://files.pythonhosted.org/packages/bd/57/e0a3b8215d203763e3eb11b57e6961667216ee015acbb66ce5dd1ed88b5b/ds_caselaw_marklogic_api_client-41.1.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-09-10 10:16:06",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "nationalarchives",
"github_project": "ds-caselaw-custom-api-client",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"lcname": "ds-caselaw-marklogic-api-client"
}