diff --git a/test/utils/interceptor.spec.ts b/test/utils/interceptor.spec.ts index f2074ec36..4664854ed 100644 --- a/test/utils/interceptor.spec.ts +++ b/test/utils/interceptor.spec.ts @@ -82,4 +82,32 @@ describe.only('interceptor spec', () => { expect(x).to.equal('divided-by-zero') }) }) + + it('wrap: one-value Observable to multi-value Observable conversion', function* () { + const cache = new Map([['leo', '你好,里奥']]) + const interceptor = (options: { cacheThenRefresh: boolean }, gateFn: any, gateArgs: any[]) => { + const request$ = gateFn(...gateArgs) + if (options.cacheThenRefresh) { + const userName = gateArgs[0] + const requestAndCache = request$.do((hello: string) => cache.set(userName, hello)) + if (cache.has(userName)) { + return Observable.concat(Observable.of(cache.get(userName)), requestAndCache) + } else { + return requestAndCache + } + } else { + return request$ + } + } + const gate = (userName: string) => { + return Observable.of(`hello ${userName}`) + } + const wrapped = ix.wrap(gate, interceptor) + const intercepted = wrapped({ cacheThenRefresh: true }) + yield intercepted('leo').take(2).toArray() + .do((xs) => { + expect(xs).to.deep.equal(['你好,里奥', 'hello leo']) + expect(cache.get('leo')).to.equal('hello leo') + }) + }) })