All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Modernize package quality tooling and configuration
- Add support for Python 3.13
- Updated to simpler typing syntax for optional arguments and iterable types using
pyupgrade
- Reformatted files constrained to Python 3.8+ syntax using
black
- Updated documentation to prefer
tox
usage - Updated documentation dependencies and removed upper bounds on their versions
- Add support for Python 3.12
- Remove upper bound on dependencies
- apiron no longer supports Python 3.7, which reached end of life on 2023-06-27
- apiron no longer supports Python 3.8, which reaches end of life on 2024-10-31
- Update permissions in publishing workflow to allow publishing of files to GitHub releases
- Use
package
andwheel_build_env
to speed up tests as this is a pure Python package. See the tox docs for more detail.
- Use PyPI trusted publishing instead of manual token authentication
- You can now configure
retry_spec
andtimeout_spec
at the endpoint level. Calls to endpoints may override the endpoint-level configuration when necessary.
- Ensure
py.typed
files end up in binary wheel distribution, which may break type checking for consumers
- Run tests against Python 3.11
- Stop ignoring imports during type checking
- Add
py.typed
file so mypy can check against package types in downstream applications
- Use interpolation for logging messages to avoid wasted computation
- Move from Travis CI to GitHub Actions for testing and publishing
- Use PEP 517 builds
- Testing matrix and trove classifiers for Python 3.9
- Type hints for all classes, methods, and functions
- Support for Python 3.6 has been removed due to its impending end of life and the desire to leverage features from 3.7
- Remove Python 3.10 testing and support for now, as Travis CI only has Python 3.10.0a5 which isn't compatible with recent pytest-randomly releases
- Indicate (by renaming) that all functions in the
client
module are private, except forcall
- Ability to specify
proxies
for aService
definition so all calls to the service use the defined proxies - Ability to specify
auth
for aService
definition so all calls to the service use the defined authentication - Ability to specify
return_raw_response_object
at the endpoint level, overridden by any value specified at call time
- Add pre-commit configuration for earlier linting and formatting checks
- Support for Python 3.4 and 3.5 has been removed based on official Python support timelines and usage statistics
- Ability to pass dict to
files
keyword argument for file-like-objects for multipart encoding upload
- Ability to run linting and build docs using
tox
- Ability to access raw response object when making a call using
return_raw_response_object=True
. Useful for accessing things like response cookies or headers.
- Moved implementation to
src/
directory for improved end-to-end testing with packaging.
- An
endpoints
attribute onService
classes returns a list of that service's configured endpoints Endpoint
classes now have a useful__repr__
implementation, e.g."JsonEndpoint(path='/foo')"
.
StubEndpoint
now inherits fromEndpoint
and as a result does not accept arbitrary keyword arguments- Use
setup.cfg
for most project metadata and tool configuration, aside fromblack
.
- More testing for the bug fixed in v2.6.1
- Extract
ServiceCaller
behaviors to module level and remove class - Remove
path_kwargs
argument from thecall
function (previously aServiceCaller
method)
- Backwards compatibility to allow
ServiceCaller.call()
to use endpoints that live in an instantiatedService
- Ability to pass optional parameter
allow_redirects
to enable/disable HTTP redirection when calling an endpoint
- Move to the descriptor protocol from metaclassing under the hood for turning an endpoint into a callable
- Ability to pass dict to
json
keyword argument for raw POST body instead of form-encoded data - Ability to use regular keyword arguments when calling an endpoint (instead of
path_kwargs
)
DiscoverableService
now inherits fromServiceBase
, an ancestor common withService
, instead ofService
itself
- Simplify imports so that all commonly-used classes can be imported with
from apiron import <class>
- Error in calling a dynamic stub endpoint
pytest.ini
forpytest
configuration- Syntax sugar for calling endpoints
- Update tests to use
pytest
-styleassert
s and fixtures (unittest.mock
usage is still in place, for now) - Make
--cov=apiron
the default when runningpytest
- Make test output terse by default (
-v
when running restores previous behavior;-vv
gives explicit test list) - An endpoint's
stub_response
can optionally be a callable, for returning dynamic values in response to parameters
- End PyPI server URL with a slash to avoid a redirect, allowing deployment of build artifacts during release
- Automated release artifact deployment via Travis CI's
providers
feature
- The
endpoint
module has been split up into a module for each endpoint type, still importable as before
- Added the missing
wheel
dependency todev-requirements.txt
for creating a wheel distribution during release
- Added ability to create a
StubEndpoint
for stubs
- The
check_for_trailing_slash
argument and default behavior has been removed
- Service domains and endpoint paths were previously joined per IETF RCF 1808, which has surprising edge cases. These are now always joined by appending the endpoint path; the previous behavior can be achieved with multiple services or endpoints as needed.
- Exposed ability to explicitly set the response encoding
- Expose pass-through
auth
argument torequests
- Moved all tests to a top-level
tests
package and switched to using thepytest
runner - Added missing parameter in docstring for
apiron.client.ServiceCaller.call
- Removed unused imports from
apiron.client
- Initial open source release of this package!
- Documentation on use and development of this package
- Code of conduct, contribution guide, and issue templates for contributors