Bug 1976779 - rsclientcerts: make each backend responsible for rate-limiting calls to find_objects r=jschanck
Before this patch, `rsclientcerts::manager` would rate-limit calls to
`find_objects` to once every 3 seconds because the underlying operation can be
time-consuming (in particular, on macOS and Windows, if there are many
certificates/keys available). On Android, keys aren't available until the user
selects one, which means that if a call to `find_objects` happened before the
selection prompt was shown (which is what happens) and the user chose one in
less than 3 seconds, the backend wouldn't search again, thus making it seem like
no keys were available, which would cause Firefox to not send a client
certificate. This patch makes each backend implementation responsible for this
rate-limiting, because only they know if it's appropriate to do so (in particular,
on Android, `find_objects` doesn't have the same performance concern as
on macOS and Windows because rather than searching for certificates and
keys, it asks `ClientAuthCertificateManager` for the cached list of certificates
and keys that have already been approved for use by the user).
Differential Revision: https://phabricator.services.mozilla.com/D257065
<!DOCTYPE html><htmlclass="reftest-wait"><head><title>CSS Masking: Test clip-path xywh() interpolation</title><linkrel="help"href="https://drafts.csswg.org/css-shapes-1/#funcdef-basic-shape-xywh"><linkrel="match"href="clip-path-xywh-interpolation-001-ref.html"><metaname="assert"content="The clip-path property takes the basic shape 'xywh()' for clipping. Test the interpolation of xywh function."><style>@keyframesanim{from{clip-path:xywh(0px0px100px100%round10px);}to{clip-path:xywh(20px20px60px60%round20px);}}#rect{width:100px;height:100px;background-color:green;animation:anim10s-5spausedlinear;}</style></head><body><divid="rect"></div></body><script>requestAnimationFrame(()=>{document.documentElement.classList.remove('reftest-wait');});</script></html>