| /** |
| * @license |
| * Copyright (C) 2020 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.js'; |
| import './gr-hovercard-account.js'; |
| import {html} from '@polymer/polymer/lib/utils/html-tag.js'; |
| |
| const basicFixture = fixtureFromTemplate(html` |
| <gr-hovercard-account class="hovered"></gr-hovercard-account> |
| `); |
| |
| suite('gr-hovercard-account tests', () => { |
| let element; |
| |
| const ACCOUNT = { |
| email: 'kermit@gmail.com', |
| username: 'kermit', |
| name: 'Kermit The Frog', |
| _account_id: '31415926535', |
| }; |
| |
| setup(() => { |
| element = basicFixture.instantiate(); |
| sinon.stub(element.$.restAPI, 'getAccount').returns( |
| new Promise(resolve => { '2'; }) |
| ); |
| |
| element.account = Object.assign({}, ACCOUNT); |
| element.show({}); |
| flushAsynchronousOperations(); |
| }); |
| |
| teardown(() => { |
| element.hide({}); |
| }); |
| |
| test('account name is shown', () => { |
| assert.equal(element.shadowRoot.querySelector('.name').innerText, |
| 'Kermit The Frog'); |
| }); |
| |
| test('_computeText', () => { |
| let account = {_account_id: '1'}; |
| const selfAccount = {_account_id: '1'}; |
| assert.equal(element._computeText(account, selfAccount), 'Your'); |
| account = {_account_id: '2'}; |
| assert.equal(element._computeText(account, selfAccount), 'Their'); |
| }); |
| |
| test('account status is not shown if the property is not set', () => { |
| assert.isNull(element.shadowRoot.querySelector('.status')); |
| }); |
| |
| test('account status is displayed', () => { |
| element.account = Object.assign({status: 'OOO'}, ACCOUNT); |
| flushAsynchronousOperations(); |
| assert.equal(element.shadowRoot.querySelector('.status .value').innerText, |
| 'OOO'); |
| }); |
| |
| test('voteable div is not shown if the property is not set', () => { |
| assert.isNull(element.shadowRoot.querySelector('.voteable')); |
| }); |
| |
| test('voteable div is displayed', () => { |
| element.voteableText = 'CodeReview: +2'; |
| flushAsynchronousOperations(); |
| assert.equal(element.shadowRoot.querySelector('.voteable .value').innerText, |
| element.voteableText); |
| }); |
| }); |
| |