2

我无法弄清楚如何为涉及观察者的一些方法编写单元测试。我有一个像这样设置的 Iron-pages 元素

<iron-pages>
    selected="[[page]]"
    attr-for-selected="name"
    fallback-selection="manhattan-transit-view404"
    role="main">
    <manhattan-transit-home name="home"></manhattan-transit-home>
    <manhattan-transit-map name="map"></manhattan-transit-map>
    <manhattan-transit-route name="route"></manhattan-transit-route>
    <manhattan-transit-report name="report"></manhattan-transit-report>
    <manhattan-transit-view404 name="view404"></manhattan-transit-view404>
</iron-pages>

它包含通过单击其受尊重的按钮可访问的网页名称,以允许用户更改网页。在脚本节点中有一个像这样设置的观察者

properties: {
    page: {
      type: String,
      reflectToAttribute: true,
      observer: '_pageChanged'
    }
  },

  observers: [
    '_routePageChanged(routeData.page)'
  ],

  _routePageChanged: function(page) {
    this.page = page || 'home';
  },

  _pageChanged: function(page) {
    // Load page import on demand. Show 404 page if fails
    var resolvedPageUrl = this.resolveUrl('manhattan-transit-' + page + '.html');
    this.importHref(resolvedPageUrl, null, this._showPage404, true);
  },

  _showPage404: function() {
    this.page = 'view404';
  }

我是测试新手,我想我需要测试 _routePageChanged、_pageChanged 和 _show404 函数,但不知道如何测试这些函数。我知道我需要确保页面根据点击的信息正确切换,我可能想要模拟各种点击,但为了测试,但不知道如何去做。

4

0 回答 0