- Fix (Node): Respect the
databaseBasePath
setting for database deletions (#319); test courtesy @mikelehen - Fix (Node): Error (and warning) in cleaning up memory database resources (#320); test and fix courtesy @mikelehen
- Fix/optimization (Node): Don't remove cache after success, but if using cache, ensure getting last version and ensure async before dispatching any version error
- Refactoring: Avoid redundant
function
on object literals - npm: Fix web-platform-tests script
- Critical fix (Please upgrade from any previous 3.0.0 version):
Ensure unescaping done in SQL responses (and database names) always adds
back any literal
^
sequences. This loss could more easily happen for database names (whenever the name had a sequence of 1 or more literal^
followed by a singleA
toZ
(or[\u0000-\u001F\u007F"*/:<>?\\|]
or characters expanding on NFD normalization), but it could also happen in general SQL responses (or database names) where there was a sequence of 1 or more literal^
followed by an unmatched surrogate (though this should admittedly be unlikely for most users); this unescaping was meant to build back unmatched surrogates (which are allowed in IndexedDB) and the like which were unsafe for the SQLite engine used internally or for the file system used for Node, but we were failing to add back the^
escape in such cases (which was used as an escape character).
- Refactoring/Fix: For default
escapeNFDForDatabaseNames
check, temporarily circumvent current limitations in Babel until babel/babel#5978 addressed; (see also indexeddbshim#311 (comment)); fixes #311 - Linting: Expand ESLint file coverage and apply minor linting fix to test file
- Testing: Update web-platform-tests and our tests accordingly
- npm: Update
eventtargeter
to avoid automaticObject.setPrototypeOf
calls (make conditional onCFG.fullIDLSupport
); fixes #313
- npm: Update
package-lock.json
- npm: Resume allowing Node versions 8.93 - 9.0.0
- Docs: Put message in README about failure of one test as a known issue for the above Node versions
- Breaking fix (through npm): Update typeson and typeson-registry (ArrayBuffer, DataView, and typed arrays were not properly preserving entire underlying buffer when only a portion used; were also not restoring when buffers were reused cyclically across an object)
- npm: Update dev deps
- Install: Update
yarn.lock
/package-lock.json
- Testing (W3C): Update web-platform-tests
- Fix (minor): Return proper
indexedDB
object descriptor - npm: Update devDeps
- npm: Update dep to unicode-10.0.0 (no practical difference)
- Testing (W3C): Remove need for cheerio in build (use jsdom instead)
- Testing (W3C): Update
web-platform-tests
- Build: Switch from
devDependencies
todependencies
the following which Node or custom rollups may require: eventtargeter, sync-promise, typeson, typeson-registry, unicode-9.0.0
- Build: More complete
.npmignore
to exclude more files at root that we don't need in distributions - Build: Amend
.npmignore
to allow forsrc
inclusion (for those who wish to rollup own (complete or partial) versions) - Build: Update file copies out of
node_modules
needed for Rawgit demo
- Fix: Deal with issue with Chrome/Node and
Number.MIN_VALUE
converting to string - npm: Add
module
topackage.json
for potential use by Webpack/Rollup - npm: Limit engines to exclude Node 8.9.3 as having problems with Mocha IDBIndex/openCursor-spec.js test "should query multi-entry indexes with hundreds of records"; may be other problematic versions but 7.7.4 and 9.2.1 are ok
- npm (Build): Update devDeps including versioned
eventtargeter
,typeson
, andtypeson-registry
- npm (Build/Testing): Add missing
babel-core
devDep - npm (Build): Preserve LICENSE info in
npmignore
(and avoid redundant items) - npm (Testing): Add
web-platform-tests
andsqlite-rebuild
scripts - npm (Testing): Update W3C test script to clean before beginning as well
- Build: For Babel, use env over deprecated es2015; rebuild
- Build: Add
yarn.lock
- Docs: Remove outdated polyfill info in README (babel-polyfill should cover)
- Demo: Add example of IDBKeyUtils usage (not documented yet)
- License: Rename files to include file extensions for Windows
- Fix:
update
anddelete
were invalidating the cache and thus mistakenly incrementing cursor index; no longer invalidating the (read-only) cache - Enhancement: As part of #283 on export improvements, provide build
process for
Key.js
file to function as standalone file (currently targeted for Chrome) - Refactoring: In order to minimize build size for standalone
Key.js
, movecmp
out ofIDBFactory
and reference it. - npm: Update dev deps (including using harmony branch of grunt-contrib-uglify for correct ES6 support)
- Fix (Edge case): For
IDBDatabase.transaction()
(storeNames
arg),IDBDatabase.createObjectStore
(keyPath
parameter), andIDBObjectStore.createIndex
(keyPath
argument), ensure conversion to DOMString (ToString
) is being called per WebIDL (e.g., passingtrue
would produce a valid"true"
) while still throwing upon missing argument - Optimize: We didn't actually need structured cloning for keypaths as keypaths are valid JSON (but we did need the edge cases handled per the accompanying fix and the Typeson encoded as of 3.0.0 should remain compatible with this reversion to JSON)
- Refactoring (minor): Use ES6 object property name shorthand
- npm: Update dev deps
- Demo: Update copies of test files
- Fix: Avoid allowing (open-ended) escaped Unicode escape sequences for key paths (JavaScript handles the escape sequences!).
- Fix: Avoid double-escaping zero-width joiners/non-joiner in key path check.
- npm: Update dev deps
- Fix: Incorporate
typeson
library fix for periods within property names; could create cloning issues - Linting: Update per linting software updates (indents)
though avoid
no-mulit-spaces
reporting (frequent in tests) - Linting: Update and apply ESLint compat plugin linting
- npm: Update dev deps
- npm: Avoid shrinkwrap for now, pending import-js/eslint-plugin-import#871
- Testing (W3C): Update
web-platform-tests
- Testing (W3C): Exclude new
large-nesting-cloning.js
file as preventing some other tests from running; also removeparallel-cursors.uprade.js
from good tests as in timeouts (since it sometimes times out) - Docs (Testing): Update note on running W3C Node tests
- Docs (README): Fixed first hyperlink not working (courtesy @Erwin)
- Update in case lagging
npm shrinkwrap
version causing any issues - Docs (README): Update version number and remove completed to-do
- Testing: Update copies of Mocha/Chai/Sinon (for rawgit.com)
- Testing (Grunt): Comment out cumbersome minified version updater
- Testing (W3C): Revert from apparently problematic
cheerio
RC
Though we have tried to keep this accurate, some changes listed below might
have been mistakenly ascribed to changes since the previous release whereas
they were actually changes since a more recent version on master
.
-
License: Add back missing MIT license
-
Security fix: Avoid SQL injection potential--ensure database, store and index names are prefixed as SQLite columns to avoid conflict with built-in columns; add test
-
Security fix: Ensure
LIKE
clauses escape special characters -
Security fix: Escape SQLite-disallowed-for-column-names NUL characters from database, store, and index names
-
Security fix: Escape/unescape NUL for safety with node-websql->node-sqlite3 (part of fix for #274)
-
Security fix: Ensure quoting (for column names) escapes double quotes
-
Security fix: As per new requirements, ensure
IDBFactory
methodsopen
,deleteDatabase
(and we do it for the non-standardwebkitGetDatabaseNames
as well as it could relate to privacy) throw aSecurityError
DOMException
if run from a"null"
origin (unless the new configcheckOrigin
is set tofalse
); for Node, requireslocation
to be defined globally (could have some applications in Node, too, e.g., if jsdom sets the origin for iframes) -
Breaking refactoring with consequences for old data: prefix store/index names with "S_" instead of "s_" and "I_" instead of "" (consistent with casing of "D" though SQLite insensitive with ASCII while file systems may be sensitive; more future-compatible)
-
Breaking change: Avoid encoding
keyPath
internally as JSON--needs Sca encoding;breaks all tables but important to fix!Shouldn't have broken tables as supplied keypaths should only have produced Typeson that is JSON; other breaking db changes were needed in this version, however -
Breaking change/Fix: Remove
IDBTransaction
mode constants and tests since now being removed from IndexedDB -
Breaking change: Remove old
polyfill.js
code for incrementally plugging browsers with incomplete support (has not been tested for a long time and had perhaps not been properly kept up to date anyways); one can still use IndexedDBShim to replace the whole implementation, however. -
Breaking change: Throw if database name is too long, defaulting to 254 (part of fix for #274) (enforcing compatibility with Node, given our mapping it to file naming on common file systems)
-
Breaking change: If you were overriding/monkey-patching globals, these are no longer available with a shift to ES6 modules (see below). The
CFG.js
module can be imported in its place to change the default values, however. -
Breaking fix for existing data: Give comparisons/storage of arrays higher priority over binary (arrays already existing in storage will not benefit from this until re-encoded, however)
-
Breaking fix for existing data: Change encoding of key types so any future key types can be fitted into the proper place for sorting precedence
-
Breaking change (minor): Change "modules" property of
IDBFactory
to only exposeDOMException
,Event
, andIDBFactory
(replacing the former use ofidbModules
with ES6 modules and a CFG module for the globals: see below) -
Breaking change (minor): Change "eval" to "evaluate" in exception message for bad key from
keyPath
-
Breaking change (minor): Remove unneeded
DOMError
methods -
Breaking change (minor): As moved away from SQL offsets for
IDBCursor
retrieval, remove__lastKeyContinued
property (we can use__key
); also remove unused__multiEntryOffset
-
Deprecate: Numeric constants as second arguments to
IDBDatabase.prototype.transaction
(usereadonly
/readwrite
instead). -
Enhancement: Add config to allow user to override
escapeDatabaseName
function (and for convenience,unescapeDatabaseName
) or to keep it but configure its new config subcomponents,databaseCharacterBlacklist
and/ordatabaseNameLengthLimit
(part of fix for #274) -
Enhancement: Throw upon receiving bad config property in config methods
-
Enhancement: Allow initial config object to
setGlobalVars
(e.g., for setting an earlyCFG.win
value) -
Enhancement: Allow non-invasive browser build (inspired by @bolasblack's fork)
-
Enhancement: Add non-standard
webkitGetDatabaseNames
and test file (issue #223) -
Enhancement: Allow
DEFAULT_DB_SIZE
to be set viaCFG.js
; -
Enhancement:
IDBIndex
methods,get
,getKey
,count
to allow obtaining first record of anIDBKeyRange
(orIDBKeyRange
-like range) and change error messages to indicate "key or range" -
Enhancement: Support Node cleanly via
websql
SQLite3 library including customization of SQLitebusyTimeout
,trace
andprofile
-
Enhancement: Add
IDBObjectStore.openKeyCursor
-
Enhancement: Add
IDBKeyRange.includes()
with test -
Enhancement: Allow ranges to be passed to
IDBObjectStore.get
andIDBObjectStore.delete()
-
Enhancement: Allow key argument with
IDBCursor.continue
. -
Enhancement: Key value retrieval: Allow "length" type key
-
Enhancement: Add ".sqlite" extension to database name for sake of (Windows) file type identification
-
Enhancement: Expose
__setConfig(prop, val)
method for setting pseudo-global property used internally for config andshimIndexedDB.__getConfig()
to read -
Enhancement: Expose
__setUnicodeIdentifiers()
for setting Unicode regular expression strings for full key path validation compliance (could slow loading/performance as depends on large regular expressions) -
Enhancement: Implement
IDBTransaction.objectStoreNames
-
Enhancement: Add
IDBObjectStore.name
andIDBIndex.name
setters -
Enhancement: Add various missing lesser event properties (
NONE
,CAPTURING_PHASE
,AT_TARGET
,BUBBLING_PHASE
) and initialize readonlytarget
,currentTarget
,defaultPrevented
,isTrusted
. -
Enhancement: Utilize
EventTarget
to invokedispatchEvent
to allow invocation of multiple listeners as byaddEventListener
(not yet treating bubbling orpreventDefault
); changeShimEvent
to utilize polyfill fromeventtarget
-
Enhancement: Expose
ShimDOMStringList
onindexedDB.modules
for sake of tests (the former also renamed internally for interfaces testing); we may deprecateindexedDB.modules
however, asCFG.addNonIDBGlobals
is now allowing export -
Enhancement: Add new
CFG
property,addNonIDBGlobals
, to allow polyfilling non-IndexedDB interfaces used internally (and needed potentially for testing);ShimDOMStringList
,ShimDOMException
,ShimEvent
,ShimCustomEvent
, andShimEventTarget
-
Enhancement: Add non-standard
sqlError
property toDOMException
for facilitating debugging -
Enhancement: Export
ShimCustomEvent
andShimEventTarget
shims we are using onIDBFactory.modules
for sake of testing checks -
Enhancement: Add
addSQLiteExtension
config to add ".sqlite" to user databases, taking it into account when throwing against any file length limits -
Enhancement: Add
deleteDatabaseFiles
config to allow file itself to be deleted in Node; will throwUnknownError
if there are any errors removing file (besides a missing file) -
Enhancement: Make addition of
.sqlite
extension to__sysdb__
conditional onCFG.addSQLiteExtension
setting -
Enhancement: Support
autoName
config to interpret empty string name as a cue for creating a database name automatically (introspect onIDBDatabase.name
to get the actual name used) (untested) -
Enhancement: Support
memoryDatabase
config to cause all opening, deleting, and listing to be of SQLite in-memory databases (for Node); name supplied by user is still used (including to automatically build a cache since SQLite does not allow naming of in-memory databases); the name is also accessible toIDBFactory.webkitGetDatabaseNames()
; causes database name/version tracking to also be within an in-memory database; part of #278 (untested); builds on work by @ThomasGreiner) -
Enhancement: Support
cacheDatabaseInstances
config to ensure that any repeatIDBFactory.open
call to the same name and version (assuming no deletes or aborts causing rollbacks) will reuse the same SQLiteopenDatabase
instance -
Enhancement: Add
useSQLiteIndexes
option to add (and drop) SQLite indexes where utilized (#210) -
Enhancement: Provide
avoidAutoShim
option (#270) -
Enhancement: Provide
shimIndexedDB.__setConnectionQueueOrigin()
utility -
Add missing API: Add
IDBCursor.continuePrimaryKey
-
Add missing API: Implement
IDBObjectStore.getKey
-
Add missing APIs: Implement
IDBIndex.getAll/getAllKeys
-
Add missing APIs: Implement
IDBObjectStore.getAll
,IDBObjectStore.getAllKeys
-
Add missing API: Binary keys
-
Add missing API:
versionchange
andblocked
events (currently assumes single process) -
Fix: Ensure
IDBKeyRange
'slower
andupper
get round-tripped key-encoded (e.g., to ensure aDataView
gets converted into anArrayBuffer
) -
Fix: Avoid
continue
errors upon multiEntry checks with open-ended ranges -
Fix: Ensure
deleteDatabase
SQLite execution errors (not only its transaction errors) are properly surfaced (probably shouldn't occur once we implement blocking transactions anyways, but should resolve in case such errors may occur) -
Fix: Add error codes on
DOMException
's for sake of web-platform-tests' testharness.js even though new spec does not list the codes andcode
is listed on MDN as no longer being set on new exceptions -
Fix: Ensure
AbortError
sent toIDBOpenDBRequest.onerror
upon a transaction aborting or a connection being closed within an upgrade transaction -
Fix: Set
IDBOpenDBRequest.transaction
tonull
uponAbortError
due to closed connection -
Fix: Set
error
property ofIDBTransaction
for certain tx aborts -
Fix: 'error' and 'abort' bubbling events ((
IDBRequest
->)IDBTransaction
->IDBDatabase
), including reuse of same event object upon propagation and potential for cancellation as appropriate; used withinIDBTransaction
and potentially withinIDBFactory
-
Fix: Set
readyState
to "done",result
toundefined
, anderror
to a newAbortError
on each request when aborting a transaction -
Fix: Set transaction active flag on while dispatching success/error events
-
Fix: Abort transaction upon request "success" handler throwing or "error" handler throwing or "error" event not being prevented
-
Fix: Trigger queue of "error"-type events on all unfinished requests during transaction abort (then "abort" type event on transaction)
-
Fix: Avoid adding
DOMException
class when error not found (should not occur?) -
Fix (minor): Avoid defaulting to
DOMException
class for error instances inIDBFactory
-
Fix: Unknown problems creating/deleting object stores or indexes should have
UnknownError
DOMException
name (and fail through events) -
Fix: Report
ConstraintError
if attempting to add a unique index when existing values are not unique -
Fix: Ensure IndexedDB
DOMException
is returned forIDBFactory
method errors instead of WebSQL errors -
Fix: Use
AbortError
asIDBTransaction.error
property when "error" handler throws -
Fix: If transaction already aborted, avoid potential for request errors firing
-
Fix: If transaction already aborted, avoid running further request callbacks or success/error events
-
Fix: Throw for
IDBRequest
orIDBOpenDBRequest
withresult
anderror
getters if request not yet done -
Fix: Ensure
IDBOpenDBRequest
result
is set toundefined
upon erring -
Fix: Ensure
IDBOpenDBRequest
transaction
is set tonull
upon completing or aborting -
Fix: Add duck-typing
instanceof
mechanism forShimEvent
-
Fix: Change type to "abort" for transaction abort events
-
Fix: Set
readyState
for successfulIDBFactory.deleteDatabase
andIDBFactory.webkitGetDatabaseNames
-
Fix: If calling
deleteDatabase
on non-existing database, ensureoldVersion
is 0 (notnull
) -
Fix: Set
readyState
to 'pending' forIDBCursor
continue
/advance
-
Fix: Avoid adding requests with success events for
createObjectStore
/deleteObjectStore
/createIndex
/deleteIndex
and store/index renaming -
Fix: Avoid firing multiple
success
events withIDBFactory.open
-
Fix: Return appropriate IndexedDB error object instead of WebSQL error object; fixes #27
-
Fix: For
IDBCursor
, move from SQL offsets to utilization of last key as per spec (and as needed for discovering any db modifications) -
Fix: In conjunction with
IDBCursor
continue
andadvance
caching, trigger cache resets/changes (forIDBCursor
:delete
,update
and forIDBObjectStore
:add
,put
,delete
,clear
); -
Fix: Cause
IDBCursor.advance
to properly handle unique values (and also take advantage of caching) -
Fix:
IDBCursor
key-basedcontinue
to be direction-sensitive -
Fix:
IDBCursor
request source should be store or index, not cursor -
Fix: stores cursor
-
Fix: Avoid
cursor.update
always getting next key -
(Fix: Avoid storing cursor (for
IDBObjectStore.count
) if will be no cache) -
Fix: In Safari, default DEFAULT_DB_SIZE to a higher value (25 * 1024 * 1024); fixes #115
-
Fix: Properly implement and utilize
IDBCursorWithValue
-
Fix: Use latest draft spec's (and implementations') use of
DOMException
instead ofDOMError
-
Fix: Replace
instanceof
checks withArray.isArray()
for arrays and with duck-typing otherwise (for reliability with cross-window/module data) -
Fix: For
advance
/continue
, throw if the cursor source or effective object store has been deleted -
Fix: Ensure will throw when "got value flag" is unset during call to
continue
oradvance
-
Fix: Ensure "prev" cursor will iterate in descending order on primary key (sort by keyPath-indicated value then primary key)
-
Fix: Allow empty string keyPath for index to return value as is (for handling non-object values as keys)
-
Fix: For
IDBCursor.advance
, better range enforcement -
Fix: Ensure the error thrown for a count
<=0
toadvance()
is a genuineTypeError
-
Fix: Ensure other bad counts passed to
advance()
(non-numbers or non-finite numbers) throwTypeError
as per W3C tests (even though the spec is silent on bad counts except for count=0) -
Fix: Add transaction to
IDBCursor
request -
Fix: Update keyRange behavior and tests to reflect draft spec
-
Fix: Allow
__versionTransaction
not to exist (if user calling it wrong) forcreate/deleteObjectStore
and test it so it will return anInvalidStateError
-
Fix: Avoid
LIKE
check on auto-increment sequence check (could be store name inside another store name); -
Fix: Ensure numeric keys passed to
add()
orput()
on an auto-increment store which are greater or equal to the "current number" will update the auto-increment counter -
Fix: Ensure a keyPath added numeric auto-increment key will update the auto-increment counter
-
Fix: Avoid potential problem with data insertion if an index were named "key"
-
Fix: Throw
TypeError
onIDBKeyRange
methods with inadequate arguments andDataError
-typeDOMException
with explicitundefined
-
Fix: If
lower
is greater than theupper
argument toIDBKeyRange.bound
, throw aDataError
-
Fix: Throw
DataError
upon continuing the cursor in an unexpected direction -
Fix: Key validation: Avoid circular arrays
-
Fix: Key validation: Disallow Dates with NaN as [[DateValue]]
-
Fix: Ensure validation occurs for indexes before storage
-
Fix: Implement
IDBVersionChangeEvent
properly and utilize to allowinstanceof
checks -
Fix: Sort properly for next/prev(unique) (potentially by key, primary key, (position,) obj. store position)
-
Fix: Be safe in quoting "key" column (reserved SQLite word)
-
Fix: For all public methods, seek to ensure error checking occurs in spec order and add missing checks
-
Fix: Throw for
IDBCursor.update/delete
if transaction not active, if source or effective object store deleted, if got value not set, or if a key method has been invoked -
Fix: Throw
DataCloneError
ifIDBCursor.update
value is not clonable by the Structured Cloning Algorithm -
Fix: Improve structured cloning checking by using cyclonejs (not currently used for cloning though could be used elsewhere where not needed to be encoded); also avoid use of JSON.stringify which only works on a subset of SCA
-
Fix: Throw
TypeError
if call toupdate()
has no arguments -
Fix: Allow empty string key path to be utilized when validating
add
/put
input -
Fix: Avoid iterating duplicate key values for unique iterations
-
Fix: Ensure
IDBRequest.error
returnsnull
rather thanundefined
upon success event -
Fix: Readonly
- Make
indexedDB
readonly - Make
IDBCursor
properties,key
,primaryKey
,direction
,source
,value
readonly - Make
IDBRequest
properties (result
,error
,source
,transaction
,readyState
) readonly - Make
IDBDatabase
properties,name
,version
, andobjectStoreNames
readonly - Make
IDBKeyRange
properties,lower
,upper
,lowerOpen
, andupperOpen
readonly, renaming cached range attributes - Make
IDBTransaction
properties,objectStoreNames
,mode
,db
, anderror
readonly - Make
IDBIndex
properties,objectStore
,keyPath
,multiEntry
,unique
readonly - Make
IDBObjectStore
properties,keyPath
,indexNames
,transaction
,autoIncrement
readonly - Ensure
keyPath
does not return same instance as passed in (if an array) - Make
ShimEvent
properties,type
,bubbles
,cancelable
,eventPhase
,timeStamp
readonly (and for native events, stop makingtarget
writable)
- Make
-
Fix: Ensure
IDBIndex
properties,multiEntry
,unique
are always boolean -
Fix: Ensure an
IDBTransaction.objectStore
call always returns the same instance if for the same transaction -
Fix: For
IDBTransaction.abort()
, throwInvalidStateError
if transaction not active -
Fix: Ensure
IDBIndex
retrieval methods throw upon index or store being deleted, upon transaction inactive -
Fix: Allow
IDBIndex.count
to passnull
as key -
Fix: Throw if not in versionchange transaction when calling
IDBDatabase.transaction
-
Fix: Ensure
DOMException
variant ofSyntaxError
is thrown for bad key paths -
Fix: Handle (mistaken) arguments > 2 to
IDBFactory.open()
-
Fix: In
IDBObjectStore
methods, throw upon transaction inactive; fix checking error -
Fix: In
IDBObjectStore.count
, allownull
(as withundefined
) to indicate unbounded range -
Fix: Correct
IDBRequest.source
to reflectIDBCursor
,IDBIndex
, orIDBObjectStore
as appropriate -
Fix: Prevent race condition error if attempting to find indexes during insertion when index creation has begun but not yet completed
-
Fix: Validate keyPath supplied to
createObjectStore
-
Fix: Allow for empty string keyPath to
createObjectStore
-
Fix: Clone options object passed to
createObjectStore
-
Fix: Overcome lone surrogate limitation in node-sqlite3/Python (see http://bugs.python.org/issue12569 and http://stackoverflow.com/a/6701665/271577)
-
Fix: For
createObjectStore
, throw if transaction is not active, or if auto-increment with empty string or array key path -
Fix: Ensure
__versionTransaction
set tonull
and set beforeoncomplete
so thatversionchange
checks insidee.target.transaction.oncomplete
withinonupgradeneeded
or insideonsuccess
will fail (and thus will attempts to create or delete object stores) -
Fix: Throw InvalidStateError if store deleted (for
IDBObjectStore
methods:add
,put
,get
,delete
,clear
,count
,openCursor
,openKeyCursor
,index
,createIndex
,deleteeIndex
) -
Fix: For
IDBObjectStore.deleteIndex
, throw if not in upgrade transaction or if transaction is inactive -
Fix: For
IDBObjectStore.createIndex
, throwSyntaxError
if not a valid keyPath given -
Fix: For
IDBObjectStore.createIndex
, throw if transaction not active -
Fix: Apply
toString()
(and convert from sparse to dense) for validation and utilization within key path arrays -
Fix: Validate
IDBKeyRange
-like objects (e.g., passed to cursor methods) -
Fix: Properly ensure with multiEntry conversions that array members which fail validation as keys are ignored (and avoid adding duplicate members
-
Fix: Ensure
success
event does not fire if database has already been closed (inupgradeneeded
) -
Fix: Make
length
onDOMStringList
non-enumerable (impacts W3C tests and also how implemented in Chrome) -
Fix: Error checking for
DOMStringList
methods -
Fix: Prevent non-numeric and
<= 1
keys from auto-incrementing current number -
Fix: For generators, as per new requirements, ensure numbers higher than the max (including non-finite) have the effect of setting the current number to the max
-
Fix: For generators, handle numbers just beyond the max allowed by ES since confusable if only incrementing by one
-
Fix: Default to
global
for IDB exports where nowindow
orself
is defined -
Fix: Prevent incrementing if nevertheless valid key is lower than current number
-
Fix: Ensure sorting of
StringList
(forIDBDatabase.objectStoreNames
,IDBObjectStore.indexNames
) -
Fix: Escape upper-case letters as table/column names case-insensitive in SQLite, but db/store/index names not case-insensitive in IndexedDB
-
Fix: Add default option
escapeNFDForDatabaseNames
to escape characters that expand on NFD normalization so as to avoid accidental loss of precise Unicode code points and thus potential name clashes on the Mac which does NFD normalization on the file system (user should normalize themselves if they want normalization); part of #278 -
Fix: Stringify calls to
IDBDatabase.createObjectStore
andIDBObjectstore.createIndex
as per W3C tests -
Fix: Avoid setting
source
foropen
request, as, per new spec, it is to always benull
-
Fix: Ensure cloning value before as well as after key evaluated (otherwise, original object will be modified)
-
Fix: Check for array on range within multiEntry cursor iteration; fixes issue #222
-
Fix: Copy SQLite row
item
object properties (for Safari); fixes issue #261 -
Fix: Genuinely rollback version in Node
- Wrap all possible
openDatabase
operations, including version changes into an effectively single transaction; - Revert
IDBDatabase
version
andobjectStoreNames
;IDBObjectStore
name
andindexNames
;IDBTransaction
objectStoreNames
, andIDBIndex
name
properties after aborted transactions; - Allow
dbVersions
table insert to be undone in one transaction (also avoids second query); - If connection closed or errs, rollback; otherwise, commit only after transaction finished;
- Reimplement
deleteDatabase
to delete fromdbVersions
first and rollback everything if there is a failure
- Wrap all possible
-
Fix: In browser, only version can be consistently rolled back since we can't extend WebSQL transaction expiration (and thus force an error to get auto-rollback given that ROLLBACK is not supported)
-
Fix: Destroy index entries from index set upon store deletion and still allow recreation of store handles (but not removing whole clone record, allowing its properties to still be examined)
-
Fix: Ensure
createObjectStore
/createIndex
return same handles asobjectStore
/index
methods -
Fix: Avoid resetting store name if the store already existed before an upgrade transaction (per W3C test
idbobjectstore-rename-abort.html
) -
Fix: Ensure
IDBTransaction.objectStoreNames
is always aDOMStringList
even when user supplies arrays -
Fix: As per spec,
DELETE
thenINSERT
rather thanUPDATE
forIDBCursor.update
-
Fix: Add support for new "closed" event via a custom
IDBFactory.__forceClose()
method (untested) -
Fix: Do not set got value flag if end of iteration (and also avoid setting irrelevant got value flag on count cursors)
-
Fix: Closing the database in an upgrade transaction should not prevent execution of the
oncomplete
handler (though anAbortError
will subsequently occur) -
Fix: Allow
IDBFactory.open()
to accept explicitundefined
version -
Fix: Round down version in
IDBFactory.open()
-
Fix: Ensure store names passed into
IDBDatabase.transaction
are stored as unique names and are sorted -
Fix: Add
Symbol.toStringTag
(ortoString
) toIDB*
classes for properObject.prototype.toString.call
-type invocations checked in W3C interface tests) -
Fix: Throw precise and better ordered exceptions upon non-strings or non-iterable objects or non-string sequences being supplied as
storeNames
argument toIDBDatabase.transaction
(as should occur per WebIDL when converting to a "DOMString or sequence<DOMString>"); see https://heycam.github.io/webidl/#es-sequence -
Fix: Add iterator to
DOMStringList
as it should be convertable to sequence<DOMStringList> per https://html.spec.whatwg.org/multipage/infrastructure.html#domstringlist and https://infra.spec.whatwg.org/#list-iterate -
Fix: Make
DOMStringList
non-enumerable but configurable -
Fix: Interface changes for
DOMStringList
: illegal constructor, length enumerable,instanceof
override -
Fix: WebIDL-based changes, including:
- new
CFG
optionfullIDLSupport
to avoid expensivesetPrototypeOf
by default; - Illegal constructor and
prototype
invocation (while allowing normal access) - Make
prototype
non-writable as appropriate - Ensure
constructor
set onprototype
as appropriate - Proper
Symbol.toStringTag
andtoString
exposure on classes and prototypes - Use
arguments
object in place of some function parameters to get proper function lengths - Set properties to appropriate
enumerable
/configurable
- Set proper inheritance hierarchy, including to
EventTarget
orEvent
- new
-
Fix: Properly report global shimming errors when setting a readonly failed and
Object.defineProperty
is not present -
Fix: As per spec, check whether transaction is finished for
IDBDatabase
(createObjectStore
,deleteObjectStore
),IDBObjectStore.index
,IDBTransaction
(objectStore
,abort
), and not merely whether it is active -
Fix: Improve evaluate key path splitting of identifier algorithm
-
Fix: Ensure extraction of key value from value using key path algorithm is applied during ignoring of bad indexes of storage and during checks for storing operations
-
Fix: Better
IDBIndex
(openCursor
,openKeyCursor
,count
,get*
) range validation -
Fix: Disallow invocation of
webkitGetDatabaseNames
onIDBFactory.prototype
-
Fix: Throw synchronously if won't be able to inject into a value (thereby avoiding the need to check during the injection); assumes PR w3c/IndexedDB#146
-
Fix: Make
DataError
message more accurate for cursor key path resolution failures -
Fix: Ensure non-numeric/non-finite or
< 1
keys can be stored as per spec even though not changing the current number -
Fix: Allow iterables where
sequence<DOMString>
is accepted (IDBDatabase.createObjectStore
,IDBObjectStore.createIndex
,IDBDatabase.transaction
) -
Fix: Avoid modifying the supplied
createObjectStore
createOptions
object whenkeyPath
isundefined
-
Fix: For
IDBDatabase.transaction
, allowToString
to occur on iterables -
Fix: Tighten up
DOMException
shim to support legacy constants per W3C tests and better follow W3C interface expectations -
Fix: Improve precision of
util.isFile
and haveutil.isBlob
fail with files but support non-file Blobs -
Fix: Clone before checking against key path (
IDBObjectStore
(put
,add
) andIDBCursor.update
) -
Fix: Avoid
eval()
in cloning (issue #211, #236) -
Fix: Support cyclic values via typeson/typeson-registry (#267)
-
Fix: Distinguish deleted and pending deleted stores and indexes; for insertion operations, do index checks independent of
indexNames
in case subsequently deleted bydeleteIndex
(#276) -
Fix: Ensure same index instance object returned for same store object and index name
-
Fix: Better error reporting for
IDBRequest.error
orIDBRequest.result
errors. -
Fix: Throw
InvalidStateError
DOMException
upon deleted object store or index for:- cursor-related operations
- index and store name setters
- index and store get or manipulation operations
- index creation, deletion, or retrieval operations
-
Fix: Ensure will throw
InvalidStateError
DOMException
as with deleted object stores or indexes for access after an aborted transaction when there were pending object stores or indexes to be created -
Fix: Cause not finished assertions to fire even if at beginning of abort except for
IDBDatabase
createObjectStore
/deleteObjectStore
which per corrected spec throw different error upon (incompletely) finished check -
Fix
IDBDatabase.createObjectStore
exception order fix (object storeConstraintError
check follows key pathSyntaxError
check) -
Fix
IDBDatabase.transaction
exception order fixes (InvalidAccessError
followsInvalidStateError
version change check,InvalidStateError
closed check, andNotFoundError
object store check);TypeError
mode check per newly corrected spec behavior, to follow all other exception checks -
Fix: Close connection on abort (setting closed flag)
-
Fix: Have
deleteDatabase
empty relevantconnections
(relevant for__forceClose
as well asopen
) -
Fix: Change
VARCHAR(255)
toBLOB
for database and store name fields as may be longer (for db names, ifdatabaseNameLengthLimit
is higher than default) -
Fix: Upon upgrade transaction abort, attempt to clean up other resources (remove memory database or remove/empty database file if no prior versions)
-
Fix: Ensure escaping of unmatched surrogates occurs in all SQLite statements as needed by Chrome (but not Node) (noted in failed dropping of tables)
-
Fix: Revert current number if operation fails (even if not aborting)
-
Fix: Avoid reporting abort errors on duplicates of same request in transaction queue (ensures subsequent unsetting of cursor request done flag does not return additional error results in an abort error)
-
Repo files: Rename test folders for ease in distinguishing
-
Optimize: Only retrieve required SQLite columns
-
Optimize: Have
IDBObjectStore
andIDBIndex
'sget
andgetKey
only retrieve one record from SQLite -
Optimize: use WebSQL
readTransaction
as possible/when inreadonly
mode -
Optimize: Run SELECT only on columns we need
-
Optimize: Avoid caching and other processing in
IDBCursor
multiEntry finds (used byIDBObjectStore
orIDBIndex
count
with key range) -
Optimize: Switch to
SyncPromise
for faster execution -
Optimize: Avoid redundant key->value checks and redundant cloning
-
Optimize: Avoid cloning key when already a primitive
-
Refactoring: Replace Node-deprecated
GLOBAL
withglobal
-
Refactoring: Rename internal escaping/unescaping functions to semantic names and add further documentation
-
Refactoring (Avoid globals): Change from using window global to a CFG module for better maintainability
-
Refactoring (Avoid deprecated): Avoid deprecated
unescape
-
Refactoring (ES6): Add Babel with ES6 module support for imports and add to ESLint
-
Refactoring (ES6): Move to ES6 modules with babel/browserify (for immediately clear semantics and cruft removal), removing 'use strict' (redundant for modules) and remove build.js
-
Refactoring (ES6): Use
const
where possible, andlet
otherwise and add as ESLint rules, other minor changes -
Refactoring (ESLint): Move from JSHint to ESLint and to "standard" config, with a few exceptions
-
Refactoring (spec parity): Use same naming/return of methods in spec
-
Refactoring (spec parity): Implement
convertKeyToValue
(not in use internally) -
Refactoring (spec parity): Extract steps for storing a record (affecting
IDBCursor.update
andIDBObjectStore
'sput
/add
) -
Refactoring (spec parity): Perform auto-increment in spec order (should be of no consequence to the user, however)
-
Refactoring (spec parity): Rename
Key.getValue
toKey.evaluateKeyPathOnValue
-
Refactoring (spec parity): Rename and repurpose
Key.validate
toKey.convertValueToKey
(also paralleling terminology in the spec), also supporting multiEntry argument -
Refactoring (spec parity): Make current number retrieval routines more closely parallel spec
-
Refactoring (spec parity): Mirror recent minor spec changes re: bubbling/cancelable
IDBFactory
error events -
Refactoring (SQL): Quoting columns consistently for SQLite
-
Refactoring (SQL): Make SQL-relationship clearer for method names (escaping)
-
Refactoring (SQL): upper-case SQL keywords for greater visual distinction
-
Refactoring: Where safe, switch from
typeof ... === 'undefined'
to check against undefined (safe for strict mode implicit in modules) -
Refactoring: Use spread operator in place of
arguments
where named args not needed (also may be more future-proof) -
Refactoring: Have
setSQLForRange
handle key encoding -
Refactoring:
isObj
utility, further use ofArray.isArray()
-
Refactoring: Key value retrieval: Avoid
eval()
(#211, #236) -
Refactoring: Use ES6 classes for cleaner inheritance
-
Refactoring: Avoid JSON methods upon each
objectStore
/createObjectStore
call in favor of one-time inIDBDatabase
-
Refactoring: Replace SQLite auto-increment with our own table since SQLite's own apparently cannot be decremented successfully; also rename to spec "current number"
-
Refactoring: Avoid using native events, as we need to let
EventTarget
alter its readonlytarget
,currentTarget
, etc. properties -
Refactoring: Throw count 0 error differently from negative count in
IDBCursor.advance
-
Refactoring: Put
DOMStringList
andIDBVersionChangeEvent
into own files -
Updating: Bump various
devDependency
min versions -
Docs: List known issues on README
-
Docs: Notice on deprecation for transaction mode constants
-
Docs: Update summarization of npm testing info
-
Docs: Distinguish
dependencies
/devDependencies
display on README -
npm: Update packages
-
Testing: Update tests per current spec and behavior
-
Testing: Ensure db closes after each test to allow non-blocking
open()
(was affecting testing) -
Testing: Work on Node tests and for Firefox (including increasing timeouts as needed)
-
Testing: Rely on
node_modules
paths for testing framework files -
Testing (browser index): Update links to test cases
-
Testing (ESLint): Add compat plugin for browser feature testing
-
Testing (fakeIndexedDB.js): Comment out non-standard property checks
-
Testing (mock): Update IndexedDBMock tests
-
Testing (mock): Expect
InvalidStateError
instead ofConstraintError
when not in an upgrade transaction callingcreateObjectStore
-
Testing (mock): Fix for
blocked
event's expectednewVersion
(submitted fix as kristofdegrave/indexedDBmock#2) -
Testing (W3C Old): Fix global
-
Testing (W3C Old): Bump timeout for browser key validity tests
-
Testing (W3C Old):
IDBFactory.open
tests to do more flexibleinstanceof
checks; -
Testing (W3C Old): Fix test to reflect latest draft spec -- see brettz9/web-platform-tests#1
-
Testing (W3C Old): Cause recursive value test not to be skipped
-
Testing (W3C Old): Change example to expect
ConstraintError
(since object store already existing per test)--though perhaps should ensure it is not yet existing -
Testing (W3C Old): Ensure
DOMException
variant ofSyntaxError
is checked -
Testing (W3C Old): Increase timeout for Node testing
createObjectStore
'sIDBObjectStoreParameters
test and IDBCursorBehavior'sIDBCursor.direction
-
Testing (W3C Old): Utilize Unicode in
KeyPath.js
test -
Testing (W3C Old): Update w3c-old to work with browser
-
Testing (W3C Old): Fix a few globals, increase test timeouts for browser, allow array-like properties as per original tests
-
Testing (W3C Old): Update tests per latest behavior as far as throwing
InvalidStateError
for deleted object stores or indexes -
Test scaffolding (W3C Old): Fix args to
initionalSituation()
-
Test scaffolding (W3C Old): Fix test ok condition, typo
-
Test scaffolding (W3C Old): Fix assertions
-
Testing (W3C): Add new preliminary testing framework (mostly complete)
-
Testing (W3C): Add separate tests for events and workers; also incorporate tests for
DOMStringList
andDOMException
-
Testing (W3C Old): Fix
DOMStringList
API usage (failing on Safari) -
Testing (W3C Old): Partly update
TransactionBehavior.js
tests to ensureobjectStoreNames
are compared as arrays -
(Testing) (Unless stated otherwise, "Browser" below refers to Safari 10.1 and Chrome 57.0.2987.133 (64-bit); note that both browsers (especially Safari may require re-running tests or running the tests as individual groups)
From tests-qunit (Node and browser), all tests are now passing.
From tests-mocha (Node), all tests are now passing. From tests-mocha (Browser), all tests are now passing except: 1. in Chrome:
IDBFactory.cmp
simple keys->should compare two numbers
due to an apparentNumber.MIN_VALUE
problem as described here.From fakeIndexedDB (Node), all tests now passing. From fakeIndexedDB (Browser), only the first test is passing (as expected due to rollback limitations);
From indexedDBmock (Node and browser), all tests are now passing. (see https://github.com/kristofdegrave/indexedDBmock/compare/f6cdf451769827e13c746984b820096b0de3ac6d...master for any new changes to add to tests).
From old W3C (Node and browser), all tests are now passing.
From new W3C (Node): See
/test-support/node-good-bad-files.js
for the current test status on these tests.From new W3C (Browser): Individual tests can be run as per TESTING. See node-good-bad-files.js for the current test status on these tests.
-
Testing (Grunt): Force ESLint (since "standard" currently causing a warning)
-
Testing (Grunt): More granular uglification, add build-browser, dev-browser, Unicode watching
-
Testing (Grunt): Add Node-specific, Unicode-specific build/dev commands
-
Testing (Grunt): Clarify Grunt tasks, expand tasks for cleaning, make tests more granular
-
Testing (Grunt): Remove now redundant
sourceMappingURL
, usesourceMapName
per current specs -
Testing (Grunt): Add
uglify
to grunt watch task -
Testing (Grunt): Allow use of own sauce access key
-
Testing (Grunt): Add task to avoid Saucelabs when running PhantomJS
-
Testing (Grunt): Add assorted testing tasks
-
Testing (Grunt): Update grunt-node-qunit to support latest QUnit
-
Testing (Grunt): Get Saucelabs working (for Chrome and most of Firefox)
-
Testing (Grunt): Log Saucelabs results
-
Testing (Grunt): Work toward fixing source maps
-
Testing (Grunt): Avoid missing grunt-cli message
-
Testing (PhantomJS): Deal with PhantomJS error
-
Testing (npm): Streamline test names; add convenience scripts
-
Testing (QUnit): Upgrade QUnit refs
-
Testing (QUnit): Minimize chances for QUnit random integer failure
-
Testing (QUnit): Allow QUnit tests to pass when "Check for globals" enabled (put certain test code blocks in closures)
-
Testing (QUnit): Separate out QUnit for sake of choosing between browser or Node testing, supporting node-qunit for Node testing
-
Testing (QUnit): Upgrade to QUnit 2.0 API, lint test files
-
Testing (QUnit): Add local copies of QUnit files
-
Testing (QUnit): Allow
noanalytics=true
string in QUnit URL (slows down testing in China where Google is blocked) -
Testing (Mocha): Conditionally check for
indexedDB.modules
in case we are running tests without shim -
Testing improvement: Shim
Event
in Unicode test for parity (even if not needed in current tests) -
Testing (Mocha): Add missing
IDBKeyRange/includes-spec.js
to browser tests -
Testing (Mocha): Add Mocha tests to Grunt (along with clean-up) and add node-qunit for Node mocha testing
-
Testing (Mocha): Allow passing in specific test files to mocha tests
-
Testing (Mocha): Add test to ensure unique index checks are safely ignored with bad index keys
-
Testing (Mocha): Rename test sets for distinguishing
-
Testing (Mocha): Change fakeIndexedDB and indexedDBmock to Mocha tests
-
Testing (Mocha): Increase default Mocha timeout to 5000ms (Chrome failing some at 2000ms as was Node occasionally); tweak as needed
-
Testing (Mocha): Safari currently problematic with (old) Sinon code; avoid on error checks for Safari too
-
Testing (Mocha): Fall back to genuine
Event
/DOMException
when shims not present (if testing native) -
Testing (Cordova): Update Cordova testing (untested)