sql_builder.test.js 803 B

1234567891011121314151617181920212223242526272829
  1. /**
  2. * sql拼接器单元测试
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/10/20
  6. * @version
  7. */
  8. 'use strict';
  9. const { app, assert } = require('egg-mock/bootstrap');
  10. const SqlBuilder = require('../../../app/lib/sql_builder');
  11. describe('test/app/lib/sql_builder.test.js', () => {
  12. it('set normal sql', function* () {
  13. const sqlBuilder = new SqlBuilder();
  14. sqlBuilder.columns = ['id'];
  15. sqlBuilder.limit = 10;
  16. sqlBuilder.offset = 1;
  17. sqlBuilder.orderBy = [['id', 'DESC']];
  18. const [sql, param] = sqlBuilder.build('table');
  19. const finalSql = app.mysql.format(sql, param);
  20. // 最后组合后应该获得的数据
  21. const matchSql = 'SELECT `id` FROM `table` LIMIT 1,10 ORDER BY `id` DESC';
  22. assert(finalSql === matchSql);
  23. });
  24. });