blob: 2751163509ee6f5c05b643dc353f757cf87935eb [file] [log] [blame]
/**
* @license
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import '../../../test/common-test-setup-karma';
import './gr-label-scores';
import {isHidden, queryAndAssert, stubRestApi} from '../../../test/test-utils';
import {GrLabelScores} from './gr-label-scores';
import {AccountId} from '../../../types/common';
import {GrLabelScoreRow} from '../gr-label-score-row/gr-label-score-row';
import {
createAccountWithId,
createChange,
} from '../../../test/test-data-generators';
import {ChangeStatus} from '../../../constants/constants';
import {getVoteForAccount} from '../../../utils/label-util';
const basicFixture = fixtureFromElement('gr-label-scores');
suite('gr-label-scores tests', () => {
const accountId = 123 as AccountId;
let element: GrLabelScores;
setup(async () => {
stubRestApi('getLoggedIn').resolves(false);
element = basicFixture.instantiate();
element.change = {
...createChange(),
labels: {
'Code-Review': {
values: {
'0': 'No score',
'+1': 'good',
'+2': 'excellent',
'-1': 'bad',
'-2': 'terrible',
},
default_value: 0,
value: 1,
all: [
{
_account_id: accountId,
value: 1,
},
],
},
Verified: {
values: {
'0': 'No score',
'+1': 'good',
'+2': 'excellent',
'-1': 'bad',
'-2': 'terrible',
},
default_value: 0,
value: 1,
all: [
{
_account_id: accountId,
value: 1,
},
],
},
},
};
element.account = createAccountWithId(accountId);
element.permittedLabels = {
'Code-Review': ['-2', '-1', ' 0', '+1', '+2'],
Verified: ['-1', ' 0', '+1'],
};
await element.updateComplete;
});
test('get and set label scores', async () => {
for (const label of Object.keys(element.permittedLabels!)) {
const row = queryAndAssert<GrLabelScoreRow>(
element,
'gr-label-score-row[name="' + label + '"]'
);
row.setSelectedValue('-1');
}
await element.updateComplete;
assert.deepEqual(element.getLabelValues(), {
'Code-Review': -1,
Verified: -1,
});
});
test('getLabelValues includeDefaults', async () => {
element.change = {
...createChange(),
labels: {
'Code-Review': {
values: {'0': 'meh', '+1': 'good', '-1': 'bad'},
default_value: 0,
},
},
};
await element.updateComplete;
assert.deepEqual(element.getLabelValues(true), {'Code-Review': 0});
assert.deepEqual(element.getLabelValues(false), {});
});
test('getVoteForAccount', () => {
const labelName = 'Code-Review';
assert.strictEqual(
getVoteForAccount(labelName, element.account, element.change),
'+1'
);
});
suite('message', () => {
test('shown when change is abandoned', async () => {
element.change = {
...createChange(),
status: ChangeStatus.ABANDONED,
};
await flush();
assert.isFalse(isHidden(queryAndAssert(element, '.abandonedMessage')));
assert.isTrue(isHidden(queryAndAssert(element, '.mergedMessage')));
});
test('shown when change is merged', async () => {
element.change = {
...createChange(),
status: ChangeStatus.MERGED,
};
await flush();
assert.isFalse(isHidden(queryAndAssert(element, '.mergedMessage')));
assert.isTrue(isHidden(queryAndAssert(element, '.abandonedMessage')));
});
test('do not show for new', async () => {
element.change = {
...createChange(),
status: ChangeStatus.NEW,
};
await flush();
assert.isTrue(isHidden(queryAndAssert(element, '.mergedMessage')));
assert.isTrue(isHidden(queryAndAssert(element, '.abandonedMessage')));
});
});
});