Add hooks to sql based connectors

This commit is contained in:
Raymond Feng 2015-05-22 09:03:27 -07:00
parent ceea61e93c
commit 50ac48c5f7
2 changed files with 36 additions and 2 deletions

View File

@ -397,7 +397,21 @@ SQLConnector.prototype.execute = function(sql, params, options, callback) {
self.execute(sql, params, options, callback); self.execute(sql, params, options, callback);
}); });
} }
this.executeSQL(sql, params, options, callback); var context = {
req: {
sql: sql,
params: params
},
options: options
};
this.notifyObserversAround('execute', context, function(context, done) {
self.executeSQL(sql, params, options, function(err, info, extra) {
if (!err && info != null) {
context.res = info;
}
done(err, info, extra);
});
}, callback);
}; };
/** /**

View File

@ -9,13 +9,14 @@ var ds = new juggler.DataSource({
debug: true debug: true
}); });
var connector; var connector;
var Customer;
describe('sql connector', function() { describe('sql connector', function() {
before(function() { before(function() {
connector = ds.connector; connector = ds.connector;
connector._tables = {}; connector._tables = {};
connector._models = {}; connector._models = {};
ds.createModel('customer', Customer = ds.createModel('customer',
{ {
name: { name: {
id: true, id: true,
@ -307,4 +308,23 @@ describe('sql connector', function() {
connector.execute('SELECT * FROM `CUSTOMER`', [], {}, 'xyz'); connector.execute('SELECT * FROM `CUSTOMER`', [], {}, 'xyz');
}).to.throw('callback must be a function'); }).to.throw('callback must be a function');
}); });
it('should invoke hooks', function(done) {
var events = [];
connector.observe('before execute', function(ctx, next) {
expect(ctx.req.sql).be.a('string');
expect(ctx.req.params).be.a('array');
events.push('before execute');
next();
});
connector.observe('after execute', function(ctx, next) {
expect(ctx.res).be.an('array');
events.push('after execute');
next();
});
Customer.find(function(err, results) {
expect(events).to.eql(['before execute', 'after execute']);
done(err, results);
});
});
}); });