|  | <!DOCTYPE html> | 
|  | <!-- | 
|  | @license | 
|  | Copyright (C) 2016 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. | 
|  | --> | 
|  |  | 
|  | <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes"> | 
|  | <meta charset="utf-8"> | 
|  | <title>gr-settings-view</title> | 
|  |  | 
|  | <script src="/node_modules/@webcomponents/webcomponentsjs/custom-elements-es5-adapter.js"></script> | 
|  |  | 
|  | <script src="/node_modules/@webcomponents/webcomponentsjs/webcomponents-lite.js"></script> | 
|  | <script src="/components/wct-browser-legacy/browser.js"></script> | 
|  |  | 
|  | <test-fixture id="basic"> | 
|  | <template> | 
|  | <gr-group-list></gr-group-list> | 
|  | </template> | 
|  | </test-fixture> | 
|  |  | 
|  | <script type="module"> | 
|  | import '../../../test/common-test-setup.js'; | 
|  | import './gr-group-list.js'; | 
|  | import {dom} from '@polymer/polymer/lib/legacy/polymer.dom.js'; | 
|  | import {GerritNav} from '../../core/gr-navigation/gr-navigation.js'; | 
|  |  | 
|  | suite('gr-group-list tests', () => { | 
|  | let sandbox; | 
|  | let element; | 
|  | let groups; | 
|  |  | 
|  | setup(done => { | 
|  | sandbox = sinon.sandbox.create(); | 
|  | groups = [{ | 
|  | url: 'some url', | 
|  | options: {}, | 
|  | description: 'Group 1 description', | 
|  | group_id: 1, | 
|  | owner: 'Administrators', | 
|  | owner_id: '123', | 
|  | id: 'abc', | 
|  | name: 'Group 1', | 
|  | }, { | 
|  | options: {visible_to_all: true}, | 
|  | id: '456', | 
|  | name: 'Group 2', | 
|  | }, { | 
|  | options: {}, | 
|  | id: '789', | 
|  | name: 'Group 3', | 
|  | }]; | 
|  |  | 
|  | stub('gr-rest-api-interface', { | 
|  | getAccountGroups() { return Promise.resolve(groups); }, | 
|  | }); | 
|  |  | 
|  | element = fixture('basic'); | 
|  |  | 
|  | element.loadData().then(() => { flush(done); }); | 
|  | }); | 
|  |  | 
|  | teardown(() => { sandbox.restore(); }); | 
|  |  | 
|  | test('renders', () => { | 
|  | const rows = Array.from( | 
|  | dom(element.root).querySelectorAll('tbody tr')); | 
|  |  | 
|  | assert.equal(rows.length, 3); | 
|  |  | 
|  | const nameCells = rows.map(row => | 
|  | row.querySelectorAll('td a')[0].textContent.trim() | 
|  | ); | 
|  |  | 
|  | assert.equal(nameCells[0], 'Group 1'); | 
|  | assert.equal(nameCells[1], 'Group 2'); | 
|  | assert.equal(nameCells[2], 'Group 3'); | 
|  | }); | 
|  |  | 
|  | test('_computeVisibleToAll', () => { | 
|  | assert.equal(element._computeVisibleToAll(groups[0]), 'No'); | 
|  | assert.equal(element._computeVisibleToAll(groups[1]), 'Yes'); | 
|  | }); | 
|  |  | 
|  | test('_computeGroupPath', () => { | 
|  | sandbox.stub(GerritNav, 'getUrlForGroup', | 
|  | () => '/admin/groups/e2cd66f88a2db4d391ac068a92d987effbe872f5'); | 
|  |  | 
|  | let group = { | 
|  | id: 'e2cd66f88a2db4d391ac068a92d987effbe872f5', | 
|  | }; | 
|  |  | 
|  | assert.equal(element._computeGroupPath(group), | 
|  | '/admin/groups/e2cd66f88a2db4d391ac068a92d987effbe872f5'); | 
|  |  | 
|  | group = { | 
|  | name: 'admin', | 
|  | }; | 
|  |  | 
|  | assert.isUndefined(element._computeGroupPath(group)); | 
|  | }); | 
|  | }); | 
|  | </script> |