summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/IndexedDB/idbobjectstore-rename-abort.html
blob: b4bfc914ed7671c5b53dadcaf9cc248c6e33ff9f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<!doctype html>
<meta charset="utf8">
<title>IndexedDB: object store renaming support in aborted transactions</title>
<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/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/support-promises.js"></script>
<script>
'use strict';

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 promiseForRequest(testCase, request);
    }).then(database => {
        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', {durability: 'relaxed'});
        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 promiseForRequest(testCase, request);
    }).then(database => {
        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>