diff --git a/src/node_sqlite.cc b/src/node_sqlite.cc index 4b347dbbe2a59e..fc0d1b168d891f 100644 --- a/src/node_sqlite.cc +++ b/src/node_sqlite.cc @@ -330,7 +330,7 @@ void DatabaseSync::ApplyChangeset(const FunctionCallbackInfo& args) { if (!args[1]->IsObject()) { node::THROW_ERR_INVALID_ARG_TYPE( env->isolate(), - "The second argument, if provided, must be an options object."); + "The \"options\" argument must be an object."); return; } diff --git a/test/parallel/test-sqlite.js b/test/parallel/test-sqlite.js index 8d0bbaa44e4ff1..c3f695940311a2 100644 --- a/test/parallel/test-sqlite.js +++ b/test/parallel/test-sqlite.js @@ -831,18 +831,6 @@ suite('session extension', () => { }); }); - test('set table with wrong type when creating session', (t) => { - const database = new DatabaseSync(':memory:'); - t.assert.throws(() => { - database.createSession({ - table: true - }); - }, { - name: 'TypeError', - message: 'The "options.table" argument must be a string.' - }); - }); - test('setting options.table causes only one table to be tracked', (t) => { const database1 = new DatabaseSync(':memory:'); const database2 = new DatabaseSync(':memory:'); @@ -974,9 +962,9 @@ suite('session extension', () => { const data1Rows = database2.prepare('SELECT * FROM data1').all(); const data2Rows = database2.prepare('SELECT * FROM data2').all(); - // Expect no rows since all changes where filtered out + // Expect no rows since all changes were filtered out t.assert.strictEqual(data1Rows.length, 0); - // Expect 5 rows since these changes where not filtered out + // Expect 5 rows since these changes were not filtered out t.assert.strictEqual(data2Rows.length, 5); }); @@ -997,8 +985,24 @@ suite('session extension', () => { t.assert.strictEqual(sessionTest.changeset().length, 0); }); - test('wrong argument name of other database', (t) => { + test('wrong arguments database.createSession()', (t) => { const database = new DatabaseSync(':memory:'); + t.assert.throws(() => { + database.createSession(null); + }, { + name: 'TypeError', + message: 'The "options" argument must be an object.' + }); + + t.assert.throws(() => { + database.createSession({ + table: 123 + }); + }, { + name: 'TypeError', + message: 'The "options.table" argument must be a string.' + }); + t.assert.throws(() => { database.createSession({ db: 123 @@ -1009,6 +1013,42 @@ suite('session extension', () => { }); }); + test('wrong arguments database.applyChangeset()', (t) => { + const database = new DatabaseSync(':memory:'); + const session = database.createSession(); + t.assert.throws(() => { + database.applyChangeset(null); + }, { + name: 'TypeError', + message: 'The "changeset" argument must be a Uint8Array.' + }); + + t.assert.throws(() => { + database.applyChangeset(session.changeset(), null); + }, { + name: 'TypeError', + message: 'The "options" argument must be an object.' + }); + + t.assert.throws(() => { + database.applyChangeset(session.changeset(), { + filter: null + }, null); + }, { + name: 'TypeError', + message: 'The "options.filter" argument must be a function.' + }); + + t.assert.throws(() => { + database.applyChangeset(session.changeset(), { + onConflict: null + }, null); + }, { + name: 'TypeError', + message: 'The "options.onConflict" argument must be an number.' + }); + }); + test('generate patchset', (t) => { const database = new DatabaseSync(':memory:'); database.exec('CREATE TABLE data(key INTEGER PRIMARY KEY, value TEXT)');