Switch indexeddb backend to sqlite and improve IPC messaging (#38187)

- Use sqlite instead of heed. (one indexed database = one sqlite
database)
- Implement the backend for indexes
- Use keyranges where needed (as specified by the spec)
- Implement `getKey`
- Fix channel error messaging (led to a bunch of changes to how async
requests are handled)

Note: `components/net/indexeddb/engines/sqlite/serialize.rs` is unused;
I can delete it if needed.

Testing: Switching to sqlite eliminated many panics (exposing some new
failures).
Fixes: #38040

---------

Signed-off-by: Ashwin Naren <arihant2math@gmail.com>
This commit is contained in:
Ashwin Naren 2025-08-16 00:27:17 -07:00 committed by GitHub
parent f4bbdf8010
commit fc3feceee5
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
59 changed files with 2002 additions and 818 deletions

View file

@ -1,10 +1,10 @@
[transaction-scheduling-ordering.any.html]
expected: CRASH
expected: TIMEOUT
[Verify Indexed DB transactions are ordered per spec]
expected: FAIL
expected: TIMEOUT
[transaction-scheduling-ordering.any.worker.html]
expected: CRASH
expected: TIMEOUT
[Verify Indexed DB transactions are ordered per spec]
expected: FAIL
expected: TIMEOUT