diff --git a/test/async.spec.ts b/test/async.spec.ts index 374a09d4..79bb442d 100644 --- a/test/async.spec.ts +++ b/test/async.spec.ts @@ -3,7 +3,9 @@ import * as Eta from '../src/index' import { buildRegEx } from './err.spec' -function resolveAfter2Seconds(val: string): Promise { +type AsyncTimes = {time: number, type: "start" | "end"}[] + +function resolveAfter20Milliseconds(val: string): Promise { return new Promise((resolve) => { setTimeout(() => { resolve(val) @@ -11,8 +13,20 @@ function resolveAfter2Seconds(val: string): Promise { }) } +function createWaitAndStoreTimes(val: string, times: AsyncTimes): () => Promise { + return () => new Promise((resolve) => { + times.push({time: Date.now(), type: 'start'}); + setTimeout(() => { + resolve(val) + }, 200) + }).then(x => { + times.push({time: Date.now(), type: 'end'}); + return x; + }) +} + async function asyncTest() { - const result = await resolveAfter2Seconds('HI FROM ASYNC') + const result = await resolveAfter20Milliseconds('HI FROM ASYNC') return result } @@ -56,6 +70,59 @@ if(cb){cb(null,tR)} return tR ) }) + it('does not await code in eval tags with globalAwait option', async () => { + expect( + await Eta.render('Hi <% if (it.name) { %>0<% } %>', { name: Promise.resolve(false) }, { async: true, globalAwait: true }) + ).toEqual('Hi 0') + }) + + it('automatically awaits promises with the globalAwait option', async () => { + expect( + await Eta.render('Hi <%= it.name %>', { name: Promise.resolve('Ada Lovelace') }, { async: true, globalAwait: true }) + ).toEqual('Hi Ada Lovelace') + }) + + it('globalAwait option works with an empty interpolation tag', async () => { + expect( + await Eta.render('Hi <%=%>', { }, { async: true, globalAwait: true }) + ).toEqual('Hi undefined') + }) + + it('awaits all promises in parallel with the globalAwait option (escaped)', async () => { + const times: AsyncTimes = []; + const wait = createWaitAndStoreTimes('hello', times) + const result = await Eta.render('Hi <%= it.wait() %> <%= it.wait() %> <%= it.wait() %>', { wait }, { async: true, globalAwait: true }) + expect(result).toEqual('Hi hello hello hello') + times.sort((t1, t2) => t1.time < t2.time ? -1 : t1.time > t2.time ? 1 : 0) + expect(times.map(t => t.type).join(',')).toBe('start,start,start,end,end,end') + }) + + it('awaits all promises in sequence without the globalAwait option (escaped)', async () => { + const times: AsyncTimes = []; + const wait = createWaitAndStoreTimes('hello', times) + const result = await Eta.render('Hi <%= await it.wait() %> <%= await it.wait() %> <%= await it.wait() %>', { wait }, { async: true, globalAwait: false }) + expect(result).toEqual('Hi hello hello hello') + times.sort((t1, t2) => t1.time < t2.time ? -1 : t1.time > t2.time ? 1 : 0) + expect(times.map(t => t.type).join(',')).toBe('start,end,start,end,start,end') + }) + + it('awaits all promises in parallel with the globalAwait option (raw)', async () => { + const times: AsyncTimes = []; + const wait = createWaitAndStoreTimes('hello', times) + const result = await Eta.render('Hi <%~ it.wait() %> <%~ it.wait() %> <%~ it.wait() %>', { wait }, { async: true, globalAwait: true }) + expect(result).toEqual('Hi hello hello hello') + times.sort((t1, t2) => t1.time < t2.time ? -1 : t1.time > t2.time ? 1 : 0) + expect(times.map(t => t.type).join(',')).toBe('start,start,start,end,end,end') + }) + + it('awaits all promises in sequence without the globalAwait option (raw)', async () => { + const times: AsyncTimes = []; + const wait = createWaitAndStoreTimes('hello', times) + const result = await Eta.render('Hi <%~ await it.wait() %> <%~ await it.wait() %> <%~ await it.wait() %>', { wait }, { async: true, globalAwait: false }) + expect(result).toEqual('Hi hello hello hello') + times.sort((t1, t2) => t1.time < t2.time ? -1 : t1.time > t2.time ? 1 : 0) + expect(times.map(t => t.type).join(',')).toBe('start,end,start,end,start,end') + }) it('Async template w/ syntax error passes error to callback', (done) => { function cb(err: Error | null, _res?: string) { expect(err).toBeTruthy() diff --git a/test/render.spec.ts b/test/render.spec.ts index 08e2da2d..04fa04d4 100644 --- a/test/render.spec.ts +++ b/test/render.spec.ts @@ -14,6 +14,9 @@ describe('Simple Render checks', () => { 'Hi Ada Lovelace!' ) }) + it('Empty interpolation tag works', () => { + expect(render(compile('Hi <%=%>'), {})).toEqual('Hi undefined') + }) it('Rendering function works', () => { expect(render(compile('Hi \n<%- =it.name_%> !'), { name: 'Ada Lovelace' })).toEqual( 'Hi Ada Lovelace!'