ember.js 当观察ember数据记录时,点击后集成测试未呈现

6tdlim6h  于 2022-11-05  发布在  其他
关注(0)|答案(1)|浏览(150)

我似乎不明白为什么一个非常简单的集成测试没有通过
给定一个ember数据模型setting.js

export default class SettingModel extends Model {
  @attr('string') name;
  @attr('number') value;
}

我正在使用组件渲染此模型

<MyComponent @setting={{setting}}
             @name={{setting.name}}
             @value={{setting.value}}
             @values={{array 0 1 2}}
             @saveSetting={{saveSetting}} />

该组件呈现所有可能的值(@values),并对等于当前值的值应用active

{{#each @values as |value|}}
  <div class="btn {{if (eq @value value) "active"}}" {{on "click" (fn @saveSetting @setting value)}}>
    {{value}}
  </div>
{{/each}}

我想写一个简单的测试,单击另一个按钮更新活动类,但是最后一个Assert总是失败,活动类永远不会更新。

test('updates new saved value', async function(assert) {
    this.server.get('/settings/:id', () => ({ settings: { id: 1, name: "settingName", value: 1 }}), 200);
    let setting = await this.owner.lookup('service:store').findRecord('setting', 1);
    this.set('setting', setting);
    this.set('name', setting.get('name'));
    this.set('value', setting.get('value'));
    this.set('values', [0, 1, 2]);
    this.set('saveSettingFn', (setting, newValue) => {
      setting.set('value', newValue);
      setting.save().then(() => console.log('also saved!'));
      console.log('saved!');
    });

    await render(hbs`<MyComponent @setting={{this.setting}}
                                  @name={{this.name}}
                                  @value={{this.value}}
                                  @values={{this.values}}
                                  @saveSetting={{this.saveSettingFn}} />`);

    // middle option active
    assert.ok(this.element.querySelectorAll('.btn')[1].getAttribute('class').includes('active'), 'second button active');
    // set up save handler
    this.server.put('/settings/:id', () => ({ settings: { id: 1, name: "settingName", value: 1 }}), 200);
    // click the first button
    await click('.btn');
    // first option active
    assert.ok(this.element.querySelectorAll('.btn')[0].getAttribute('class').includes('active'), 'first button active');

我在这里创建了一个测试失败的示例项目https://github.com/spicalous/component-test-example/blob/master/tests/integration/components/my-component-test.js#L55
1.看起来模型上的值已保存
1.我已尝试使用waitFor测试助手
1.我试过await settled();
任何帮助都是感激不尽的!谢谢!

yx2lnoni

yx2lnoni1#

你的saveSettingFn函数什么都不做。所以什么都没有发生。

相关问题