Releases: nolar/kopf
Releases · nolar/kopf
1.29.0rc2
Bugfixes:
- Assume a singular name is a lowercased kind for builtins (API returns empty names). #629
- Give the simulated script-module a name — to make it visible for other libraries (e.g. Pydantic). #634
- Exclude
kind: Event
fromEVERYTHING
to avoid "resource explosion". #636
Documentation:
- Document optional RBAC permissions needed for runtime cluster observation. #630
- Switch documentation, examples, and peering from
kopf.zalando.org/v1
tokopf.dev/v1
(but not annotations and finalizers). #643 #644
Other internal changes:
1.29.0rc1
BREAKING CHANGES! The major version increase (0.x → 1.x) means that there are changes in the public interface with no backwards compatibility. Pay attention when upgrading — most of them have quick replacements.
Most of these legacies are extremely old and it is highly unlikely that they were used in any existing operators. The DeprecationWarning
s were issued for all these features (except namespaces). See #511.
Removed feature | Replacement feature |
---|---|
cooldown= option of decorators |
backoff= option |
event kwarg in @kopf.on.event |
reason kwarg |
cause kwarg in handlers |
use all kwargs directly |
kopf.login() sync function |
@kopf.on.login handlers and async activities |
kopf.config module |
settings kwarg of @kopf.on.startup() handlers |
kopf.config.get_pykube_cfg() for patching |
@kopf.on.login() handlers |
kopf.HandlerFatalError |
kopf.PermanentError |
kopf.HandlerRetryError |
kopf.TemporaryError |
kopf.create_tasks() (sync) |
kopf.spawn_tasks() (async) |
kopf.events.event/info/warn/exception() |
the same directly in the kopf module |
None for labels= /annotations= filters |
kopf.PRESENT (None now raises exceptions) |
Positional field in @on.field('group', 'v1', 'plural', 'field') |
kwarg field='field' instead |
Unversioned keys in storages | generate v1/v2 keys explicitly |
Storages with unprefixed annotations | prefix is now mandatory; defaults to kopf.zalando.org/… |
@kopf.on.this(…) for sub-handlers |
@kopf.subhandler(…) (for readability) |
Dropped without replacements:
- Public fields & methods of
OperatorRegistry
— use it only as an object for theregistry=
kwarg. #625 #611 - All internal sub-registries:
Resource[Watching|Spawning|Changing]Registry
,ActivityRegistry
. #625 #611 - All legacy registries:
SimpleRegistry
,GlobalRegistry
, etc. #625
Deprecated:
operator(namespace='…')
→operator(namespaces=['…'])
. #600operator(namespace=None)
→operator(clusterwide=True)
. #600
New features:
- Namespace serving:
- Resource serving:
- Resources specified partially with/without versions:
@kopf.on.event('kopf.dev', 'kex')
. #500 - Resources specified by secondary names (short, singular, kind):
@kopf.on.event(kind='Pod')
. #500 - Resources specified by minimally sufficient auto-guess names:
@kopf.on.event('pods')
. #500 - Handling of whole categories of resources:
@kopf.on.event(category='all')
. #500 - Handling of all resources (do not try on real clusters):
@kopf.on.event(kopf.EVERYTHING)
. #500
- Resources specified partially with/without versions:
- Field filters:
- Fields' presence/absence filters: e.g.
@kopf.on.event(…, field='spec.field', value=kopf.PRESENT)
. #573 - Fields' value filters: e.g.
@kopf.on.event(…, field='spec.field', value='value')
; callbacks are supported. #573 - Fields' diff filters (only for update):
@kopf.on.update(…, field='spec.field', old=1, new=2)
; callbacks are supported. #573 - Fields' filters are now applicable to all handlers: creation/update/deletion/resuming, daemons, timers, events. #573
- Fields' presence/absence filters: e.g.
- Peering behaviour is now configurable via settings. #572
Improvements:
- The operator's core ("reactor") is full reworked for dynamic detection of resources and namespaces. #600
- Better identifiers of peers in IPv6 networks: for easier identification. #569
- Better log messages in change-detecting processing: #605
- Faster (near-instant) unfreezing when peers are gone/expire. #581
- More notes on
x-kubernetes-preserve-unknown-fields
in the docs. #612
Bugfixes:
- Resources with no uids are now supported too. #596
- CLI for freezing/resuming was failing due to missing authentication. #568
- Ignore irrelevant handlers in superseding causes (e.g. deletion-during-creation). #606
- Fixed configuration of the official Kubernetes library, if used for auth piggybacking. #567
- Guaranteed finalisation of watchers & workers. #628
Contributor experience:
- Switched to GitHub Actions for CI. #582 #586
- API errors are wrapped into our own classes, to prevent abstraction leakage of an HTTP client. #575
- Async timeouts used in the tests, some asyncio tests are time-limited. #608
- Stricter typing on resources & namespaces. #623 #624
- Squashed per-resource registries into combined ones. #622
- Some other refactorings for code clarity: #577 #576 #578 #597 #598 #609 #610 #626 #627
0.28.3
0.28.2
0.28.2rc1
0.28.1
0.28
General topic: stability, resilience, recoverability, better logging and error handling.
New features:
Bugfixes:
- On-field handlers were triggered for non-existent fields with
None
→None
change. #523 - Sub-handlers' state was not purged, preventing their execution in the future. #517
- Timers were ticking forever after the resource was deleted (if there were no finalizers). #548
- Persisted states of executed and then filtered-out handlers were not purged. #557
Resilience improvements:
- Annotations from other Kopf-based operators are fully ignored to avoid ping-pong effects. #539 #538
- The operator will force-stop itself by SIGKILL after 10 minutes of attempts to stop gracefully. #543
- Crash the whole operator on unrecoverable errors in watchers/workers. #509
- Throttle individual resource processing on unexpected errors. #510
- Extra exceptions are intercepted and ignored for k8s-event posting. #507
- Treat client timeouts during watches similar to other API errors. #506
- Handle all connection errors from the initial streaming request. #512
Experience improvements:
- Annotations restrictions on key length are reworked to allow longer names (v2/v1 keys). #529
- Annotations values are now compacted (no spaces) for the better visual outlook. #516
- Log/warn when the resulting patched object does not match the intended patch. #527
- Log when the patched object unexpectedly disappeared (e.g. was deleted). #559
- Log K8s API error explanations from K8s API itself, not from the HTTP client library. #558
- Filtered-out resources do not create phantom logs & do not get annotated anymore. #545
- Cluster-scoped objects are logged by their name, without "None" as the namespace. #544
- Better phrasing for some log messages to avoid confusion. #540
- Documentation fixes. #530
Internal changes:
- The first release since the fork. #502 #500 #505 #546
- CI feedback is sped up from ≈40-50 mins to ≈5 mins per push. #536 #537
- K3d/K3s is used for CI functional/integration testing; Minikube is for nightly tests. #536 #547
- K8s versions are updated for CI builds. #501
- Imports are sorted with
isort
. #525 #531 - Added tests for operators' peering. #519
- Added tests for logging & loggers. #544
- Get rid of mocks for causes & registries, use normal classes. #521
- Time-based tests are stabilised (though not fully fixed). #534 #528 #520 #522
- Asyncio tasks are now named in Python 3.8+, which makes the debugging easier. #542
- Python 3.9 support. #561