blob: 4e2eb3143b873c518d5dd94bddfa5814d42a27a9 [file] [log] [blame]
/**
* @license
* Copyright 2022 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import {html, LitElement} from 'lit';
import {customElement, state} from 'lit/decorators.js';
import {define, resolve} from './dependency';
import '../test/common-test-setup-karma';
import {fixture, assert} from '@open-wc/testing';
import {DIProviderElement, wrapInProvider} from './di-provider-element';
import {BehaviorSubject} from 'rxjs';
import {waitUntilObserved} from '../test/test-utils';
import {subscribe} from '../elements/lit/subscription-controller';
const modelToken = define<BehaviorSubject<string>>('token');
/**
* This is an example element-under-test. It is expecting a model injected
* using a token, and then always displaying the value from that model.
*/
@customElement('consumer-element')
class ConsumerElement extends LitElement {
readonly getModel = resolve(this, modelToken);
@state()
private injectedValue = '';
constructor() {
super();
subscribe(
this,
() => this.getModel(),
value => (this.injectedValue = value)
);
}
override render() {
return html`<div>${this.injectedValue}</div>`;
}
}
suite('di-provider-element', () => {
let injectedModel: BehaviorSubject<string>;
let element: ConsumerElement;
setup(async () => {
// The injected value and fixture are created inside `setup` to prevent
// tests from leaking into each other.
injectedModel = new BehaviorSubject('foo');
element = (
await fixture<DIProviderElement>(
wrapInProvider(
html`<consumer-element></consumer-element>`,
modelToken,
injectedModel
)
)
).element as ConsumerElement;
});
test('provides values to the wrapped element', () => {
assert.shadowDom.equal(element, '<div>foo</div>');
});
test('enables the test to control the injected dependency', async () => {
injectedModel.next('bar');
await waitUntilObserved(injectedModel, value => value === 'bar');
assert.shadowDom.equal(element, '<div>bar</div>');
});
});