日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Angular Observable数据类型的单元测试数据准备

發布時間:2023/12/19 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Angular Observable数据类型的单元测试数据准备 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我有一個Component,其items屬性是一個嵌套的Observable:

items$: Observable<Observable<Product>[]> = this.componentData$.pipe(map((data) => data.productCodes.trim().split(' ')),map((codes) =>codes.map((code) => this.productService.get(code, this.PRODUCT_SCOPE))));

ComponentData$的類型:

private componentData$: Observable<model> = this.componentData.data$.pipe(filter(Boolean));

Model的定義:

componentData$類型為Observable,調用map的回調里又嵌入了map操作,這是返回類型為嵌套Observable的原因。

因為items是從componentData是從componentDatacomponentData得來的,而componentData$又來自componentData,因此我只用考慮如何構造componentData測試數據就行了:

private componentData$: Observable<model> = this.componentData.data$.pipe(filter(Boolean));

下面看看如何在單元測試用例里創建mock數據:MockCmsProductCarouselComponent:

完整解決方案:

const mockComponentData: CmsProductCarouselComponent = {uid: '001',typeCode: 'ProductCarouselComponent',modifiedTime: new Date('2017-12-21T18:15:15+0000'),popup: 'false',productCodes: productCodeArray.join(' '),scroll: 'ALLVISIBLE',title: 'Mock Title',name: 'Mock Product Carousel',container: 'false', };const MockCmsProductCarouselComponent = <CmsComponentData<any>>{data$: of(mockComponentData), };

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

總結

以上是生活随笔為你收集整理的Angular Observable数据类型的单元测试数据准备的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。