lundi 26 janvier 2015

How can I mock a fake database for when unit testing against Knex?

I've been using Knex successfully to connect to a backend database. But I want to be able to unit test my code. Is there a way to mock the database connection?


I've tried using proxyquire but I can't seem to get it to work.


The problem seems to be with the way Knex is initialized.



var knex = require('knex')({
client: 'mysql',
connection: {}
});


I setup knex to be mocked in my unit test.



myService = proxyquire('../app/myService', {
'knex': knexProxy
});


My service includes knex.



var knex = require('knex').knex,


When my service runs a query, it fails.



var sql = knex("table_name");
sql.insert(rowToInsert, "auto_increment_id");
sql.then(function (insertId) {
resolve();
}, function (err) {
reject(err);
});


For some reason I just can't seem to capture the request before it attempts the connection.


I've also, tried to create a custom Knex Client, but that hasn't worked yet either.


Aucun commentaire:

Enregistrer un commentaire