Charlie Tran 843a6c5bbb
feat(frontend): update datahub-web client UI code (#1806)
* Releases updated version of datahub-web client UI code

* Fix typo in yarn lock

* Change yarn lock to match yarn registry directories

* Previous commit missed some paths

* Even more changes to yarnlock missing in previous commit

* Include codegen file for typings

* Add files to get parity for datahub-web and current OS datahub-midtier

* Add in typo fix from previous commit - change to proper license

* Implement proper OS fix for person entity picture url

* Workarounds for open source DH issues

* Fixes institutional memory api and removes unopensourced tabs for datasets

* Fixes search dataset deprecation and user search issue as a result of changes

* Remove internal only options in the avatar menu
2020-08-26 15:44:50 -07:00

47 lines
2.0 KiB
TypeScript

import { module, test } from 'qunit';
import { setupRenderingTest } from 'ember-qunit';
import hbs from 'htmlbars-inline-precompile';
import { getRenderedComponent } from '@datahub/utils/test-helpers/register-component';
import AvatarMainContainer from '@datahub/shared/components/avatar/containers/avatar-main';
import { Avatar } from '@datahub/shared/modules/avatars/avatar';
import { PersonEntity } from '@datahub/data-models/entity/person/person-entity';
module('Integration | Component | avatar/containers/avatar-main', function(hooks) {
setupRenderingTest(hooks);
const sampleUrn = 'urn:li:corpuser:pikachu';
test('it works as expected with a urn', async function(assert) {
this.set('urn', sampleUrn);
const component = await getRenderedComponent({
componentName: 'avatar/containers/avatar-main',
ComponentToRender: AvatarMainContainer,
testContext: this,
template: hbs`<Avatar::Containers::AvatarMain @urn={{this.urn}} />`
});
assert.equal(component.urns[0], sampleUrn, 'Gets urns correctly when given urn');
assert.equal(component.avatars?.length, 1, 'Gives the correct number of avatars');
const firstAvatar = (component.avatars as Array<Avatar>)[0];
assert.ok(firstAvatar instanceof Avatar, 'Creates an expected avatar instance');
assert.equal(firstAvatar.urn, sampleUrn);
});
test('it works as expected with an entity', async function(assert) {
const sampleEntity = new PersonEntity(sampleUrn);
this.set('entity', sampleEntity);
const secondComponent = await getRenderedComponent({
componentName: 'avatar/containers/avatar-main',
ComponentToRender: AvatarMainContainer,
testContext: this,
template: hbs`<Avatar::Containers::AvatarMain @entity={{this.entity}} />`
});
const secondAvatar = (secondComponent.avatars as Array<Avatar>)[0];
assert.ok(secondAvatar instanceof Avatar, 'Creates an expected avatar instance when given an entity');
assert.equal(secondAvatar.urn, sampleUrn, 'Given avatar from entity correctly reads underlying entity');
});
});