How can globally I mock/replace components in integration tests?

332 views Asked by At

I have a component "nested" which makes a web request, and I'm using this component from another component "parent".

I'm trying to write some integration tests for "parent", but they are failing as the "nested" component's web requests are failing.

Instead of mocking out the requests, I was just hoping to mock some of the "nested" functionality to prevent the web request. This is easily achievable with reopen, but of course this will cause the tests for "nested" to fail.

Does anyone know if there is a way that I can either stub pieces of "nested", or maybe use the registry to replace "nested" with an extended class?

1

There are 1 answers

0
Matt d' On BEST ANSWER

To swap out a component, just for the purpose of a single test module, simply register a custom component to replace the original (only for the scope of the test module):

moduleForComponent('component-under-test', 'description', {
  integration: true,

  beforeEach() {
    this.container.registry.register('component:nested-component', NestedComponent.extend({
      modifiedFunction() {
      }
    }));
  }
});