| Index: third_party/WebKit/LayoutTests/storage/indexeddb/rename-object-store-abort.html
|
| diff --git a/third_party/WebKit/LayoutTests/storage/indexeddb/rename-object-store-abort.html b/third_party/WebKit/LayoutTests/storage/indexeddb/rename-object-store-abort.html
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..67d85450a393cad2479256e1f24a8d57a9012aa5
|
| --- /dev/null
|
| +++ b/third_party/WebKit/LayoutTests/storage/indexeddb/rename-object-store-abort.html
|
| @@ -0,0 +1,120 @@
|
| +<!DOCTYPE html>
|
| +<title>IndexedDB: object store renaming support in aborted transactions</title>
|
| +<script src='../../resources/testharness.js'></script>
|
| +<link rel="help"
|
| + href="https://w3c.github.io/IndexedDB/#dom-idbobjectstore-name">
|
| +<link rel="author" href="pwnall@chromium.org" title="Victor Costan">
|
| +<script src='../../resources/testharnessreport.js'></script>
|
| +<script src='resources/rename-common.js'></script>
|
| +<script>
|
| +
|
| +promise_test(testCase => {
|
| + const dbName = databaseName(testCase);
|
| + let bookStore = null, bookStore2 = null;
|
| + return createDatabase(testCase, (database, transaction) => {
|
| + createBooksStore(testCase, database);
|
| + }).then(database => {
|
| + database.close();
|
| + }).then(() => migrateDatabase(testCase, 2, (database, transaction) => {
|
| + bookStore = transaction.objectStore('books');
|
| + bookStore.name = 'renamed_books';
|
| +
|
| + transaction.abort();
|
| +
|
| + assert_equals(
|
| + bookStore.name, 'books',
|
| + 'IDBObjectStore.name should not reflect the rename any more ' +
|
| + 'immediately after transaction.abort() returns');
|
| + assert_array_equals(
|
| + database.objectStoreNames, ['books'],
|
| + 'IDBDatabase.objectStoreNames should not reflect the rename ' +
|
| + 'any more immediately after transaction.abort() returns');
|
| + assert_array_equals(
|
| + transaction.objectStoreNames, ['books'],
|
| + 'IDBTransaction.objectStoreNames should not reflect the ' +
|
| + 'rename any more immediately after transaction.abort() returns');
|
| + })).then(event => {
|
| + assert_equals(bookStore.name, 'books',
|
| + 'IDBObjectStore.name should not reflect the rename any more ' +
|
| + 'after the versionchange transaction is aborted');
|
| + const request = indexedDB.open(dbName, 1);
|
| + return requestWatcher(testCase, request).wait_for('success');
|
| + }).then(event => {
|
| + const database = event.target.result;
|
| + assert_array_equals(
|
| + database.objectStoreNames, ['books'],
|
| + 'IDBDatabase.objectStoreNames should not reflect the rename ' +
|
| + 'after the versionchange transaction is aborted');
|
| +
|
| + const transaction = database.transaction('books', 'readonly');
|
| + bookStore2 = transaction.objectStore('books');
|
| + return checkStoreContents(
|
| + testCase, bookStore2,
|
| + 'Aborting an object store rename transaction should not change ' +
|
| + "the store's records").then(() => database.close());
|
| + }).then(() => {
|
| + assert_equals(
|
| + bookStore.name, 'books',
|
| + 'IDBObjectStore used in aborted rename transaction should not ' +
|
| + 'reflect the rename after the transaction is aborted');
|
| + assert_equals(
|
| + bookStore2.name, 'books',
|
| + 'IDBObjectStore obtained after an aborted rename transaction ' +
|
| + 'should not reflect the rename');
|
| + });
|
| +}, 'IndexedDB object store rename in aborted transaction');
|
| +
|
| +promise_test(testCase => {
|
| + const dbName = databaseName(testCase);
|
| + let notBookStore = null;
|
| + return createDatabase(testCase, (database, transaction) => {
|
| + }).then(database => {
|
| + database.close();
|
| + }).then(() => migrateDatabase(testCase, 2, (database, transaction) => {
|
| + notBookStore = createNotBooksStore(testCase, database);
|
| + notBookStore.name = 'not_books_renamed';
|
| + notBookStore.name = 'not_books_renamed_again';
|
| +
|
| + transaction.abort();
|
| +
|
| + assert_equals(
|
| + notBookStore.name, 'not_books_renamed_again',
|
| + 'IDBObjectStore.name should reflect the last rename ' +
|
| + 'immediately after transaction.abort() returns');
|
| + assert_array_equals(
|
| + database.objectStoreNames, [],
|
| + 'IDBDatabase.objectStoreNames should not reflect the creation ' +
|
| + 'or the rename any more immediately after transaction.abort() ' +
|
| + 'returns');
|
| + assert_array_equals(
|
| + transaction.objectStoreNames, [],
|
| + 'IDBTransaction.objectStoreNames should not reflect the ' +
|
| + 'creation or the rename any more immediately after ' +
|
| + 'transaction.abort() returns');
|
| + assert_array_equals(notBookStore.indexNames, [],
|
| + 'IDBObjectStore.indexNames for the newly created store ' +
|
| + 'should be empty immediately after transaction.abort() ' +
|
| + 'returns');
|
| + })).then(event => {
|
| + assert_equals(
|
| + notBookStore.name, 'not_books_renamed_again',
|
| + 'IDBObjectStore.name should reflect the last rename after the ' +
|
| + 'versionchange transaction is aborted');
|
| + assert_array_equals(notBookStore.indexNames, [],
|
| + 'IDBObjectStore.indexNames for the newly created store ' +
|
| + 'should be empty after the versionchange transaction is aborted ' +
|
| + 'returns');
|
| + const request = indexedDB.open(dbName, 1);
|
| + return requestWatcher(testCase, request).wait_for('success');
|
| + }).then(event => {
|
| + const database = event.target.result;
|
| + assert_array_equals(
|
| + database.objectStoreNames, [],
|
| + 'IDBDatabase.objectStoreNames should not reflect the creation or ' +
|
| + 'the rename after the versionchange transaction is aborted');
|
| +
|
| + database.close();
|
| + });
|
| +}, 'IndexedDB object store creation and rename in an aborted transaction');
|
| +
|
| +</script>
|
|
|