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><html><!--https://bugzilla.mozilla.org/show_bug.cgi?id=927796--><head><metacharset="utf-8"><title>Test for Bug 927796</title><scriptsrc="/tests/SimpleTest/SimpleTest.js"></script><linkrel="stylesheet"type="text/css"href="/tests/SimpleTest/test.css"/></head><body><atarget="_blank"href="https://bugzilla.mozilla.org/show_bug.cgi?id=927796">Mozilla Bug 927796</a><pid="display"><selectid="s1"><optionselected>one</option><option>two</option></select><selectid="s2"size="5"><optionselected>one</option><option>two</option></select></p><divid="content"style="display: none"></div><preid="test"></pre><scripttype="application/javascript">/** Test for Bug 927796 **/vars1=$("s1");s1.options[0].defaultSelected=false;is(s1.options[0].selected,true,"First option in combobox should still be selected");is(s1.options[1].selected,false,"Second option in combobox should not be selected");vars2=$("s2");s2.options[0].defaultSelected=false;is(s2.options[0].selected,false,"First option in listbox should not be selected");is(s2.options[1].selected,false,"Second option in listbox should not be selected");</script></body></html>