123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- const assert = require('assert')
- const Cursor = require('../')
- const pg = require('pg')
- const text = 'SELECT generate_series as num FROM generate_series(0, 5)'
- describe('cursor using promises', function () {
- beforeEach(function (done) {
- const client = (this.client = new pg.Client())
- client.connect(done)
- this.pgCursor = function (text, values) {
- return client.query(new Cursor(text, values || []))
- }
- })
- afterEach(function () {
- this.client.end()
- })
- it('resolve with result', async function () {
- const cursor = this.pgCursor(text)
- const res = await cursor.read(6)
- assert.strictEqual(res.length, 6)
- })
- it('reject with error', function (done) {
- const cursor = this.pgCursor('select asdfasdf')
- cursor.read(1).catch((err) => {
- assert(err)
- done()
- })
- })
- it('read multiple times', async function () {
- const cursor = this.pgCursor(text)
- let res
- res = await cursor.read(2)
- assert.strictEqual(res.length, 2)
- res = await cursor.read(3)
- assert.strictEqual(res.length, 3)
- res = await cursor.read(1)
- assert.strictEqual(res.length, 1)
- res = await cursor.read(1)
- assert.strictEqual(res.length, 0)
- })
- })
|