blob: 6da91be29e34d88a50c4d946dd4639aca5b8cd20 [file] [log] [blame]
/**
* @license
* Copyright 2022 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import '../../../test/common-test-setup';
import {fixture, assert} from '@open-wc/testing';
import {html} from 'lit';
import './gr-change-list-column-requirements-summary';
import {GrChangeListColumnRequirementsSummary} from './gr-change-list-column-requirements-summary';
import {
createApproval,
createDetailedLabelInfo,
createParsedChange,
createSubmitRequirementExpressionInfo,
createSubmitRequirementResultInfo,
createNonApplicableSubmitRequirementResultInfo,
} from '../../../test/test-data-generators';
import {
SubmitRequirementResultInfo,
SubmitRequirementStatus,
} from '../../../api/rest-api';
import {ParsedChangeInfo} from '../../../types/types';
suite('gr-change-list-column-requirements-summary tests', () => {
let element: GrChangeListColumnRequirementsSummary;
let change: ParsedChangeInfo;
setup(() => {
const submitRequirement: SubmitRequirementResultInfo = {
...createSubmitRequirementResultInfo(),
status: SubmitRequirementStatus.UNSATISFIED,
description: 'Test Description',
submittability_expression_result: createSubmitRequirementExpressionInfo(),
};
change = {
...createParsedChange(),
submit_requirements: [
submitRequirement,
createNonApplicableSubmitRequirementResultInfo(),
],
labels: {
Verified: {
...createDetailedLabelInfo(),
all: [
{
...createApproval(),
value: 2,
},
],
},
},
};
});
test('renders', async () => {
element = await fixture<GrChangeListColumnRequirementsSummary>(
html`<gr-change-list-column-requirements-summary .change=${change}>
</gr-change-list-column-requirements-summary>`
);
assert.shadowDom.equal(
element,
/* HTML */ ` <span class="block" role="button" tabindex="0">
<gr-submit-requirement-dashboard-hovercard>
</gr-submit-requirement-dashboard-hovercard>
<gr-icon class="block" role="img" icon="block"></gr-icon>
<span class="unsatisfied">1 missing</span>
</span>`
);
});
test('renders comment count', async () => {
change = {
...change,
unresolved_comment_count: 5,
};
element = await fixture<GrChangeListColumnRequirementsSummary>(
html`<gr-change-list-column-requirements-summary .change=${change}>
</gr-change-list-column-requirements-summary>`
);
assert.shadowDom.equal(
element,
/* HTML */ ` <span class="block" role="button" tabindex="0">
<gr-submit-requirement-dashboard-hovercard>
</gr-submit-requirement-dashboard-hovercard>
<gr-icon class="block" role="img" icon="block"></gr-icon>
<span class="unsatisfied">1 missing</span>
</span>
<gr-icon
class="commentIcon"
small
filled
icon="chat_bubble"
title="5 unresolved comments"
></gr-icon>`
);
});
});