Merge changes I433937b4,I3b1a8830

* changes:
  Enable `arrow-body-style` with as-needed
  Enable `no-confusing-arrow` and `newline-per-chained-call`
This commit is contained in:
Ben Rohlfs 2020-01-10 13:53:23 +00:00 committed by Gerrit Code Review
commit 5909ea1fed
130 changed files with 1395 additions and 1370 deletions

View File

@ -21,6 +21,9 @@
"flushAsynchronousOperations": false "flushAsynchronousOperations": false
}, },
"rules": { "rules": {
"no-confusing-arrow": "error",
"newline-per-chained-call": ["error", { "ignoreChainWithDepth": 2 }],
"arrow-body-style": ["error", "as-needed", { "requireReturnForObjectLiteral": true }],
"arrow-parens": ["error", "as-needed"], "arrow-parens": ["error", "as-needed"],
"block-spacing": ["error", "always"], "block-spacing": ["error", "always"],
"brace-style": ["error", "1tbs", { "allowSingleLine": true }], "brace-style": ["error", "1tbs", { "allowSingleLine": true }],

View File

@ -139,15 +139,17 @@ limitations under the License.
*/ */
toSortedArray(obj) { toSortedArray(obj) {
if (!obj) { return []; } if (!obj) { return []; }
return Object.keys(obj).map(key => { return Object.keys(obj)
return { .map(key => {
id: key, return {
value: obj[key], id: key,
}; value: obj[key],
}).sort((a, b) => { };
// Since IDs are strings, use localeCompare. })
return a.id.localeCompare(b.id); .sort((a, b) =>
}); // Since IDs are strings, use localeCompare.
a.id.localeCompare(b.id)
);
}, },
}; };

View File

@ -64,12 +64,11 @@ limitations under the License.
getAdminMenuLinks, opt_options)); getAdminMenuLinks, opt_options));
} }
return getAccountCapabilities() return getAccountCapabilities()
.then(capabilities => { .then(capabilities => this._filterLinks(
return this._filterLinks(link => { link => !link.capability
return !link.capability || || capabilities.hasOwnProperty(link.capability),
capabilities.hasOwnProperty(link.capability); getAdminMenuLinks,
}, getAdminMenuLinks, opt_options); opt_options));
});
}, },
/** /**
@ -92,15 +91,17 @@ limitations under the License.
const isExernalLink = link => link.url[0] !== '/'; const isExernalLink = link => link.url[0] !== '/';
// Append top-level links that are defined by plugins. // Append top-level links that are defined by plugins.
links.push(...getAdminMenuLinks().map(link => ({ links.push(...getAdminMenuLinks().map(link => {
url: link.url, return {
name: link.text, url: link.url,
capability: link.capability || null, name: link.text,
noBaseUrl: !isExernalLink(link), capability: link.capability || null,
view: null, noBaseUrl: !isExernalLink(link),
viewableToAll: !link.capability, view: null,
target: isExernalLink(link) ? '_blank' : null, viewableToAll: !link.capability,
}))); target: isExernalLink(link) ? '_blank' : null,
};
}));
links = links.filter(filterFn); links = links.filter(filterFn);

View File

@ -95,9 +95,8 @@ limitations under the License.
if (expected.pluginGeneratedLinks) { if (expected.pluginGeneratedLinks) {
for (const link of expected.pluginGeneratedLinks) { for (const link of expected.pluginGeneratedLinks) {
const linkMatch = res.links.find(l => { const linkMatch = res.links
return (l.url === link.url && l.name === link.text); .find(l => (l.url === link.url && l.name === link.text));
});
assert.isTrue(!!linkMatch); assert.isTrue(!!linkMatch);
// External links should open in new tab. // External links should open in new tab.
@ -325,7 +324,9 @@ limitations under the License.
let options; let options;
const generatedLinks = [ const generatedLinks = [
{text: 'without capability', url: '/without'}, {text: 'without capability', url: '/without'},
{text: 'with capability', url: '/with', capability: 'pluginCapability'}, {text: 'with capability',
url: '/with',
capability: 'pluginCapability'},
]; ];
menuLinkStub.returns(generatedLinks); menuLinkStub.returns(generatedLinks);
expected = Object.assign(expected, { expected = Object.assign(expected, {

View File

@ -46,9 +46,7 @@ limitations under the License.
* @return {!Array} * @return {!Array}
*/ */
getComplementColumns(columns) { getComplementColumns(columns) {
return this.columnNames.filter(column => { return this.columnNames.filter(column => !columns.includes(column));
return !columns.includes(column);
});
}, },
/** /**

View File

@ -124,9 +124,9 @@ limitations under the License.
// Map a normal patchNum to 2 * (patchNum - 1) + 1... I.e. 1 -> 1, // Map a normal patchNum to 2 * (patchNum - 1) + 1... I.e. 1 -> 1,
// 2 -> 3, 3 -> 5, etc. // 2 -> 3, 3 -> 5, etc.
// Map an edit to the patchNum of parent*2... I.e. edit on 2 -> 4. // Map an edit to the patchNum of parent*2... I.e. edit on 2 -> 4.
const num = r => r._number === Gerrit.PatchSetBehavior.EDIT_NAME ? const num = r => (r._number === Gerrit.PatchSetBehavior.EDIT_NAME ?
2 * editParent : 2 * editParent :
2 * (r._number - 1) + 1; 2 * (r._number - 1) + 1);
return revisions.sort((a, b) => num(b) - num(a)); return revisions.sort((a, b) => num(b) - num(a));
}, },
@ -150,9 +150,8 @@ limitations under the License.
if (!change) { return []; } if (!change) { return []; }
let patchNums = []; let patchNums = [];
if (change.revisions && Object.keys(change.revisions).length) { if (change.revisions && Object.keys(change.revisions).length) {
const revisions = Object.keys(change.revisions).map(sha => { const revisions = Object.keys(change.revisions)
return Object.assign({sha}, change.revisions[sha]); .map(sha => Object.assign({sha}, change.revisions[sha]));
});
patchNums = patchNums =
Gerrit.PatchSetBehavior.sortRevisions(revisions) Gerrit.PatchSetBehavior.sortRevisions(revisions)
.map(e => { .map(e => {

View File

@ -170,9 +170,7 @@ limitations under the License.
messages: [], messages: [],
work_in_progress: initialWip, work_in_progress: initialWip,
}; };
const revs = Object.keys(tagsByRevision).sort((a, b) => { const revs = Object.keys(tagsByRevision).sort((a, b) => a - b);
return a - b;
});
for (const rev of revs) { for (const rev of revs) {
for (const tag of tagsByRevision[rev]) { for (const tag of tagsByRevision[rev]) {
change.messages.push({ change.messages.push({
@ -190,9 +188,7 @@ limitations under the License.
} }
const verifier = { const verifier = {
assertWip(revision, expectedWip) { assertWip(revision, expectedWip) {
const patchNum = patchNums.find(patchNum => { const patchNum = patchNums.find(patchNum => patchNum.num == revision);
return patchNum.num == revision;
});
if (!patchNum) { if (!patchNum) {
assert.fail('revision ' + revision + ' not found'); assert.fail('revision ' + revision + ' not found');
} }

View File

@ -146,9 +146,8 @@
allPermissions = labelOptions.concat( allPermissions = labelOptions.concat(
this.toSortedArray(this.permissionValues)); this.toSortedArray(this.permissionValues));
} }
return allPermissions.filter(permission => { return allPermissions
return !this.section.value.permissions[permission.id]; .filter(permission => !this.section.value.permissions[permission.id]);
});
} }
_computeHideEditClass(section) { _computeHideEditClass(section) {
@ -248,7 +247,8 @@
_computeSectionClass(editing, canUpload, ownerOf, editingRef, deleted) { _computeSectionClass(editing, canUpload, ownerOf, editingRef, deleted) {
const classList = []; const classList = [];
if (editing && this._isEditEnabled(canUpload, ownerOf, this.section.id)) { if (editing
&& this._isEditEnabled(canUpload, ownerOf, this.section.id)) {
classList.push('editing'); classList.push('editing');
} }
if (editingRef) { if (editingRef) {

View File

@ -127,9 +127,10 @@ limitations under the License.
suite('filter', () => { suite('filter', () => {
test('_paramsChanged', done => { test('_paramsChanged', done => {
sandbox.stub(element.$.restAPI, 'getGroups', () => { sandbox.stub(
return Promise.resolve(groups); element.$.restAPI,
}); 'getGroups',
() => Promise.resolve(groups));
const value = { const value = {
filter: 'test', filter: 'test',
offset: 25, offset: 25,

View File

@ -101,13 +101,15 @@ limitations under the License.
sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({ sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({
name: 'test-user', name: 'test-user',
})); }));
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
})
);
element.reload().then(() => { element.reload().then(() => {
assert.equal(element._filteredLinks.length, 3); assert.equal(element._filteredLinks.length, 3);
@ -127,9 +129,11 @@ limitations under the License.
sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({ sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({
name: 'test-user', name: 'test-user',
})); }));
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({}); element.$.restAPI,
}); 'getAccountCapabilities',
() => Promise.resolve({})
);
element.reload().then(() => { element.reload().then(() => {
assert.equal(element._filteredLinks.length, 2); assert.equal(element._filteredLinks.length, 2);
@ -185,13 +189,14 @@ limitations under the License.
sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({ sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({
name: 'test-user', name: 'test-user',
})); }));
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
}));
element.reload().then(() => { element.reload().then(() => {
flushAsynchronousOperations(); flushAsynchronousOperations();
assert.equal(Polymer.dom(element.root) assert.equal(Polymer.dom(element.root)
@ -214,13 +219,14 @@ limitations under the License.
sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({ sandbox.stub(element.$.restAPI, 'getAccount').returns(Promise.resolve({
name: 'test-user', name: 'test-user',
})); }));
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
}));
element.reload().then(() => { element.reload().then(() => {
flushAsynchronousOperations(); flushAsynchronousOperations();
assert.equal(element._filteredLinks.length, 3); assert.equal(element._filteredLinks.length, 3);
@ -239,16 +245,18 @@ limitations under the License.
}); });
test('Nav is reloaded when repo changes', () => { test('Nav is reloaded when repo changes', () => {
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
sandbox.stub(element.$.restAPI, 'getAccount', () => { }));
return Promise.resolve({_id: 1}); sandbox.stub(
}); element.$.restAPI,
'getAccount',
() => Promise.resolve({_id: 1}));
sandbox.stub(element, 'reload'); sandbox.stub(element, 'reload');
element.params = {repo: 'Test Repo', adminView: 'gr-repo'}; element.params = {repo: 'Test Repo', adminView: 'gr-repo'};
assert.equal(element.reload.callCount, 1); assert.equal(element.reload.callCount, 1);
@ -259,16 +267,18 @@ limitations under the License.
test('Nav is reloaded when group changes', () => { test('Nav is reloaded when group changes', () => {
sandbox.stub(element, '_computeGroupName'); sandbox.stub(element, '_computeGroupName');
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
sandbox.stub(element.$.restAPI, 'getAccount', () => { }));
return Promise.resolve({_id: 1}); sandbox.stub(
}); element.$.restAPI,
'getAccount',
() => Promise.resolve({_id: 1}));
sandbox.stub(element, 'reload'); sandbox.stub(element, 'reload');
element.params = {groupId: '1', adminView: 'gr-group'}; element.params = {groupId: '1', adminView: 'gr-group'};
assert.equal(element.reload.callCount, 1); assert.equal(element.reload.callCount, 1);
@ -304,7 +314,9 @@ limitations under the License.
assert.isOk(element.$$('.mainHeader')); assert.isOk(element.$$('.mainHeader'));
element._subsectionLinks = undefined; element._subsectionLinks = undefined;
flushAsynchronousOperations(); flushAsynchronousOperations();
assert.equal(getComputedStyle(element.$$('.mainHeader')).display, 'none'); assert.equal(
getComputedStyle(element.$$('.mainHeader')).display,
'none');
}); });
test('Dropdown only triggers navigation on explicit select', done => { test('Dropdown only triggers navigation on explicit select', done => {
@ -314,16 +326,18 @@ limitations under the License.
view: Gerrit.Nav.View.REPO, view: Gerrit.Nav.View.REPO,
detail: Gerrit.Nav.RepoDetailView.ACCESS, detail: Gerrit.Nav.RepoDetailView.ACCESS,
}; };
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
sandbox.stub(element.$.restAPI, 'getAccount', () => { }));
return Promise.resolve({_id: 1}); sandbox.stub(
}); element.$.restAPI,
'getAccount',
() => Promise.resolve({_id: 1}));
flushAsynchronousOperations(); flushAsynchronousOperations();
const expectedFilteredLinks = [ const expectedFilteredLinks = [
{ {
@ -475,16 +489,18 @@ limitations under the License.
suite('_computeSelectedClass', () => { suite('_computeSelectedClass', () => {
setup(() => { setup(() => {
sandbox.stub(element.$.restAPI, 'getAccountCapabilities', () => { sandbox.stub(
return Promise.resolve({ element.$.restAPI,
createGroup: true, 'getAccountCapabilities',
createProject: true, () => Promise.resolve({
viewPlugins: true, createGroup: true,
}); createProject: true,
}); viewPlugins: true,
sandbox.stub(element.$.restAPI, 'getAccount', () => { }));
return Promise.resolve({_id: 1}); sandbox.stub(
}); element.$.restAPI,
'getAccount',
() => Promise.resolve({_id: 1}));
return element.reload(); return element.reload();
}); });

View File

@ -81,9 +81,7 @@ limitations under the License.
}; };
const saveStub = sandbox.stub(element.$.restAPI, const saveStub = sandbox.stub(element.$.restAPI,
'createChange', () => { 'createChange', () => Promise.resolve({}));
return Promise.resolve({});
});
element.branch = 'test-branch'; element.branch = 'test-branch';
element.topic = 'test-topic'; element.topic = 'test-topic';
@ -109,9 +107,7 @@ limitations under the License.
configured_value: 'TRUE', configured_value: 'TRUE',
inherited_value: false, inherited_value: false,
}; };
sandbox.stub(element, '_formatBooleanString', () => { sandbox.stub(element, '_formatBooleanString', () => Promise.resolve(true));
return Promise.resolve(true);
});
flushAsynchronousOperations(); flushAsynchronousOperations();
const configInputObj = { const configInputObj = {
@ -123,9 +119,7 @@ limitations under the License.
}; };
const saveStub = sandbox.stub(element.$.restAPI, const saveStub = sandbox.stub(element.$.restAPI,
'createChange', () => { 'createChange', () => Promise.resolve({}));
return Promise.resolve({});
});
element.branch = 'test-branch'; element.branch = 'test-branch';
element.topic = 'test-topic'; element.topic = 'test-topic';

View File

@ -56,9 +56,10 @@ limitations under the License.
}); });
test('branch created', done => { test('branch created', done => {
sandbox.stub(element.$.restAPI, 'createRepoBranch', () => { sandbox.stub(
return Promise.resolve({}); element.$.restAPI,
}); 'createRepoBranch',
() => Promise.resolve({}));
assert.isFalse(element.hasNewItemName); assert.isFalse(element.hasNewItemName);
@ -77,9 +78,10 @@ limitations under the License.
}); });
test('tag created', done => { test('tag created', done => {
sandbox.stub(element.$.restAPI, 'createRepoTag', () => { sandbox.stub(
return Promise.resolve({}); element.$.restAPI,
}); 'createRepoTag',
() => Promise.resolve({}));
assert.isFalse(element.hasNewItemName); assert.isFalse(element.hasNewItemName);
@ -98,9 +100,10 @@ limitations under the License.
}); });
test('tag created with annotations', done => { test('tag created with annotations', done => {
sandbox.stub(element.$.restAPI, 'createRepoTag', () => { sandbox.stub(
return Promise.resolve({}); element.$.restAPI,
}); 'createRepoTag',
() => Promise.resolve({}));
assert.isFalse(element.hasNewItemName); assert.isFalse(element.hasNewItemName);

View File

@ -66,9 +66,7 @@ limitations under the License.
}; };
const saveStub = sandbox.stub(element.$.restAPI, const saveStub = sandbox.stub(element.$.restAPI,
'createRepo', () => { 'createRepo', () => Promise.resolve({}));
return Promise.resolve({});
});
assert.isFalse(element.hasNewRepoName); assert.isFalse(element.hasNewRepoName);

View File

@ -153,9 +153,10 @@ limitations under the License.
element = fixture('basic'); element = fixture('basic');
sandbox.stub(element, 'getBaseUrl').returns('https://test/site'); sandbox.stub(element, 'getBaseUrl').returns('https://test/site');
element.groupId = 1; element.groupId = 1;
groupStub = sandbox.stub(element.$.restAPI, 'getGroupConfig', () => { groupStub = sandbox.stub(
return Promise.resolve(groups); element.$.restAPI,
}); 'getGroupConfig',
() => Promise.resolve(groups));
return element._loadGroupDetails(); return element._loadGroupDetails();
}); });
@ -181,9 +182,7 @@ limitations under the License.
const memberName = 'test-admin'; const memberName = 'test-admin';
const saveStub = sandbox.stub(element.$.restAPI, 'saveGroupMembers', const saveStub = sandbox.stub(element.$.restAPI, 'saveGroupMembers',
() => { () => Promise.resolve({}));
return Promise.resolve({});
});
const button = element.$.saveGroupMember; const button = element.$.saveGroupMember;
@ -208,9 +207,7 @@ limitations under the License.
const includedGroupName = 'testName'; const includedGroupName = 'testName';
const saveIncludedGroupStub = sandbox.stub( const saveIncludedGroupStub = sandbox.stub(
element.$.restAPI, 'saveIncludedGroup', () => { element.$.restAPI, 'saveIncludedGroup', () => Promise.resolve({}));
return Promise.resolve({});
});
const button = element.$.saveIncludedGroups; const button = element.$.saveIncludedGroups;
@ -248,35 +245,31 @@ limitations under the License.
}); });
}); });
test('_getAccountSuggestions empty', () => { test('_getAccountSuggestions empty', () => element
return element._getAccountSuggestions('nonexistent').then(accounts => { ._getAccountSuggestions('nonexistent').then(accounts => {
assert.equal(accounts.length, 0); assert.equal(accounts.length, 0);
}); }));
});
test('_getAccountSuggestions non-empty', () => { test('_getAccountSuggestions non-empty', () => element
return element._getAccountSuggestions('test-').then(accounts => { ._getAccountSuggestions('test-').then(accounts => {
assert.equal(accounts.length, 3); assert.equal(accounts.length, 3);
assert.equal(accounts[0].name, assert.equal(accounts[0].name,
'test-account <test.account@example.com>'); 'test-account <test.account@example.com>');
assert.equal(accounts[1].name, 'test-admin <test.admin@example.com>'); assert.equal(accounts[1].name, 'test-admin <test.admin@example.com>');
assert.equal(accounts[2].name, 'test-git'); assert.equal(accounts[2].name, 'test-git');
}); }));
});
test('_getGroupSuggestions empty', () => { test('_getGroupSuggestions empty', () => element
return element._getGroupSuggestions('nonexistent').then(groups => { ._getGroupSuggestions('nonexistent').then(groups => {
assert.equal(groups.length, 0); assert.equal(groups.length, 0);
}); }));
});
test('_getGroupSuggestions non-empty', () => { test('_getGroupSuggestions non-empty', () => element
return element._getGroupSuggestions('test').then(groups => { ._getGroupSuggestions('test').then(groups => {
assert.equal(groups.length, 2); assert.equal(groups.length, 2);
assert.equal(groups[0].name, 'test-admin'); assert.equal(groups[0].name, 'test-admin');
assert.equal(groups[1].name, 'test/Administrator (admin)'); assert.equal(groups[1].name, 'test/Administrator (admin)');
}); }));
});
test('_computeHideItemClass returns string for admin', () => { test('_computeHideItemClass returns string for admin', () => {
const admin = true; const admin = true;

View File

@ -56,9 +56,11 @@ limitations under the License.
getLoggedIn() { return Promise.resolve(true); }, getLoggedIn() { return Promise.resolve(true); },
}); });
element = fixture('basic'); element = fixture('basic');
groupStub = sandbox.stub(element.$.restAPI, 'getGroupConfig', () => { groupStub = sandbox.stub(
return Promise.resolve(group); element.$.restAPI,
}); 'getGroupConfig',
() => Promise.resolve(group)
);
}); });
teardown(() => { teardown(() => {
@ -74,9 +76,10 @@ limitations under the License.
}); });
test('default values are populated with internal group', done => { test('default values are populated with internal group', done => {
sandbox.stub(element.$.restAPI, 'getIsGroupOwner', () => { sandbox.stub(
return Promise.resolve(true); element.$.restAPI,
}); 'getIsGroupOwner',
() => Promise.resolve(true));
element.groupId = 1; element.groupId = 1;
element._loadGroup().then(() => { element._loadGroup().then(() => {
assert.isTrue(element._groupIsInternal); assert.isTrue(element._groupIsInternal);
@ -89,12 +92,14 @@ limitations under the License.
const groupExternal = Object.assign({}, group); const groupExternal = Object.assign({}, group);
groupExternal.id = 'external-group-id'; groupExternal.id = 'external-group-id';
groupStub.restore(); groupStub.restore();
groupStub = sandbox.stub(element.$.restAPI, 'getGroupConfig', () => { groupStub = sandbox.stub(
return Promise.resolve(groupExternal); element.$.restAPI,
}); 'getGroupConfig',
sandbox.stub(element.$.restAPI, 'getIsGroupOwner', () => { () => Promise.resolve(groupExternal));
return Promise.resolve(true); sandbox.stub(
}); element.$.restAPI,
'getIsGroupOwner',
() => Promise.resolve(true));
element.groupId = 1; element.groupId = 1;
element._loadGroup().then(() => { element._loadGroup().then(() => {
assert.isFalse(element._groupIsInternal); assert.isFalse(element._groupIsInternal);
@ -114,13 +119,15 @@ limitations under the License.
element._groupName = groupName; element._groupName = groupName;
element._groupOwner = true; element._groupOwner = true;
sandbox.stub(element.$.restAPI, 'getIsGroupOwner', () => { sandbox.stub(
return Promise.resolve(true); element.$.restAPI,
}); 'getIsGroupOwner',
() => Promise.resolve(true));
sandbox.stub(element.$.restAPI, 'saveGroupName', () => { sandbox.stub(
return Promise.resolve({status: 200}); element.$.restAPI,
}); 'saveGroupName',
() => Promise.resolve({status: 200}));
const button = element.$.inputUpdateNameBtn; const button = element.$.inputUpdateNameBtn;
@ -154,9 +161,10 @@ limitations under the License.
test('test for undefined group name', done => { test('test for undefined group name', done => {
groupStub.restore(); groupStub.restore();
sandbox.stub(element.$.restAPI, 'getGroupConfig', () => { sandbox.stub(
return Promise.resolve({}); element.$.restAPI,
}); 'getGroupConfig',
() => Promise.resolve({}));
assert.isUndefined(element.groupId); assert.isUndefined(element.groupId);

View File

@ -209,9 +209,8 @@
_computeLabelValues(values) { _computeLabelValues(values) {
const valuesArr = []; const valuesArr = [];
const keys = Object.keys(values).sort((a, b) => { const keys = Object.keys(values)
return parseInt(a, 10) - parseInt(b, 10); .sort((a, b) => parseInt(a, 10) - parseInt(b, 10));
});
for (const key of keys) { for (const key of keys) {
let text = values[key]; let text = values[key];
@ -255,9 +254,8 @@
}); });
} }
// Does not return groups in which we already have rules for. // Does not return groups in which we already have rules for.
return groups.filter(group => { return groups
return !this._groupsWithRules[group.value.id]; .filter(group => !this._groupsWithRules[group.value.id]);
});
}); });
} }
@ -268,7 +266,8 @@
_handleAddRuleItem(e) { _handleAddRuleItem(e) {
// The group id is encoded, but have to decode in order for the access // The group id is encoded, but have to decode in order for the access
// API to work as expected. // API to work as expected.
const groupId = decodeURIComponent(e.detail.value.id).replace(/\+/g, ' '); const groupId = decodeURIComponent(e.detail.value.id)
.replace(/\+/g, ' ');
this.set(['permission', 'value', 'rules', groupId], {}); this.set(['permission', 'value', 'rules', groupId], {});
// Purposely don't recompute sorted array so that the newly added rule // Purposely don't recompute sorted array so that the newly added rule

View File

@ -125,9 +125,10 @@ limitations under the License.
suite('filter', () => { suite('filter', () => {
test('_paramsChanged', done => { test('_paramsChanged', done => {
sandbox.stub(element.$.restAPI, 'getPlugins', () => { sandbox.stub(
return Promise.resolve(plugins); element.$.restAPI,
}); 'getPlugins',
() => Promise.resolve(plugins));
const value = { const value = {
filter: 'test', filter: 'test',
offset: 25, offset: 25,

View File

@ -579,8 +579,9 @@ limitations under the License.
remove: {}, remove: {},
}; };
element.$$('gr-access-section').$$('gr-permission')._handleAddRuleItem( element.$$('gr-access-section').$$('gr-permission')
{detail: {value: {id: 'Maintainers'}}}); ._handleAddRuleItem(
{detail: {value: {id: 'Maintainers'}}});
flushAsynchronousOperations(); flushAsynchronousOperations();
assert.deepEqual(element._computeAddAndRemove(), expectedInput); assert.deepEqual(element._computeAddAndRemove(), expectedInput);

View File

@ -44,9 +44,10 @@ limitations under the License.
setup(() => { setup(() => {
sandbox = sinon.sandbox.create(); sandbox = sinon.sandbox.create();
element = fixture('basic'); element = fixture('basic');
repoStub = sandbox.stub(element.$.restAPI, 'getProjectConfig', () => { repoStub = sandbox.stub(
return Promise.resolve({}); element.$.restAPI,
}); 'getProjectConfig',
() => Promise.resolve({}));
}); });
teardown(() => { teardown(() => {

View File

@ -54,7 +54,7 @@
// Group by ref and sort by id. // Group by ref and sort by id.
const dashboards = res.concat.apply([], res).sort((a, b) => const dashboards = res.concat.apply([], res).sort((a, b) =>
a.id < b.id ? -1 : 1); (a.id < b.id ? -1 : 1));
const dashboardsByRef = {}; const dashboardsByRef = {};
dashboards.forEach(d => { dashboards.forEach(d => {
if (!dashboardsByRef[d.ref]) { if (!dashboardsByRef[d.ref]) {
@ -64,12 +64,13 @@
}); });
const dashboardBuilder = []; const dashboardBuilder = [];
Object.keys(dashboardsByRef).sort().forEach(ref => { Object.keys(dashboardsByRef).sort()
dashboardBuilder.push({ .forEach(ref => {
section: ref, dashboardBuilder.push({
dashboards: dashboardsByRef[ref], section: ref,
}); dashboards: dashboardsByRef[ref],
}); });
});
this._dashboards = dashboardBuilder; this._dashboards = dashboardBuilder;
this._loading = false; this._loading = false;

View File

@ -297,9 +297,10 @@ limitations under the License.
suite('filter', () => { suite('filter', () => {
test('_paramsChanged', done => { test('_paramsChanged', done => {
sandbox.stub(element.$.restAPI, 'getRepoBranches', () => { sandbox.stub(
return Promise.resolve(branches); element.$.restAPI,
}); 'getRepoBranches',
() => Promise.resolve(branches));
const params = { const params = {
detail: 'branches', detail: 'branches',
repo: 'test', repo: 'test',
@ -480,9 +481,10 @@ limitations under the License.
suite('filter', () => { suite('filter', () => {
test('_paramsChanged', done => { test('_paramsChanged', done => {
sandbox.stub(element.$.restAPI, 'getRepoTags', () => { sandbox.stub(
return Promise.resolve(tags); element.$.restAPI,
}); 'getRepoTags',
() => Promise.resolve(tags));
const params = { const params = {
repo: 'test', repo: 'test',
detail: 'tags', detail: 'tags',

View File

@ -127,9 +127,7 @@ limitations under the License.
}); });
test('_paramsChanged', done => { test('_paramsChanged', done => {
sandbox.stub(element.$.restAPI, 'getRepos', () => { sandbox.stub(element.$.restAPI, 'getRepos', () => Promise.resolve(repos));
return Promise.resolve(repos);
});
const value = { const value = {
filter: 'test', filter: 'test',
offset: 25, offset: 25,

View File

@ -49,7 +49,8 @@
return []; return [];
} }
const {config} = dataRecord.base; const {config} = dataRecord.base;
return Object.keys(config).map(_key => ({_key, info: config[_key]})); return Object.keys(config)
.map(_key => { return {_key, info: config[_key]}; });
} }
_isArray(type) { _isArray(type) {

View File

@ -136,7 +136,7 @@
const pluginConfig = configRecord.base; const pluginConfig = configRecord.base;
return Object.keys(pluginConfig) return Object.keys(pluginConfig)
.map(name => ({name, config: pluginConfig[name]})); .map(name => { return {name, config: pluginConfig[name]}; });
} }
_loadRepo() { _loadRepo() {

View File

@ -120,9 +120,10 @@ limitations under the License.
}, },
}); });
element = fixture('basic'); element = fixture('basic');
repoStub = sandbox.stub(element.$.restAPI, 'getProjectConfig', () => { repoStub = sandbox.stub(
return Promise.resolve(repoConf); element.$.restAPI,
}); 'getProjectConfig',
() => Promise.resolve(repoConf));
}); });
teardown(() => { teardown(() => {
@ -187,12 +188,11 @@ limitations under the License.
test('form defaults to read only when logged in and not admin', done => { test('form defaults to read only when logged in and not admin', done => {
element.repo = REPO; element.repo = REPO;
sandbox.stub(element, '_getLoggedIn', () => { sandbox.stub(element, '_getLoggedIn', () => Promise.resolve(true));
return Promise.resolve(true); sandbox.stub(
}); element.$.restAPI,
sandbox.stub(element.$.restAPI, 'getRepoAccess', () => { 'getRepoAccess',
return Promise.resolve({'test-repo': {}}); () => Promise.resolve({'test-repo': {}}));
});
element._loadRepo().then(() => { element._loadRepo().then(() => {
assert.isTrue(element._readOnly); assert.isTrue(element._readOnly);
done(); done();
@ -280,12 +280,11 @@ limitations under the License.
suite('admin', () => { suite('admin', () => {
setup(() => { setup(() => {
element.repo = REPO; element.repo = REPO;
sandbox.stub(element, '_getLoggedIn', () => { sandbox.stub(element, '_getLoggedIn', () => Promise.resolve(true));
return Promise.resolve(true); sandbox.stub(
}); element.$.restAPI,
sandbox.stub(element.$.restAPI, 'getRepoAccess', () => { 'getRepoAccess',
return Promise.resolve({'test-repo': {is_owner: true}}); () => Promise.resolve({'test-repo': {is_owner: true}}));
});
}); });
test('all form elements are enabled', done => { test('all form elements are enabled', done => {
@ -308,14 +307,13 @@ limitations under the License.
}); });
}); });
test('inherited submit type value is calculated correctly', () => { test('inherited submit type value is calculated correctly', () => element
return element._loadRepo().then(() => { ._loadRepo().then(() => {
const sel = element.$.submitTypeSelect; const sel = element.$.submitTypeSelect;
assert.equal(sel.bindValue, 'INHERIT'); assert.equal(sel.bindValue, 'INHERIT');
assert.equal( assert.equal(
sel.nativeSelect.options[0].text, 'Inherit (Merge if necessary)'); sel.nativeSelect.options[0].text, 'Inherit (Merge if necessary)');
}); }));
});
test('fields update and save correctly', () => { test('fields update and save correctly', () => {
const configInputObj = { const configInputObj = {
@ -338,9 +336,7 @@ limitations under the License.
}; };
const saveStub = sandbox.stub(element.$.restAPI, 'saveRepoConfig' const saveStub = sandbox.stub(element.$.restAPI, 'saveRepoConfig'
, () => { , () => Promise.resolve({}));
return Promise.resolve({});
});
const button = Polymer.dom(element.root).querySelector('gr-button'); const button = Polymer.dom(element.root).querySelector('gr-button');

View File

@ -121,7 +121,8 @@
} else { } else {
classes['u-gray-background'] = true; classes['u-gray-background'] = true;
} }
return Object.keys(classes).sort().join(' '); return Object.keys(classes).sort()
.join(' ');
} }
_computeLabelValue(change, labelName) { _computeLabelValue(change, labelName) {

View File

@ -163,24 +163,26 @@
// in an async so that attachment to the DOM can take place first. // in an async so that attachment to the DOM can take place first.
this.async(() => this.fire('title-change', {title: this._query})); this.async(() => this.fire('title-change', {title: this._query}));
this._getPreferences().then(prefs => { this._getPreferences()
this._changesPerPage = prefs.changes_per_page; .then(prefs => {
return this._getChanges(); this._changesPerPage = prefs.changes_per_page;
}).then(changes => { return this._getChanges();
changes = changes || []; })
if (this._query && changes.length === 1) { .then(changes => {
for (const query in LookupQueryPatterns) { changes = changes || [];
if (LookupQueryPatterns.hasOwnProperty(query) && if (this._query && changes.length === 1) {
for (const query in LookupQueryPatterns) {
if (LookupQueryPatterns.hasOwnProperty(query) &&
this._query.match(LookupQueryPatterns[query])) { this._query.match(LookupQueryPatterns[query])) {
this._replaceCurrentLocation( this._replaceCurrentLocation(
Gerrit.Nav.getUrlForChange(changes[0])); Gerrit.Nav.getUrlForChange(changes[0]));
return; return;
}
}
} }
} this._changes = changes;
} this._loading = false;
this._changes = changes; });
this._loading = false;
});
} }
_loadPreferences() { _loadPreferences() {

View File

@ -234,11 +234,8 @@
_processQuery(query) { _processQuery(query) {
let tokens = query.split(' '); let tokens = query.split(' ');
const invalidTokens = ['limit:', 'age:', '-age:']; const invalidTokens = ['limit:', 'age:', '-age:'];
tokens = tokens.filter(token => { tokens = tokens.filter(token => !invalidTokens
return !invalidTokens.some(invalidToken => { .some(invalidToken => token.startsWith(invalidToken)));
return token.startsWith(invalidToken);
});
});
return tokens.join(' '); return tokens.join(' ');
} }

View File

@ -181,12 +181,14 @@
.then(() => { .then(() => {
this._maybeShowDraftsBanner(); this._maybeShowDraftsBanner();
this.$.reporting.dashboardDisplayed(); this.$.reporting.dashboardDisplayed();
}).catch(err => { })
.catch(err => {
this.fire('title-change', { this.fire('title-change', {
title: title || this._computeTitle(user), title: title || this._computeTitle(user),
}); });
console.warn(err); console.warn(err);
}).then(() => { this._loading = false; }); })
.then(() => { this._loading = false; });
} }
/** /**
@ -201,9 +203,9 @@
if (!res) { return Promise.resolve(); } if (!res) { return Promise.resolve(); }
const queries = res.sections const queries = res.sections
.map(section => section.suffixForDashboard ? .map(section => (section.suffixForDashboard ?
section.query + ' ' + section.suffixForDashboard : section.query + ' ' + section.suffixForDashboard :
section.query); section.query));
if (checkForNewUser) { if (checkForNewUser) {
queries.push('owner:self limit:1'); queries.push('owner:self limit:1');
@ -216,13 +218,15 @@
const lastResultSet = changes.pop(); const lastResultSet = changes.pop();
this._showNewUserHelp = lastResultSet.length == 0; this._showNewUserHelp = lastResultSet.length == 0;
} }
this._results = changes.map((results, i) => ({ this._results = changes.map((results, i) => {
name: res.sections[i].name, return {
countLabel: this._computeSectionCountLabel(results), name: res.sections[i].name,
query: res.sections[i].query, countLabel: this._computeSectionCountLabel(results),
results, query: res.sections[i].query,
isOutgoing: res.sections[i].isOutgoing, results,
})).filter((section, i) => i < res.sections.length && ( isOutgoing: res.sections[i].isOutgoing,
};
}).filter((section, i) => i < res.sections.length && (
!res.sections[i].hideIfEmpty || !res.sections[i].hideIfEmpty ||
section.results.length)); section.results.length));
}); });

View File

@ -474,16 +474,18 @@
} }
this._loading = true; this._loading = true;
return this._getRevisionActions().then(revisionActions => { return this._getRevisionActions()
if (!revisionActions) { return; } .then(revisionActions => {
if (!revisionActions) { return; }
this.revisionActions = this._updateRebaseAction(revisionActions); this.revisionActions = this._updateRebaseAction(revisionActions);
this._handleLoadingComplete(); this._handleLoadingComplete();
}).catch(err => { })
this.fire('show-alert', {message: ERR_REVISION_ACTIONS}); .catch(err => {
this._loading = false; this.fire('show-alert', {message: ERR_REVISION_ACTIONS});
throw err; this._loading = false;
}); throw err;
});
} }
_handleLoadingComplete() { _handleLoadingComplete() {
@ -515,7 +517,8 @@
label, label,
__type: type, __type: type,
__key: ADDITIONAL_ACTION_KEY_PREFIX + __key: ADDITIONAL_ACTION_KEY_PREFIX +
Math.random().toString(36).substr(2), Math.random().toString(36)
.substr(2),
}; };
this.push('_additionalActions', action); this.push('_additionalActions', action);
return action.__key; return action.__key;
@ -558,9 +561,8 @@
if (type !== ActionType.CHANGE && type !== ActionType.REVISION) { if (type !== ActionType.CHANGE && type !== ActionType.REVISION) {
throw Error(`Invalid action type given: ${type}`); throw Error(`Invalid action type given: ${type}`);
} }
const index = this._actionPriorityOverrides.findIndex(action => { const index = this._actionPriorityOverrides
return action.type === type && action.key === key; .findIndex(action => action.type === type && action.key === key);
});
const action = { const action = {
type, type,
key, key,
@ -723,9 +725,7 @@
} }
_getValuesFor(obj) { _getValuesFor(obj) {
return Object.keys(obj).map(key => { return Object.keys(obj).map(key => obj[key]);
return obj[key];
});
} }
_getLabelStatus(label) { _getLabelStatus(label) {
@ -790,9 +790,8 @@
hideQuickApproveAction() { hideQuickApproveAction() {
this._topLevelSecondaryActions = this._topLevelSecondaryActions =
this._topLevelSecondaryActions.filter(sa => { this._topLevelSecondaryActions
return sa.key !== QUICK_APPROVE_ACTION.key; .filter(sa => sa.key !== QUICK_APPROVE_ACTION.key);
});
this._hideQuickApproveAction = true; this._hideQuickApproveAction = true;
} }
@ -850,13 +849,13 @@
let additionalActions = (additionalActionsChangeRecord && let additionalActions = (additionalActionsChangeRecord &&
additionalActionsChangeRecord.base) || []; additionalActionsChangeRecord.base) || [];
additionalActions = additionalActions.filter(a => { additionalActions = additionalActions
return a.__type === type; .filter(a => a.__type === type)
}).map(a => { .map(a => {
a.__primary = primaryActionKeys.includes(a.__key); a.__primary = primaryActionKeys.includes(a.__key);
// Triggers a re-render by ensuring object inequality. // Triggers a re-render by ensuring object inequality.
return Object.assign({}, a); return Object.assign({}, a);
}); });
return result.concat(additionalActions).concat(pluginActions); return result.concat(additionalActions).concat(pluginActions);
} }
@ -993,9 +992,7 @@
this._showActionDialog(this.$.confirmAbandonDialog); this._showActionDialog(this.$.confirmAbandonDialog);
break; break;
case QUICK_APPROVE_ACTION.key: case QUICK_APPROVE_ACTION.key:
action = this._allActionValues.find(o => { action = this._allActionValues.find(o => o.key === key);
return o.key === key;
});
this._fireAction( this._fireAction(
this._prependSlash(key), action, true, action.payload); this._prependSlash(key), action, true, action.payload);
break; break;
@ -1193,9 +1190,8 @@
} }
_getActionOverflowIndex(type, key) { _getActionOverflowIndex(type, key) {
return this._overflowActions.findIndex(action => { return this._overflowActions
return action.type === type && action.key === key; .findIndex(action => action.type === type && action.key === key);
});
} }
_setLoadingOnButtonWithKey(type, key) { _setLoadingOnButtonWithKey(type, key) {
@ -1457,9 +1453,8 @@
_getActionPriority(action) { _getActionPriority(action) {
if (action.__type && action.__key) { if (action.__type && action.__key) {
const overrideAction = this._actionPriorityOverrides.find(i => { const overrideAction = this._actionPriorityOverrides
return i.type === action.__type && i.key === action.__key; .find(i => i.type === action.__type && i.key === action.__key);
});
if (overrideAction !== undefined) { if (overrideAction !== undefined) {
return overrideAction.priority; return overrideAction.priority;

View File

@ -220,9 +220,8 @@ limitations under the License.
test('delete buttons have explicit labels', done => { test('delete buttons have explicit labels', done => {
flush(() => { flush(() => {
const deleteItems = element.$.moreActions.items.filter(item => { const deleteItems = element.$.moreActions.items
return item.id.startsWith('delete'); .filter(item => item.id.startsWith('delete'));
});
assert.equal(deleteItems.length, 1); assert.equal(deleteItems.length, 1);
assert.notEqual(deleteItems[0].name); assert.notEqual(deleteItems[0].name);
assert.equal(deleteItems[0].name, 'Delete change'); assert.equal(deleteItems[0].name, 'Delete change');
@ -261,7 +260,7 @@ limitations under the License.
sandbox.stub(element.$.restAPI, 'getFromProjectLookup') sandbox.stub(element.$.restAPI, 'getFromProjectLookup')
.returns(Promise.resolve('test')); .returns(Promise.resolve('test'));
sandbox.stub(element, 'fetchChangeUpdates', sandbox.stub(element, 'fetchChangeUpdates',
() => { return Promise.resolve({isLatest: true}); }); () => Promise.resolve({isLatest: true}));
sandbox.stub(element.$.overlay, 'open').returns(Promise.resolve()); sandbox.stub(element.$.overlay, 'open').returns(Promise.resolve());
element.change = { element.change = {
revisions: { revisions: {
@ -284,7 +283,7 @@ limitations under the License.
sandbox.stub(element.$.restAPI, 'getFromProjectLookup') sandbox.stub(element.$.restAPI, 'getFromProjectLookup')
.returns(Promise.resolve('test')); .returns(Promise.resolve('test'));
sandbox.stub(element, 'fetchChangeUpdates', sandbox.stub(element, 'fetchChangeUpdates',
() => { return Promise.resolve({isLatest: true}); }); () => Promise.resolve({isLatest: true}));
sandbox.stub(element.$.overlay, 'open').returns(Promise.resolve()); sandbox.stub(element.$.overlay, 'open').returns(Promise.resolve());
element.change = { element.change = {
revisions: { revisions: {
@ -318,7 +317,7 @@ limitations under the License.
test('submit change with plugin hook', done => { test('submit change with plugin hook', done => {
sandbox.stub(element, '_canSubmitChange', sandbox.stub(element, '_canSubmitChange',
() => { return false; }); () => false);
const fireActionStub = sandbox.stub(element, '_fireAction'); const fireActionStub = sandbox.stub(element, '_fireAction');
flush(() => { flush(() => {
const submitButton = element.$$('gr-button[data-action-key="submit"]'); const submitButton = element.$$('gr-button[data-action-key="submit"]');
@ -819,9 +818,9 @@ limitations under the License.
}; };
const newRevertMsg = 'Modified revert msg'; const newRevertMsg = 'Modified revert msg';
sandbox.stub(element, '_modifyRevertMsg', sandbox.stub(element, '_modifyRevertMsg',
() => { return newRevertMsg; }); () => newRevertMsg);
sandbox.stub(element.$.confirmRevertDialog, 'populateRevertMessage', sandbox.stub(element.$.confirmRevertDialog, 'populateRevertMessage',
() => { return 'original msg'; }); () => 'original msg');
flush(() => { flush(() => {
const revertButton = const revertButton =
element.$$('gr-button[data-action-key="revert"]'); element.$$('gr-button[data-action-key="revert"]');
@ -837,7 +836,7 @@ limitations under the License.
current_revision: 'abc1234', current_revision: 'abc1234',
}; };
sandbox.stub(element.$.confirmRevertDialog, 'populateRevertMessage', sandbox.stub(element.$.confirmRevertDialog, 'populateRevertMessage',
() => { return 'original msg'; }); () => 'original msg');
const revertButton = element.$$('gr-button[data-action-key="revert"]'); const revertButton = element.$$('gr-button[data-action-key="revert"]');
MockInteractions.tap(revertButton); MockInteractions.tap(revertButton);
@ -1398,15 +1397,13 @@ limitations under the License.
sandbox.stub(element, 'async', fn => fn()); sandbox.stub(element, 'async', fn => fn());
}); });
const makeGetChange = numTries => { const makeGetChange = numTries => () => {
return () => { if (numTries === 1) {
if (numTries === 1) { return Promise.resolve({_number: 123});
return Promise.resolve({_number: 123}); } else {
} else { numTries--;
numTries--; return Promise.resolve(undefined);
return Promise.resolve(undefined); }
}
};
}; };
test('succeed', () => { test('succeed', () => {
@ -1457,15 +1454,14 @@ limitations under the License.
'navigateToChange').returns(Promise.resolve(true)); 'navigateToChange').returns(Promise.resolve(true));
}); });
test('change action', () => { test('change action', () => element
return element._send('DELETE', payload, '/endpoint', false, cleanup) ._send('DELETE', payload, '/endpoint', false, cleanup)
.then(() => { .then(() => {
assert.isFalse(onShowError.called); assert.isFalse(onShowError.called);
assert.isTrue(cleanup.calledOnce); assert.isTrue(cleanup.calledOnce);
assert.isTrue(sendStub.calledWith(42, 'DELETE', '/endpoint', assert.isTrue(sendStub.calledWith(42, 'DELETE', '/endpoint',
null, payload)); null, payload));
}); }));
});
suite('show revert submission dialog', () => { suite('show revert submission dialog', () => {
setup(() => { setup(() => {
@ -1549,15 +1545,14 @@ limitations under the License.
}); });
}); });
test('revision action', () => { test('revision action', () => element
return element._send('DELETE', payload, '/endpoint', true, cleanup) ._send('DELETE', payload, '/endpoint', true, cleanup)
.then(() => { .then(() => {
assert.isFalse(onShowError.called); assert.isFalse(onShowError.called);
assert.isTrue(cleanup.calledOnce); assert.isTrue(cleanup.calledOnce);
assert.isTrue(sendStub.calledWith(42, 'DELETE', '/endpoint', assert.isTrue(sendStub.calledWith(42, 'DELETE', '/endpoint',
12, payload)); 12, payload));
}); }));
});
}); });
suite('failure modes', () => { suite('failure modes', () => {

View File

@ -376,15 +376,18 @@
_handleTopicRemoved(e) { _handleTopicRemoved(e) {
const target = Polymer.dom(e).rootTarget; const target = Polymer.dom(e).rootTarget;
target.disabled = true; target.disabled = true;
this.$.restAPI.setChangeTopic(this.change._number, null).then(() => { this.$.restAPI.setChangeTopic(this.change._number, null)
target.disabled = false; .then(() => {
this.set(['change', 'topic'], ''); target.disabled = false;
this.dispatchEvent( this.set(['change', 'topic'], '');
new CustomEvent('topic-changed', {bubbles: true, composed: true})); this.dispatchEvent(
}).catch(err => { new CustomEvent('topic-changed',
target.disabled = false; {bubbles: true, composed: true}));
return; })
}); .catch(err => {
target.disabled = false;
return;
});
} }
_handleHashtagRemoved(e) { _handleHashtagRemoved(e) {
@ -396,7 +399,8 @@
.then(newHashtag => { .then(newHashtag => {
target.disabled = false; target.disabled = false;
this.set(['change', 'hashtags'], newHashtag); this.set(['change', 'hashtags'], newHashtag);
}).catch(err => { })
.catch(err => {
target.disabled = false; target.disabled = false;
return; return;
}); });

View File

@ -736,8 +736,8 @@ limitations under the License.
Gerrit.install( Gerrit.install(
p => { p => {
plugin = p; plugin = p;
plugin.hook('change-metadata-item').getLastAttached().then( plugin.hook('change-metadata-item').getLastAttached()
el => hookEl = el); .then(el => hookEl = el);
}, },
'0.1', '0.1',
'http://some/plugins/url.html'); 'http://some/plugins/url.html');

View File

@ -362,16 +362,18 @@
this._setDiffViewMode(); this._setDiffViewMode();
}); });
Gerrit.awaitPluginsLoaded().then(() => { Gerrit.awaitPluginsLoaded()
this._dynamicTabHeaderEndpoints = .then(() => {
this._dynamicTabHeaderEndpoints =
Gerrit._endpoints.getDynamicEndpoints('change-view-tab-header'); Gerrit._endpoints.getDynamicEndpoints('change-view-tab-header');
this._dynamicTabContentEndpoints = this._dynamicTabContentEndpoints =
Gerrit._endpoints.getDynamicEndpoints('change-view-tab-content'); Gerrit._endpoints.getDynamicEndpoints('change-view-tab-content');
if (this._dynamicTabContentEndpoints.length !== if (this._dynamicTabContentEndpoints.length !==
this._dynamicTabHeaderEndpoints.length) { this._dynamicTabHeaderEndpoints.length) {
console.warn('Different number of tab headers and tab content.'); console.warn('Different number of tab headers and tab content.');
} }
}).then(() => this._setPrimaryTab()); })
.then(() => this._setPrimaryTab());
this.addEventListener('comment-save', this._handleCommentSave.bind(this)); this.addEventListener('comment-save', this._handleCommentSave.bind(this));
this.addEventListener('comment-refresh', this._reloadDrafts.bind(this)); this.addEventListener('comment-refresh', this._reloadDrafts.bind(this));
@ -413,15 +415,17 @@
_setDiffViewMode(opt_reset) { _setDiffViewMode(opt_reset) {
if (!opt_reset && this.viewState.diffViewMode) { return; } if (!opt_reset && this.viewState.diffViewMode) { return; }
return this._getPreferences().then( prefs => { return this._getPreferences()
if (!this.viewState.diffMode) { .then( prefs => {
this.set('viewState.diffMode', prefs.default_diff_view); if (!this.viewState.diffMode) {
} this.set('viewState.diffMode', prefs.default_diff_view);
}).then(() => { }
if (!this.viewState.diffMode) { })
this.set('viewState.diffMode', 'SIDE_BY_SIDE'); .then(() => {
} if (!this.viewState.diffMode) {
}); this.set('viewState.diffMode', 'SIDE_BY_SIDE');
}
});
} }
_onOpenFixPreview(e) { _onOpenFixPreview(e) {
@ -497,9 +501,10 @@
message); message);
this._editingCommitMessage = false; this._editingCommitMessage = false;
this._reloadWindow(); this._reloadWindow();
}).catch(err => { })
this.$.commitMessageEditor.disabled = false; .catch(err => {
}); this.$.commitMessageEditor.disabled = false;
});
} }
_reloadWindow() { _reloadWindow() {
@ -603,11 +608,11 @@
} }
} }
diffDrafts[draft.path].push(draft); diffDrafts[draft.path].push(draft);
diffDrafts[draft.path].sort((c1, c2) => { diffDrafts[draft.path].sort((c1, c2) =>
// No line number means that its a file comment. Sort it above the // No line number means that its a file comment. Sort it above the
// others. // others.
return (c1.line || -1) - (c2.line || -1); (c1.line || -1) - (c2.line || -1)
}); );
this._diffDrafts = diffDrafts; this._diffDrafts = diffDrafts;
} }
@ -689,7 +694,8 @@
_handleMessageReply(e) { _handleMessageReply(e) {
const msg = e.detail.message.message; const msg = e.detail.message.message;
const quoteStr = msg.split('\n').map( const quoteStr = msg.split('\n').map(
line => { return '> ' + line; }).join('\n') + '\n\n'; line => '> ' + line)
.join('\n') + '\n\n';
this.$.replyDialog.quote = quoteStr; this.$.replyDialog.quote = quoteStr;
this._openReplyDialog(this.$.replyDialog.FocusTarget.BODY); this._openReplyDialog(this.$.replyDialog.FocusTarget.BODY);
} }
@ -1087,9 +1093,8 @@
} }
const drafts = (changeRecord && changeRecord.base) || {}; const drafts = (changeRecord && changeRecord.base) || {};
const draftCount = Object.keys(drafts).reduce((count, file) => { const draftCount = Object.keys(drafts)
return count + drafts[file].length; .reduce((count, file) => count + drafts[file].length, 0);
}, 0);
let label = 'Reply'; let label = 'Reply';
if (draftCount > 0) { if (draftCount > 0) {
@ -1395,9 +1400,7 @@
} }
_reloadDraftsWithCallback(e) { _reloadDraftsWithCallback(e) {
return this._reloadDrafts().then(() => { return this._reloadDrafts().then(() => e.detail.resolve());
return e.detail.resolve();
});
} }
/** /**

View File

@ -91,9 +91,7 @@ limitations under the License.
}); });
}); });
getCustomCssValue = cssParam => { getCustomCssValue = cssParam => util.getComputedStyleValue(cssParam, element);
return util.getComputedStyleValue(cssParam, element);
};
test('_handleMessageAnchorTap', () => { test('_handleMessageAnchorTap', () => {
element._changeNum = '1'; element._changeNum = '1';
@ -725,10 +723,10 @@ limitations under the License.
test('dont reload entire page when patchRange changes', () => { test('dont reload entire page when patchRange changes', () => {
const reloadStub = sandbox.stub(element, '_reload', const reloadStub = sandbox.stub(element, '_reload',
() => { return Promise.resolve(); }); () => Promise.resolve());
const reloadPatchDependentStub = sandbox.stub(element, const reloadPatchDependentStub = sandbox.stub(element,
'_reloadPatchNumDependentResources', '_reloadPatchNumDependentResources',
() => { return Promise.resolve(); }); () => Promise.resolve());
const relatedClearSpy = sandbox.spy(element.$.relatedChanges, 'clear'); const relatedClearSpy = sandbox.spy(element.$.relatedChanges, 'clear');
const collapseStub = sandbox.stub(element.$.fileList, 'collapseAllDiffs'); const collapseStub = sandbox.stub(element.$.fileList, 'collapseAllDiffs');
@ -753,7 +751,7 @@ limitations under the License.
test('reload entire page when patchRange doesnt change', () => { test('reload entire page when patchRange doesnt change', () => {
const reloadStub = sandbox.stub(element, '_reload', const reloadStub = sandbox.stub(element, '_reload',
() => { return Promise.resolve(); }); () => Promise.resolve());
const collapseStub = sandbox.stub(element.$.fileList, 'collapseAllDiffs'); const collapseStub = sandbox.stub(element.$.fileList, 'collapseAllDiffs');
const value = { const value = {
view: Gerrit.Nav.View.CHANGE, view: Gerrit.Nav.View.CHANGE,
@ -769,11 +767,9 @@ limitations under the License.
test('related changes are updated and new patch selected after rebase', test('related changes are updated and new patch selected after rebase',
done => { done => {
element._changeNum = '42'; element._changeNum = '42';
sandbox.stub(element, 'computeLatestPatchNum', () => { sandbox.stub(element, 'computeLatestPatchNum', () => 1);
return 1;
});
sandbox.stub(element, '_reload', sandbox.stub(element, '_reload',
() => { return Promise.resolve(); }); () => Promise.resolve());
const e = {detail: {action: 'rebase'}}; const e = {detail: {action: 'rebase'}};
element._handleReloadChange(e).then(() => { element._handleReloadChange(e).then(() => {
assert.isTrue(navigateToChangeStub.lastCall.calledWithExactly( assert.isTrue(navigateToChangeStub.lastCall.calledWithExactly(
@ -783,7 +779,7 @@ limitations under the License.
}); });
test('related changes are not updated after other action', done => { test('related changes are not updated after other action', done => {
sandbox.stub(element, '_reload', () => { return Promise.resolve(); }); sandbox.stub(element, '_reload', () => Promise.resolve());
sandbox.stub(element.$.relatedChanges, 'reload'); sandbox.stub(element.$.relatedChanges, 'reload');
const e = {detail: {action: 'abandon'}}; const e = {detail: {action: 'abandon'}};
element._handleReloadChange(e).then(() => { element._handleReloadChange(e).then(() => {
@ -929,14 +925,12 @@ limitations under the License.
test('topic is coalesced to null', done => { test('topic is coalesced to null', done => {
sandbox.stub(element, '_changeChanged'); sandbox.stub(element, '_changeChanged');
sandbox.stub(element.$.restAPI, 'getChangeDetail', () => { sandbox.stub(element.$.restAPI, 'getChangeDetail', () => Promise.resolve({
return Promise.resolve({ id: '123456789',
id: '123456789', labels: {},
labels: {}, current_revision: 'foo',
current_revision: 'foo', revisions: {foo: {commit: {}}},
revisions: {foo: {commit: {}}}, }));
});
});
element._getChangeDetail().then(() => { element._getChangeDetail().then(() => {
assert.isNull(element._change.topic); assert.isNull(element._change.topic);
@ -946,14 +940,12 @@ limitations under the License.
test('commit sha is populated from getChangeDetail', done => { test('commit sha is populated from getChangeDetail', done => {
sandbox.stub(element, '_changeChanged'); sandbox.stub(element, '_changeChanged');
sandbox.stub(element.$.restAPI, 'getChangeDetail', () => { sandbox.stub(element.$.restAPI, 'getChangeDetail', () => Promise.resolve({
return Promise.resolve({ id: '123456789',
id: '123456789', labels: {},
labels: {}, current_revision: 'foo',
current_revision: 'foo', revisions: {foo: {commit: {}}},
revisions: {foo: {commit: {}}}, }));
});
});
element._getChangeDetail().then(() => { element._getChangeDetail().then(() => {
assert.equal('foo', element._commitInfo.commit); assert.equal('foo', element._commitInfo.commit);
@ -963,20 +955,16 @@ limitations under the License.
test('edit is added to change', () => { test('edit is added to change', () => {
sandbox.stub(element, '_changeChanged'); sandbox.stub(element, '_changeChanged');
sandbox.stub(element.$.restAPI, 'getChangeDetail', () => { sandbox.stub(element.$.restAPI, 'getChangeDetail', () => Promise.resolve({
return Promise.resolve({ id: '123456789',
id: '123456789', labels: {},
labels: {}, current_revision: 'foo',
current_revision: 'foo', revisions: {foo: {commit: {}}},
revisions: {foo: {commit: {}}}, }));
}); sandbox.stub(element, '_getEdit', () => Promise.resolve({
}); base_patch_set_number: 1,
sandbox.stub(element, '_getEdit', () => { commit: {commit: 'bar'},
return Promise.resolve({ }));
base_patch_set_number: 1,
commit: {commit: 'bar'},
});
});
element._patchRange = {}; element._patchRange = {};
return element._getChangeDetail().then(() => { return element._getChangeDetail().then(() => {
@ -1097,12 +1085,8 @@ limitations under the License.
}); });
test('revert dialog opened with revert param', done => { test('revert dialog opened with revert param', done => {
sandbox.stub(element.$.restAPI, 'getLoggedIn', () => { sandbox.stub(element.$.restAPI, 'getLoggedIn', () => Promise.resolve(true));
return Promise.resolve(true); sandbox.stub(Gerrit, 'awaitPluginsLoaded', () => Promise.resolve());
});
sandbox.stub(Gerrit, 'awaitPluginsLoaded', () => {
return Promise.resolve();
});
element._patchRange = { element._patchRange = {
basePatchNum: 'PARENT', basePatchNum: 'PARENT',
@ -1173,7 +1157,7 @@ limitations under the License.
setup(() => { setup(() => {
sandbox.stub(element.$.replyDialog, '_draftChanged'); sandbox.stub(element.$.replyDialog, '_draftChanged');
sandbox.stub(element.$.replyDialog, 'fetchChangeUpdates', sandbox.stub(element.$.replyDialog, 'fetchChangeUpdates',
() => { return Promise.resolve({isLatest: true}); }); () => Promise.resolve({isLatest: true}));
element._change = {labels: {}}; element._change = {labels: {}};
}); });
@ -1222,7 +1206,7 @@ limitations under the License.
suite('commit message expand/collapse', () => { suite('commit message expand/collapse', () => {
setup(() => { setup(() => {
sandbox.stub(element, 'fetchChangeUpdates', sandbox.stub(element, 'fetchChangeUpdates',
() => { return Promise.resolve({isLatest: false}); }); () => Promise.resolve({isLatest: false}));
}); });
test('commitCollapseToggle hidden for short commit message', () => { test('commitCollapseToggle hidden for short commit message', () => {
@ -1260,7 +1244,7 @@ limitations under the License.
sandbox.stub(element, '_getOffsetHeight', () => 50); sandbox.stub(element, '_getOffsetHeight', () => 50);
sandbox.stub(element, '_getScrollHeight', () => 60); sandbox.stub(element, '_getScrollHeight', () => 60);
sandbox.stub(element, '_getLineHeight', () => 5); sandbox.stub(element, '_getLineHeight', () => 5);
sandbox.stub(window, 'matchMedia', () => ({matches: true})); sandbox.stub(window, 'matchMedia', () => { return {matches: true}; });
element.$.relatedChanges.dispatchEvent( element.$.relatedChanges.dispatchEvent(
new CustomEvent('new-section-loaded')); new CustomEvent('new-section-loaded'));
assert.isTrue(element.$.relatedChangesToggle.classList assert.isTrue(element.$.relatedChangesToggle.classList
@ -1275,7 +1259,7 @@ limitations under the License.
sandbox.stub(element, '_getOffsetHeight', () => 50); sandbox.stub(element, '_getOffsetHeight', () => 50);
sandbox.stub(element, '_getScrollHeight', () => 40); sandbox.stub(element, '_getScrollHeight', () => 40);
sandbox.stub(element, '_getLineHeight', () => 5); sandbox.stub(element, '_getLineHeight', () => 5);
sandbox.stub(window, 'matchMedia', () => ({matches: true})); sandbox.stub(window, 'matchMedia', () => { return {matches: true}; });
element.$.relatedChanges.dispatchEvent( element.$.relatedChanges.dispatchEvent(
new CustomEvent('new-section-loaded')); new CustomEvent('new-section-loaded'));
assert.isFalse(element.$.relatedChangesToggle.classList assert.isFalse(element.$.relatedChangesToggle.classList
@ -1285,7 +1269,7 @@ limitations under the License.
test('relatedChangesToggle functions', () => { test('relatedChangesToggle functions', () => {
sandbox.stub(element, '_getOffsetHeight', () => 50); sandbox.stub(element, '_getOffsetHeight', () => 50);
sandbox.stub(window, 'matchMedia', () => ({matches: false})); sandbox.stub(window, 'matchMedia', () => { return {matches: false}; });
element._relatedChangesLoading = false; element._relatedChangesLoading = false;
assert.isTrue(element._relatedChangesCollapsed); assert.isTrue(element._relatedChangesCollapsed);
assert.isTrue( assert.isTrue(
@ -1299,7 +1283,7 @@ limitations under the License.
test('_updateRelatedChangeMaxHeight without commit toggle', () => { test('_updateRelatedChangeMaxHeight without commit toggle', () => {
sandbox.stub(element, '_getOffsetHeight', () => 50); sandbox.stub(element, '_getOffsetHeight', () => 50);
sandbox.stub(element, '_getLineHeight', () => 12); sandbox.stub(element, '_getLineHeight', () => 12);
sandbox.stub(window, 'matchMedia', () => ({matches: false})); sandbox.stub(window, 'matchMedia', () => { return {matches: false}; });
// 50 (existing height) - 30 (extra height) = 20 (adjusted height). // 50 (existing height) - 30 (extra height) = 20 (adjusted height).
// 20 (max existing height) % 12 (line height) = 6 (remainder). // 20 (max existing height) % 12 (line height) = 6 (remainder).
@ -1316,7 +1300,7 @@ limitations under the License.
element._latestCommitMessage = _.times(31, String).join('\n'); element._latestCommitMessage = _.times(31, String).join('\n');
sandbox.stub(element, '_getOffsetHeight', () => 50); sandbox.stub(element, '_getOffsetHeight', () => 50);
sandbox.stub(element, '_getLineHeight', () => 12); sandbox.stub(element, '_getLineHeight', () => 12);
sandbox.stub(window, 'matchMedia', () => ({matches: false})); sandbox.stub(window, 'matchMedia', () => { return {matches: false}; });
// 50 (existing height) % 12 (line height) = 2 (remainder). // 50 (existing height) % 12 (line height) = 2 (remainder).
// 50 (existing height) - 2 (remainder) = 48 (max height to set). // 50 (existing height) - 2 (remainder) = 48 (max height to set).
@ -1332,7 +1316,7 @@ limitations under the License.
element._latestCommitMessage = _.times(31, String).join('\n'); element._latestCommitMessage = _.times(31, String).join('\n');
sandbox.stub(element, '_getOffsetHeight', () => 50); sandbox.stub(element, '_getOffsetHeight', () => 50);
sandbox.stub(element, '_getLineHeight', () => 12); sandbox.stub(element, '_getLineHeight', () => 12);
sandbox.stub(window, 'matchMedia', () => ({matches: true})); sandbox.stub(window, 'matchMedia', () => { return {matches: true}; });
element._updateRelatedChangeMaxHeight(); element._updateRelatedChangeMaxHeight();
@ -1383,7 +1367,7 @@ limitations under the License.
test('_startUpdateCheckTimer up-to-date', () => { test('_startUpdateCheckTimer up-to-date', () => {
sandbox.stub(element, 'fetchChangeUpdates', sandbox.stub(element, 'fetchChangeUpdates',
() => { return Promise.resolve({isLatest: true}); }); () => Promise.resolve({isLatest: true}));
element._serverConfig = {change: {update_delay: 12345}}; element._serverConfig = {change: {update_delay: 12345}};
@ -1394,7 +1378,7 @@ limitations under the License.
test('_startUpdateCheckTimer out-of-date shows an alert', done => { test('_startUpdateCheckTimer out-of-date shows an alert', done => {
sandbox.stub(element, 'fetchChangeUpdates', sandbox.stub(element, 'fetchChangeUpdates',
() => { return Promise.resolve({isLatest: false}); }); () => Promise.resolve({isLatest: false}));
element.addEventListener('show-alert', e => { element.addEventListener('show-alert', e => {
assert.equal(e.detail.message, assert.equal(e.detail.message,
'A newer patch set has been uploaded'); 'A newer patch set has been uploaded');
@ -1738,8 +1722,9 @@ limitations under the License.
Gerrit.install( Gerrit.install(
p => { p => {
plugin = p; plugin = p;
plugin.hook('change-view-integration').getLastAttached().then( plugin.hook('change-view-integration').getLastAttached()
el => hookEl = el); .then(
el => hookEl = el);
}, },
'0.1', '0.1',
'http://some/plugins/url.html'); 'http://some/plugins/url.html');

View File

@ -153,15 +153,17 @@ limitations under the License.
test('_getRecentChanges', () => { test('_getRecentChanges', () => {
sandbox.spy(element, '_getRecentChanges'); sandbox.spy(element, '_getRecentChanges');
return element._getRecentChanges().then(() => { return element._getRecentChanges()
assert.deepEqual(element._recentChanges, recentChanges); .then(() => {
assert.equal(element.$.restAPI.getChanges.callCount, 1); assert.deepEqual(element._recentChanges, recentChanges);
// When called a second time, should not re-request recent changes. assert.equal(element.$.restAPI.getChanges.callCount, 1);
element._getRecentChanges(); // When called a second time, should not re-request recent changes.
}).then(() => { element._getRecentChanges();
assert.equal(element._getRecentChanges.callCount, 2); })
assert.equal(element.$.restAPI.getChanges.callCount, 1); .then(() => {
}); assert.equal(element._getRecentChanges.callCount, 2);
assert.equal(element.$.restAPI.getChanges.callCount, 1);
});
}); });
test('_filterChanges', () => { test('_filterChanges', () => {

View File

@ -201,7 +201,8 @@
this.set(['change', 'revisions', sha, 'description'], desc); this.set(['change', 'revisions', sha, 'description'], desc);
this._patchsetDescription = desc; this._patchsetDescription = desc;
} }
}).catch(err => { })
.catch(err => {
if (target) { target.disabled = false; } if (target) { target.disabled = false; }
return; return;
}); });

View File

@ -133,35 +133,37 @@ limitations under the License.
// Simulate tapping the remove button, but call function directly so that // Simulate tapping the remove button, but call function directly so that
// can determine what happens after the promise is resolved. // can determine what happens after the promise is resolved.
return element._handleDescriptionRemoved().then(() => { return element._handleDescriptionRemoved()
// The API stub should be called with an empty string for the new .then(() => {
// description. // The API stub should be called with an empty string for the new
assert.equal(putDescStub.lastCall.args[2], ''); // description.
assert.equal(element.change.revisions.rev1.description, ''); assert.equal(putDescStub.lastCall.args[2], '');
assert.equal(element.change.revisions.rev1.description, '');
flushAsynchronousOperations(); flushAsynchronousOperations();
// The editable label should now be visible and the chip hidden. // The editable label should now be visible and the chip hidden.
label = Polymer.dom(element.root).querySelector('#descriptionLabel'); label = Polymer.dom(element.root).querySelector('#descriptionLabel');
assert.isOk(label); assert.isOk(label);
assert.equal(getComputedStyle(chip).display, 'none'); assert.equal(getComputedStyle(chip).display, 'none');
assert.notEqual(getComputedStyle(label).display, 'none'); assert.notEqual(getComputedStyle(label).display, 'none');
assert.isFalse(label.readOnly); assert.isFalse(label.readOnly);
// Edit the label to have a new value of test2, and save. // Edit the label to have a new value of test2, and save.
label.editing = true; label.editing = true;
label._inputText = 'test2'; label._inputText = 'test2';
label._save(); label._save();
flushAsynchronousOperations(); flushAsynchronousOperations();
// The API stub should be called with an `test2` for the new // The API stub should be called with an `test2` for the new
// description. // description.
assert.equal(putDescStub.callCount, 2); assert.equal(putDescStub.callCount, 2);
assert.equal(putDescStub.lastCall.args[2], 'test2'); assert.equal(putDescStub.lastCall.args[2], 'test2');
}).then(() => { })
flushAsynchronousOperations(); .then(() => {
// The chip should be visible again, and the label hidden. flushAsynchronousOperations();
assert.equal(element.change.revisions.rev1.description, 'test2'); // The chip should be visible again, and the label hidden.
assert.equal(getComputedStyle(label).display, 'none'); assert.equal(element.change.revisions.rev1.description, 'test2');
assert.notEqual(getComputedStyle(chip).display, 'none'); assert.equal(getComputedStyle(label).display, 'none');
}); assert.notEqual(getComputedStyle(chip).display, 'none');
});
}); });
test('expandAllDiffs called when expand button clicked', () => { test('expandAllDiffs called when expand button clicked', () => {

View File

@ -297,15 +297,15 @@
promises.push(this._getFiles().then(filesByPath => { promises.push(this._getFiles().then(filesByPath => {
this._filesByPath = filesByPath; this._filesByPath = filesByPath;
})); }));
promises.push(this._getLoggedIn().then(loggedIn => { promises.push(this._getLoggedIn()
return this._loggedIn = loggedIn; .then(loggedIn => this._loggedIn = loggedIn)
}).then(loggedIn => { .then(loggedIn => {
if (!loggedIn) { return; } if (!loggedIn) { return; }
return this._getReviewedFiles().then(reviewed => { return this._getReviewedFiles().then(reviewed => {
this._reviewed = reviewed; this._reviewed = reviewed;
}); });
})); }));
promises.push(this._getDiffPreferences().then(prefs => { promises.push(this._getDiffPreferences().then(prefs => {
this.diffPrefs = prefs; this.diffPrefs = prefs;
@ -1063,30 +1063,28 @@
return (new Promise(resolve => { return (new Promise(resolve => {
this.fire('reload-drafts', {resolve}); this.fire('reload-drafts', {resolve});
})).then(() => { })).then(() => this.asyncForeach(paths, (path, cancel) => {
return this.asyncForeach(paths, (path, cancel) => { this._cancelForEachDiff = cancel;
this._cancelForEachDiff = cancel;
iter++; iter++;
console.log('Expanding diff', iter, 'of', initialCount, ':', console.log('Expanding diff', iter, 'of', initialCount, ':',
path); path);
const diffElem = this._findDiffByPath(path, diffElements); const diffElem = this._findDiffByPath(path, diffElements);
diffElem.comments = this.changeComments.getCommentsBySideForPath( diffElem.comments = this.changeComments.getCommentsBySideForPath(
path, this.patchRange, this.projectConfig); path, this.patchRange, this.projectConfig);
const promises = [diffElem.reload()]; const promises = [diffElem.reload()];
if (this._loggedIn && !this.diffPrefs.manual_review) { if (this._loggedIn && !this.diffPrefs.manual_review) {
promises.push(this._reviewFile(path, true)); promises.push(this._reviewFile(path, true));
} }
return Promise.all(promises); return Promise.all(promises);
}).then(() => { }).then(() => {
this._cancelForEachDiff = null; this._cancelForEachDiff = null;
this._nextRenderParams = null; this._nextRenderParams = null;
console.log('Finished expanding', initialCount, 'diff(s)'); console.log('Finished expanding', initialCount, 'diff(s)');
this.$.reporting.timeEndWithAverage(EXPAND_ALL_TIMING_LABEL, this.$.reporting.timeEndWithAverage(EXPAND_ALL_TIMING_LABEL,
EXPAND_ALL_AVG_TIMING_LABEL, initialCount); EXPAND_ALL_AVG_TIMING_LABEL, initialCount);
this.$.diffCursor.handleDiffUpdate(); this.$.diffCursor.handleDiffUpdate();
}); }));
});
} }
/** Cancel the rendering work of every diff in the list */ /** Cancel the rendering work of every diff in the list */
@ -1141,9 +1139,9 @@
// comments due to use in the _handleCommentUpdate function. // comments due to use in the _handleCommentUpdate function.
// The comment thread already has a side associated with it, so // The comment thread already has a side associated with it, so
// set the comment's side to match. // set the comment's side to match.
threadEl.comments = newComments.map(c => { threadEl.comments = newComments.map(c => Object.assign(
return Object.assign(c, {__commentSide: threadEl.commentSide}); c, {__commentSide: threadEl.commentSide}
}); ));
Polymer.dom.flush(); Polymer.dom.flush();
return; return;
} }

View File

@ -115,7 +115,7 @@ limitations under the License.
patchNum: '2', patchNum: '2',
}; };
saveStub = sandbox.stub(element, '_saveReviewedState', saveStub = sandbox.stub(element, '_saveReviewedState',
() => { return Promise.resolve(); }); () => Promise.resolve());
}); });
teardown(() => { teardown(() => {
@ -686,7 +686,7 @@ limitations under the License.
}); });
test('r key toggles reviewed flag', () => { test('r key toggles reviewed flag', () => {
const reducer = (accum, file) => file.isReviewed ? ++accum : accum; const reducer = (accum, file) => (file.isReviewed ? ++accum : accum);
const getNumReviewed = () => element._files.reduce(reducer, 0); const getNumReviewed = () => element._files.reduce(reducer, 0);
flushAsynchronousOperations(); flushAsynchronousOperations();
@ -865,7 +865,8 @@ limitations under the License.
// Click inside the diff. This should result in no additional calls to // Click inside the diff. This should result in no additional calls to
// _togglePathExpanded or _reviewFile. // _togglePathExpanded or _reviewFile.
Polymer.dom(element.root).querySelector('gr-diff-host').click(); Polymer.dom(element.root).querySelector('gr-diff-host')
.click();
assert.isTrue(clickSpy.calledTwice); assert.isTrue(clickSpy.calledTwice);
assert.isTrue(toggleExpandSpy.calledOnce); assert.isTrue(toggleExpandSpy.calledOnce);
assert.isFalse(reviewStub.called); assert.isFalse(reviewStub.called);
@ -1476,9 +1477,7 @@ limitations under the License.
basePatchNum: 'PARENT', basePatchNum: 'PARENT',
patchNum: '2', patchNum: '2',
}; };
sandbox.stub(window, 'fetch', () => { sandbox.stub(window, 'fetch', () => Promise.resolve());
return Promise.resolve();
});
flushAsynchronousOperations(); flushAsynchronousOperations();
}); });

View File

@ -97,12 +97,13 @@
const labelsObj = labelRecord.base; const labelsObj = labelRecord.base;
if (!labelsObj) { return []; } if (!labelsObj) { return []; }
return Object.keys(labelsObj).sort().map(key => { return Object.keys(labelsObj).sort()
return { .map(key => {
name: key, return {
value: this._getVoteForAccount(labelsObj, key, this.account), name: key,
}; value: this._getVoteForAccount(labelsObj, key, this.account),
}); };
});
} }
_computeColumns(permittedLabels) { _computeColumns(permittedLabels) {
@ -114,9 +115,7 @@
} }
} }
const orderedValues = Object.keys(values).sort((a, b) => { const orderedValues = Object.keys(values).sort((a, b) => a - b);
return a - b;
});
for (let i = 0; i < orderedValues.length; i++) { for (let i = 0; i < orderedValues.length; i++) {
values[orderedValues[i]] = i; values[orderedValues[i]] = i;

View File

@ -207,7 +207,7 @@
return scoresRaw.split(' ') return scoresRaw.split(' ')
.map(s => s.match(LABEL_TITLE_SCORE_PATTERN)) .map(s => s.match(LABEL_TITLE_SCORE_PATTERN))
.filter(ms => ms && ms.length === 3) .filter(ms => ms && ms.length === 3)
.map(ms => ({label: ms[1], value: ms[2]})); .map(ms => { return {label: ms[1], value: ms[2]}; });
} }
_computeScoreClass(score, labelExtremes) { _computeScoreClass(score, labelExtremes) {

View File

@ -324,9 +324,7 @@
} }
_getHumanMessages(messages) { _getHumanMessages(messages) {
return messages.filter(msg => { return messages.filter(msg => !this._isAutomated(msg));
return !this._isAutomated(msg);
});
} }
_computeShowHideTextHidden(visibleMessages, messages, _computeShowHideTextHidden(visibleMessages, messages,

View File

@ -354,7 +354,7 @@
changeRevision = rev; changeRevision = rev;
} }
} }
const commits = relatedChanges.map(c => { return c.commit; }); const commits = relatedChanges.map(c => c.commit);
let pos = commits.length - 1; let pos = commits.length - 1;
while (pos >= 0) { while (pos >= 0) {

View File

@ -474,28 +474,31 @@
this.disabled = true; this.disabled = true;
const errFn = this._handle400Error.bind(this); const errFn = this._handle400Error.bind(this);
return this._saveReview(obj, errFn).then(response => { return this._saveReview(obj, errFn)
if (!response) { .then(response => {
// Null or undefined response indicates that an error handler if (!response) {
// took responsibility, so just return. // Null or undefined response indicates that an error handler
return {}; // took responsibility, so just return.
} return {};
if (!response.ok) { }
this.fire('server-error', {response}); if (!response.ok) {
return {}; this.fire('server-error', {response});
} return {};
}
this.draft = ''; this.draft = '';
this._includeComments = true; this._includeComments = true;
this.fire('send', null, {bubbles: false}); this.fire('send', null, {bubbles: false});
return accountAdditions; return accountAdditions;
}).then(result => { })
this.disabled = false; .then(result => {
return result; this.disabled = false;
}).catch(err => { return result;
this.disabled = false; })
throw err; .catch(err => {
}); this.disabled = false;
throw err;
});
} }
_focusOn(section) { _focusOn(section) {

View File

@ -136,23 +136,24 @@ limitations under the License.
}); });
function stubSaveReview(jsonResponseProducer) { function stubSaveReview(jsonResponseProducer) {
return sandbox.stub(element, '_saveReview', review => { return sandbox.stub(
return new Promise((resolve, reject) => { element,
try { '_saveReview',
const result = jsonResponseProducer(review) || {}; review => new Promise((resolve, reject) => {
const resultStr = try {
element.$.restAPI.JSON_PREFIX + JSON.stringify(result); const result = jsonResponseProducer(review) || {};
resolve({ const resultStr =
ok: true, element.$.restAPI.JSON_PREFIX + JSON.stringify(result);
text() { resolve({
return Promise.resolve(resultStr); ok: true,
}, text() {
}); return Promise.resolve(resultStr);
} catch (err) { },
reject(err); });
} } catch (err) {
}); reject(err);
}); }
}));
} }
test('default to publishing drafts with reply', done => { test('default to publishing drafts with reply', done => {
@ -271,7 +272,8 @@ limitations under the License.
test('getlabelValue when no score is selected', done => { test('getlabelValue when no score is selected', done => {
flush(() => { flush(() => {
element.$$('gr-label-scores') element.$$('gr-label-scores')
.$$(`gr-label-score-row[name="Code-Review"]`).setSelectedValue(-1); .$$(`gr-label-score-row[name="Code-Review"]`)
.setSelectedValue(-1);
assert.strictEqual(element.getLabelValue('Verified'), ' 0'); assert.strictEqual(element.getLabelValue('Verified'), ' 0');
done(); done();
}); });
@ -372,73 +374,87 @@ limitations under the License.
element._pendingConfirmationDetails); element._pendingConfirmationDetails);
} }
observer.then(() => { observer
assert.isTrue(isVisible(element.$.reviewerConfirmationOverlay)); .then(() => {
observer = overlayObserver('closed'); assert.isTrue(isVisible(element.$.reviewerConfirmationOverlay));
const expected = 'Group name has 10 members'; observer = overlayObserver('closed');
assert.notEqual( const expected = 'Group name has 10 members';
element.$.reviewerConfirmationOverlay.innerText.indexOf(expected), assert.notEqual(
-1); element.$.reviewerConfirmationOverlay.innerText
MockInteractions.tap(noButton); // close the overlay .indexOf(expected),
return observer; -1);
}).then(() => { MockInteractions.tap(noButton); // close the overlay
assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay)); return observer;
}).then(() => {
assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay));
// We should be focused on account entry input. // We should be focused on account entry input.
assert.isTrue( assert.isTrue(
isFocusInsideElement(element.$.reviewers.$.entry.$.input.$.input)); isFocusInsideElement(
element.$.reviewers.$.entry.$.input.$.input
)
);
// No reviewer/CC should have been added. // No reviewer/CC should have been added.
assert.equal(element.$.ccs.additions().length, 0); assert.equal(element.$.ccs.additions().length, 0);
assert.equal(element.$.reviewers.additions().length, 0); assert.equal(element.$.reviewers.additions().length, 0);
// Reopen confirmation dialog. // Reopen confirmation dialog.
observer = overlayObserver('opened'); observer = overlayObserver('opened');
if (cc) { if (cc) {
element._ccPendingConfirmation = { element._ccPendingConfirmation = {
group, group,
count: 10, count: 10,
}; };
} else { } else {
element._reviewerPendingConfirmation = { element._reviewerPendingConfirmation = {
group, group,
count: 10, count: 10,
}; };
} }
return observer; return observer;
}).then(() => { })
assert.isTrue(isVisible(element.$.reviewerConfirmationOverlay)); .then(() => {
observer = overlayObserver('closed'); assert.isTrue(isVisible(element.$.reviewerConfirmationOverlay));
MockInteractions.tap(yesButton); // Confirm the group. observer = overlayObserver('closed');
return observer; MockInteractions.tap(yesButton); // Confirm the group.
}).then(() => { return observer;
assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay)); })
const additions = cc ? .then(() => {
element.$.ccs.additions() : assert.isFalse(isVisible(element.$.reviewerConfirmationOverlay));
element.$.reviewers.additions(); const additions = cc ?
assert.deepEqual( element.$.ccs.additions() :
additions, element.$.reviewers.additions();
[ assert.deepEqual(
{ additions,
group: { [
id: 'id', {
name: 'name', group: {
confirmed: true, id: 'id',
_group: true, name: 'name',
_pendingAdd: true, confirmed: true,
}, _group: true,
}, _pendingAdd: true,
]); },
},
]);
// We should be focused on account entry input. // We should be focused on account entry input.
if (cc) { if (cc) {
assert.isTrue( assert.isTrue(
isFocusInsideElement(element.$.ccs.$.entry.$.input.$.input)); isFocusInsideElement(
} else { element.$.ccs.$.entry.$.input.$.input
assert.isTrue( )
isFocusInsideElement(element.$.reviewers.$.entry.$.input.$.input)); );
} } else {
}).then(done); assert.isTrue(
isFocusInsideElement(
element.$.reviewers.$.entry.$.input.$.input
)
);
}
})
.then(done);
} }
test('cc confirmation', done => { test('cc confirmation', done => {
@ -673,7 +689,8 @@ limitations under the License.
// fail. // fail.
element.$$('gr-label-scores').$$( element.$$('gr-label-scores').$$(
'gr-label-score-row[name="Verified"]').setSelectedValue(-1); 'gr-label-score-row[name="Verified"]')
.setSelectedValue(-1);
MockInteractions.tap(element.$$('.send')); MockInteractions.tap(element.$$('.send'));
}); });
}); });
@ -967,9 +984,10 @@ limitations under the License.
let startReviewStub; let startReviewStub;
setup(() => { setup(() => {
startReviewStub = sandbox.stub(element.$.restAPI, 'startReview', () => { startReviewStub = sandbox.stub(
return Promise.resolve(); element.$.restAPI,
}); 'startReview',
() => Promise.resolve());
}); });
test('ready property in review input on start review', () => { test('ready property in review input on start review', () => {

View File

@ -102,10 +102,12 @@
*/ */
_permittedLabelsToNumericScores(labels) { _permittedLabelsToNumericScores(labels) {
if (!labels) return []; if (!labels) return [];
return Object.keys(labels).map(label => ({ return Object.keys(labels).map(label => {
label, return {
scores: labels[label].map(v => parseInt(v, 10)), label,
})); scores: labels[label].map(v => parseInt(v, 10)),
};
});
} }
/** /**
@ -116,10 +118,12 @@
*/ */
_getMaxPermittedScores(change) { _getMaxPermittedScores(change) {
return this._permittedLabelsToNumericScores(change.permitted_labels) return this._permittedLabelsToNumericScores(change.permitted_labels)
.map(({label, scores}) => ({ .map(({label, scores}) => {
[label]: scores return {
.map(v => parseInt(v, 10)) [label]: scores
.reduce((a, b) => Math.max(a, b))})) .map(v => parseInt(v, 10))
.reduce((a, b) => Math.max(a, b))};
})
.reduce((acc, i) => Object.assign(acc, i), {}); .reduce((acc, i) => Object.assign(acc, i), {});
} }
@ -189,9 +193,8 @@
result = result.concat(reviewers[key]); result = result.concat(reviewers[key]);
} }
} }
this._reviewers = result.filter(reviewer => { this._reviewers = result
return reviewer._account_id != owner._account_id; .filter(reviewer => reviewer._account_id != owner._account_id);
});
// If there is one or two more than the max reviewers, don't show the // If there is one or two more than the max reviewers, don't show the
// 'show more' button, because it takes up just as much space. // 'show more' button, because it takes up just as much space.
@ -249,10 +252,11 @@
} }
} }
} }
}).catch(err => { })
this.disabled = false; .catch(err => {
throw err; this.disabled = false;
}); throw err;
});
} }
_handleAddTap(e) { _handleAddTap(e) {

View File

@ -67,16 +67,18 @@
attached() { attached() {
super.attached(); super.attached();
this.$.restAPI.getLoggedIn().then(loggedIn => { this.$.restAPI.getLoggedIn()
if (loggedIn) { .then(loggedIn => {
return this.$.restAPI.getPreferences(); if (loggedIn) {
} return this.$.restAPI.getPreferences();
}).then(prefs => { }
if (prefs) { })
this._preferredDownloadCommand = prefs.download_command; .then(prefs => {
this._preferredDownloadScheme = prefs.download_scheme; if (prefs) {
} this._preferredDownloadCommand = prefs.download_command;
}); this._preferredDownloadScheme = prefs.download_scheme;
}
});
} }
_handleCloseTap(e) { _handleCloseTap(e) {

View File

@ -102,9 +102,9 @@
} }
_interpolateUrl(url, replacements) { _interpolateUrl(url, replacements) {
return url.replace(INTERPOLATE_URL_PATTERN, (match, p1) => { return url.replace(
return replacements[p1] || ''; INTERPOLATE_URL_PATTERN,
}); (match, p1) => replacements[p1] || '');
} }
_accountName(account) { _accountName(account) {

View File

@ -107,7 +107,7 @@ limitations under the License.
test('show normal Error', done => { test('show normal Error', done => {
const showErrorStub = sandbox.stub(element, '_showErrorDialog'); const showErrorStub = sandbox.stub(element, '_showErrorDialog');
const textSpy = sandbox.spy(() => { return Promise.resolve('ZOMG'); }); const textSpy = sandbox.spy(() => Promise.resolve('ZOMG'));
element.fire('server-error', {response: {status: 500, text: textSpy}}); element.fire('server-error', {response: {status: 500, text: textSpy}});
assert.isTrue(textSpy.called); assert.isTrue(textSpy.called);
@ -129,8 +129,9 @@ limitations under the License.
'Error 409'); 'Error 409');
assert.equal(element._constructServerErrorMsg({status, url}), assert.equal(element._constructServerErrorMsg({status, url}),
'Error 409: \nEndpoint: /my/test/url'); 'Error 409: \nEndpoint: /my/test/url');
assert.equal(element._constructServerErrorMsg({status, statusText, url}), assert.equal(element.
'Error 409 (Conflict): \nEndpoint: /my/test/url'); _constructServerErrorMsg({status, statusText, url}),
'Error 409 (Conflict): \nEndpoint: /my/test/url');
assert.equal(element._constructServerErrorMsg({ assert.equal(element._constructServerErrorMsg({
status, status,
statusText, statusText,
@ -142,9 +143,9 @@ limitations under the License.
test('suppress TOO_MANY_FILES error', done => { test('suppress TOO_MANY_FILES error', done => {
const showAlertStub = sandbox.stub(element, '_showAlert'); const showAlertStub = sandbox.stub(element, '_showAlert');
const textSpy = sandbox.spy(() => { const textSpy = sandbox.spy(
return Promise.resolve('too many files to find conflicts'); () => Promise.resolve('too many files to find conflicts')
}); );
element.fire('server-error', {response: {status: 500, text: textSpy}}); element.fire('server-error', {response: {status: 500, text: textSpy}});
assert.isTrue(textSpy.called); assert.isTrue(textSpy.called);
@ -172,7 +173,7 @@ limitations under the License.
// starts with authed state // starts with authed state
element.$.restAPI.getLoggedIn(); element.$.restAPI.getLoggedIn();
const refreshStub = sandbox.stub(element.$.restAPI, 'getAccount', const refreshStub = sandbox.stub(element.$.restAPI, 'getAccount',
() => { return Promise.resolve({}); }); () => Promise.resolve({}));
const toastSpy = sandbox.spy(element, '_createToastAlert'); const toastSpy = sandbox.spy(element, '_createToastAlert');
const windowOpen = sandbox.stub(window, 'open'); const windowOpen = sandbox.stub(window, 'open');
const responseText = Promise.resolve('Authentication required\n'); const responseText = Promise.resolve('Authentication required\n');
@ -297,7 +298,10 @@ limitations under the License.
test('show-error', () => { test('show-error', () => {
const openStub = sandbox.stub(element.$.errorOverlay, 'open'); const openStub = sandbox.stub(element.$.errorOverlay, 'open');
const closeStub = sandbox.stub(element.$.errorOverlay, 'close'); const closeStub = sandbox.stub(element.$.errorOverlay, 'close');
const reportStub = sandbox.stub(element.$.reporting, 'reportErrorDialog'); const reportStub = sandbox.stub(
element.$.reporting,
'reportErrorDialog'
);
const message = 'test message'; const message = 'test message';
element.fire('show-error', {message}); element.fire('show-error', {message});
@ -317,7 +321,9 @@ limitations under the License.
const accountPromise = Promise.resolve({_account_id: 1234}); const accountPromise = Promise.resolve({_account_id: 1234});
sandbox.stub(element.$.restAPI, 'getAccount') sandbox.stub(element.$.restAPI, 'getAccount')
.returns(accountPromise); .returns(accountPromise);
const requestCheckStub = sandbox.stub(element, '_requestCheckLoggedIn'); const requestCheckStub = sandbox.stub(
element,
'_requestCheckLoggedIn');
const handleRefreshStub = sandbox.stub(element, const handleRefreshStub = sandbox.stub(element,
'_handleCredentialRefreshed'); '_handleCredentialRefreshed');
const reloadStub = sandbox.stub(element, '_reloadPage'); const reloadStub = sandbox.stub(element, '_reloadPage');
@ -344,7 +350,9 @@ limitations under the License.
}); });
test('refresh loop continues on credential fail', done => { test('refresh loop continues on credential fail', done => {
const requestCheckStub = sandbox.stub(element, '_requestCheckLoggedIn'); const requestCheckStub = sandbox.stub(
element,
'_requestCheckLoggedIn');
const handleRefreshStub = sandbox.stub(element, const handleRefreshStub = sandbox.stub(element,
'_handleCredentialRefreshed'); '_handleCredentialRefreshed');
const reloadStub = sandbox.stub(element, '_reloadPage'); const reloadStub = sandbox.stub(element, '_reloadPage');

View File

@ -231,10 +231,10 @@
const topMenuLinks = []; const topMenuLinks = [];
links.forEach(link => { topMenuLinks[link.title] = link.links; }); links.forEach(link => { topMenuLinks[link.title] = link.links; });
for (const m of topMenus) { for (const m of topMenus) {
const items = m.items.map(this._fixCustomMenuItem).filter(link => { const items = m.items.map(this._fixCustomMenuItem).filter(link =>
// Ignore GWT project links // Ignore GWT project links
return !link.url.includes('${projectName}'); !link.url.includes('${projectName}')
}); );
if (m.name in topMenuLinks) { if (m.name in topMenuLinks) {
items.forEach(link => { topMenuLinks[m.name].push(link); }); items.forEach(link => { topMenuLinks[m.name].push(link); });
} else { } else {

View File

@ -634,7 +634,8 @@
* @return {!string} Everything after the first '#' ("a#b#c" -> "b#c"). * @return {!string} Everything after the first '#' ("a#b#c" -> "b#c").
*/ */
_getHashFromCanonicalPath(canonicalPath) { _getHashFromCanonicalPath(canonicalPath) {
return canonicalPath.split('#').slice(1).join('#'); return canonicalPath.split('#').slice(1)
.join('#');
} }
_parseLineAddress(hash) { _parseLineAddress(hash) {

View File

@ -74,7 +74,7 @@ limitations under the License.
test('_getChangeWeblinks', () => { test('_getChangeWeblinks', () => {
const link = {name: 'test', url: 'test/url'}; const link = {name: 'test', url: 'test/url'};
const browserLink = {name: 'browser', url: 'browser/url'}; const browserLink = {name: 'browser', url: 'browser/url'};
const mapLinksToConfig = weblinks => ({options: {weblinks}}); const mapLinksToConfig = weblinks => { return {options: {weblinks}}; };
sandbox.stub(element, '_getBrowseCommitWeblink').returns(browserLink); sandbox.stub(element, '_getBrowseCommitWeblink').returns(browserLink);
assert.deepEqual( assert.deepEqual(

View File

@ -200,9 +200,7 @@
const trimmedInput = this._inputVal && this._inputVal.trim(); const trimmedInput = this._inputVal && this._inputVal.trim();
if (trimmedInput) { if (trimmedInput) {
const predefinedOpOnlyQuery = SEARCH_OPERATORS_WITH_NEGATIONS.some( const predefinedOpOnlyQuery = SEARCH_OPERATORS_WITH_NEGATIONS.some(
op => { op => op.endsWith(':') && op === trimmedInput
return op.endsWith(':') && op === trimmedInput;
}
); );
if (predefinedOpOnlyQuery) { if (predefinedOpOnlyQuery) {
return; return;
@ -252,7 +250,7 @@
default: default:
return Promise.resolve(SEARCH_OPERATORS_WITH_NEGATIONS return Promise.resolve(SEARCH_OPERATORS_WITH_NEGATIONS
.filter(operator => operator.includes(input)) .filter(operator => operator.includes(input))
.map(operator => ({text: operator}))); .map(operator => { return {text: operator}; }));
} }
} }

View File

@ -59,11 +59,9 @@ limitations under the License.
assert.equal(element._inputVal, 'foo'); assert.equal(element._inputVal, 'foo');
}); });
getActiveElement = () => { getActiveElement = () => (document.activeElement.shadowRoot ?
return document.activeElement.shadowRoot ? document.activeElement.shadowRoot.activeElement :
document.activeElement.shadowRoot.activeElement : document.activeElement);
document.activeElement;
};
test('enter in search input fires event', done => { test('enter in search input fires event', done => {
element.addEventListener('handle-search', () => { element.addEventListener('handle-search', () => {

View File

@ -91,7 +91,7 @@
.then(projects => { .then(projects => {
if (!projects) { return []; } if (!projects) { return []; }
const keys = Object.keys(projects); const keys = Object.keys(projects);
return keys.map(key => ({text: predicate + ':' + key})); return keys.map(key => { return {text: predicate + ':' + key}; });
}); });
} }
@ -113,7 +113,7 @@
.then(groups => { .then(groups => {
if (!groups) { return []; } if (!groups) { return []; }
const keys = Object.keys(groups); const keys = Object.keys(groups);
return keys.map(key => ({text: predicate + ':' + key})); return keys.map(key => { return {text: predicate + ':' + key}; });
}); });
} }
@ -135,7 +135,8 @@
.then(accounts => { .then(accounts => {
if (!accounts) { return []; } if (!accounts) { return []; }
return this._mapAccountsHelper(accounts, predicate); return this._mapAccountsHelper(accounts, predicate);
}).then(accounts => { })
.then(accounts => {
// When the expression supplied is a beginning substring of 'self', // When the expression supplied is a beginning substring of 'self',
// add it as an autocomplete option. // add it as an autocomplete option.
if (SELF_EXPRESSION.startsWith(expression)) { if (SELF_EXPRESSION.startsWith(expression)) {
@ -150,12 +151,14 @@
} }
_mapAccountsHelper(accounts, predicate) { _mapAccountsHelper(accounts, predicate) {
return accounts.map(account => ({ return accounts.map(account => {
label: account.name || '', return {
text: account.email ? label: account.name || '',
`${predicate}:${account.email}` : text: account.email ?
`${predicate}:"${this._accountOrAnon(account)}"`, `${predicate}:${account.email}` :
})); `${predicate}:"${this._accountOrAnon(account)}"`,
};
});
} }
} }

View File

@ -71,12 +71,15 @@ limitations under the License.
}, },
]) ])
); );
element._fetchAccounts('owner', 's').then(s => { element._fetchAccounts('owner', 's')
assert.deepEqual(s[0], {text: 'owner:fred@goog.co', label: 'fred'}); .then(s => {
assert.deepEqual(s[1], {text: 'owner:self'}); assert.deepEqual(s[0], {text: 'owner:fred@goog.co', label: 'fred'});
}).then(() => element._fetchAccounts('owner', 'selfs')).then(s => { assert.deepEqual(s[1], {text: 'owner:self'});
assert.notEqual(s[0], {text: 'owner:self'}); })
}); .then(() => element._fetchAccounts('owner', 'selfs'))
.then(s => {
assert.notEqual(s[0], {text: 'owner:self'});
});
}); });
test('Inserts me as option when valid', () => { test('Inserts me as option when valid', () => {
@ -88,12 +91,15 @@ limitations under the License.
}, },
]) ])
); );
return element._fetchAccounts('owner', 'm').then(s => { return element._fetchAccounts('owner', 'm')
assert.deepEqual(s[0], {text: 'owner:fred@goog.co', label: 'fred'}); .then(s => {
assert.deepEqual(s[1], {text: 'owner:me'}); assert.deepEqual(s[0], {text: 'owner:fred@goog.co', label: 'fred'});
}).then(() => element._fetchAccounts('owner', 'meme')).then(s => { assert.deepEqual(s[1], {text: 'owner:me'});
assert.notEqual(s[0], {text: 'owner:me'}); })
}); .then(() => element._fetchAccounts('owner', 'meme'))
.then(s => {
assert.notEqual(s[0], {text: 'owner:me'});
});
}); });
test('Autocompletes groups', () => { test('Autocompletes groups', () => {

View File

@ -85,11 +85,13 @@
.getRobotCommentFixPreview(this.changeNum, this._patchNum, fixId) .getRobotCommentFixPreview(this.changeNum, this._patchNum, fixId)
.then(res => { .then(res => {
if (res != null) { if (res != null) {
const previews = Object.keys(res).map(key => const previews = Object.keys(res).map(key => {
({filepath: key, preview: res[key]})); return {filepath: key, preview: res[key]};
});
this._currentPreviews = previews; this._currentPreviews = previews;
} }
}).catch(err => { })
.catch(err => {
this._close(); this._close();
this.dispatchEvent(new CustomEvent('show-error', { this.dispatchEvent(new CustomEvent('show-error', {
bubbles: true, bubbles: true,
@ -175,13 +177,14 @@
this._currentFix.fix_id).then(res => { this._currentFix.fix_id).then(res => {
Gerrit.Nav.navigateToChange(this.change, 'edit', this._patchNum); Gerrit.Nav.navigateToChange(this.change, 'edit', this._patchNum);
this._close(); this._close();
}).catch(err => { })
this.dispatchEvent(new CustomEvent('show-error', { .catch(err => {
bubbles: true, this.dispatchEvent(new CustomEvent('show-error', {
composed: true, bubbles: true,
detail: {message: `Error applying fix suggestion: ${err}`}, composed: true,
})); detail: {message: `Error applying fix suggestion: ${err}`},
}); }));
});
}, },
getFixDescription(currentFix) { getFixDescription(currentFix) {

View File

@ -39,9 +39,7 @@
* file simpler by just using _reloadComments here instead. * file simpler by just using _reloadComments here instead.
*/ */
_reloadDraftsWithCallback(e) { _reloadDraftsWithCallback(e) {
return this._reloadComments().then(() => { return this._reloadComments().then(() => e.detail.resolve());
return e.detail.resolve();
});
} }
_reloadComments() { _reloadComments() {

View File

@ -362,9 +362,10 @@
}; };
ChangeComments.prototype._sortComments = function(comments) { ChangeComments.prototype._sortComments = function(comments) {
return comments.slice(0).sort((c1, c2) => { return comments.slice(0)
return util.parseDate(c1.updated) - util.parseDate(c2.updated); .sort(
}); (c1, c2) => util.parseDate(c1.updated) - util.parseDate(c2.updated)
);
}; };
/** /**

View File

@ -131,19 +131,21 @@ limitations under the License.
test('with loadAll first', done => { test('with loadAll first', done => {
assert.isNotOk(element._changeComments); assert.isNotOk(element._changeComments);
element.loadAll().then(() => { element.loadAll()
assert.isOk(element._changeComments); .then(() => {
assert.equal(commentStub.callCount, 1); assert.isOk(element._changeComments);
assert.equal(robotCommentStub.callCount, 1); assert.equal(commentStub.callCount, 1);
assert.equal(draftStub.callCount, 1); assert.equal(robotCommentStub.callCount, 1);
return element.reloadDrafts(); assert.equal(draftStub.callCount, 1);
}).then(() => { return element.reloadDrafts();
assert.isOk(element._changeComments); })
assert.equal(commentStub.callCount, 1); .then(() => {
assert.equal(robotCommentStub.callCount, 1); assert.isOk(element._changeComments);
assert.equal(draftStub.callCount, 2); assert.equal(commentStub.callCount, 1);
done(); assert.equal(robotCommentStub.callCount, 1);
}); assert.equal(draftStub.callCount, 2);
done();
});
}); });
}); });

View File

@ -230,7 +230,7 @@
GrDiffBuilder.prototype.getSectionsByLineRange = function( GrDiffBuilder.prototype.getSectionsByLineRange = function(
startLine, endLine, opt_side) { startLine, endLine, opt_side) {
return this.getGroupsByLineRange(startLine, endLine, opt_side).map( return this.getGroupsByLineRange(startLine, endLine, opt_side).map(
group => { return group.element; }); group => group.element);
}; };
GrDiffBuilder.prototype._createContextControl = function(section, line) { GrDiffBuilder.prototype._createContextControl = function(section, line) {

View File

@ -322,7 +322,8 @@ limitations under the License.
const lineNumberEl = document.createElement('td'); const lineNumberEl = document.createElement('td');
function slice(str, start, end) { function slice(str, start, end) {
return Array.from(str).slice(start, end).join(''); return Array.from(str).slice(start, end)
.join('');
} }
setup(() => { setup(() => {
@ -811,9 +812,8 @@ limitations under the License.
sandbox.stub(builder, 'addColumns'); sandbox.stub(builder, 'addColumns');
builder.buildSectionElement = function(group) { builder.buildSectionElement = function(group) {
const section = document.createElement('stub'); const section = document.createElement('stub');
section.textContent = group.lines.reduce((acc, line) => { section.textContent = group.lines
return acc + line.text; .reduce((acc, line) => acc + line.text, '');
}, '');
return section; return section;
}; };
return builder; return builder;
@ -858,7 +858,7 @@ limitations under the License.
const dispatchEventStub = sandbox.stub(element, 'dispatchEvent'); const dispatchEventStub = sandbox.stub(element, 'dispatchEvent');
element.render(keyLocations, {}).then(() => { element.render(keyLocations, {}).then(() => {
const firedEventTypes = dispatchEventStub.getCalls() const firedEventTypes = dispatchEventStub.getCalls()
.map(c => { return c.args[0].type; }); .map(c => c.args[0].type);
assert.include(firedEventTypes, 'render-start'); assert.include(firedEventTypes, 'render-start');
assert.include(firedEventTypes, 'render-content'); assert.include(firedEventTypes, 'render-content');
done(); done();

View File

@ -165,9 +165,7 @@
moveToNextChunk(opt_clipToTop) { moveToNextChunk(opt_clipToTop) {
this.$.cursorManager.next(this._isFirstRowOfChunk.bind(this), this.$.cursorManager.next(this._isFirstRowOfChunk.bind(this),
target => { target => target.parentNode.scrollHeight, opt_clipToTop);
return target.parentNode.scrollHeight;
}, opt_clipToTop);
this._fixSide(); this._fixSide();
} }
@ -273,9 +271,8 @@
} }
createCommentInPlace() { createCommentInPlace() {
const diffWithRangeSelected = this.diffs.find(diff => { const diffWithRangeSelected = this.diffs
return diff.isRangeSelected(); .find(diff => diff.isRangeSelected());
});
if (diffWithRangeSelected) { if (diffWithRangeSelected) {
diffWithRangeSelected.createRangeComment(); diffWithRangeSelected.createRangeComment();
} else { } else {
@ -404,9 +401,7 @@
_getStops() { _getStops() {
return this.diffs.reduce( return this.diffs.reduce(
(stops, diff) => { (stops, diff) => stops.concat(diff.getCursorStops()), []);
return stops.concat(diff.getCursorStops());
}, []);
} }
_updateStops() { _updateStops() {

View File

@ -377,7 +377,8 @@ limitations under the License.
const getRangeAtStub = sandbox.stub(); const getRangeAtStub = sandbox.stub();
getRangeAtStub getRangeAtStub
.onFirstCall().returns(startRange) .onFirstCall().returns(startRange)
.onSecondCall().returns(endRange); .onSecondCall()
.returns(endRange);
const selection = { const selection = {
rangeCount: 2, rangeCount: 2,
getRangeAt: getRangeAtStub, getRangeAt: getRangeAtStub,

View File

@ -412,7 +412,8 @@
range.side); range.side);
}); });
}); });
}).catch(err => { })
.catch(err => {
console.warn('Loading coverage ranges failed: ', err); console.warn('Loading coverage ranges failed: ', err);
}); });
} }

View File

@ -123,9 +123,8 @@ limitations under the License.
element.comments.left.push(comment); element.comments.left.push(comment);
comment.id = id; comment.id = id;
element.fire('comment-discard', {comment}); element.fire('comment-discard', {comment});
const drafts = element.comments.left.filter(item => { const drafts = element.comments.left
return item.__draftID === draftID; .filter(item => item.__draftID === draftID);
});
assert.equal(drafts.length, 0); assert.equal(drafts.length, 0);
assert.isTrue(diffCommentsModifiedStub.called); assert.isTrue(diffCommentsModifiedStub.called);
}); });
@ -145,9 +144,8 @@ limitations under the License.
element.comments.left.push(comment); element.comments.left.push(comment);
comment.id = id; comment.id = id;
element.fire('comment-save', {comment}); element.fire('comment-save', {comment});
const drafts = element.comments.left.filter(item => { const drafts = element.comments.left
return item.__draftID === draftID; .filter(item => item.__draftID === draftID);
});
assert.equal(drafts.length, 1); assert.equal(drafts.length, 1);
assert.equal(drafts[0].id, id); assert.equal(drafts[0].id, id);
assert.isTrue(diffCommentsModifiedStub.called); assert.isTrue(diffCommentsModifiedStub.called);
@ -361,12 +359,14 @@ limitations under the License.
Promise.resolve({content: []})); Promise.resolve({content: []}));
element.patchRange = {}; element.patchRange = {};
let reloadComplete = false; let reloadComplete = false;
element.$.restAPI.getDiffPreferences().then(prefs => { element.$.restAPI.getDiffPreferences()
element.prefs = prefs; .then(prefs => {
return element.reload(); element.prefs = prefs;
}).then(() => { return element.reload();
reloadComplete = true; })
}); .then(() => {
reloadComplete = true;
});
// Multiple cascading microtasks are scheduled. // Multiple cascading microtasks are scheduled.
setTimeout(() => { setTimeout(() => {
assert.isFalse(reloadComplete); assert.isFalse(reloadComplete);
@ -506,10 +506,10 @@ limitations under the License.
}; };
sandbox.stub(element.$.restAPI, sandbox.stub(element.$.restAPI,
'getB64FileContents', 'getB64FileContents',
(changeId, patchNum, path, opt_parentIndex) => { (changeId, patchNum, path, opt_parentIndex) => Promise.resolve(
return Promise.resolve(opt_parentIndex === 1 ? mockFile1 : opt_parentIndex === 1 ? mockFile1 :
mockFile2); mockFile2)
}); );
element.patchRange = {basePatchNum: 'PARENT', patchNum: 1}; element.patchRange = {basePatchNum: 'PARENT', patchNum: 1};
element.comments = { element.comments = {
@ -1380,7 +1380,8 @@ limitations under the License.
}); });
test('starts syntax layer processing on render event', done => { test('starts syntax layer processing on render event', done => {
sandbox.stub(element.$.syntaxLayer, 'process').returns(Promise.resolve()); sandbox.stub(element.$.syntaxLayer, 'process')
.returns(Promise.resolve());
sandbox.stub(element.$.restAPI, 'getDiff').returns( sandbox.stub(element.$.restAPI, 'getDiff').returns(
Promise.resolve({content: []})); Promise.resolve({content: []}));
element.reload(); element.reload();

View File

@ -500,7 +500,7 @@ limitations under the License.
test('breaks down shared chunks w/ whole-file', () => { test('breaks down shared chunks w/ whole-file', () => {
const size = 120 * 2 + 5; const size = 120 * 2 + 5;
const content = [{ const content = [{
ab: _.times(size, () => { return `${Math.random()}`; }), ab: _.times(size, () => `${Math.random()}`),
}]; }];
element.context = -1; element.context = -1;
const result = element._splitLargeChunks(content); const result = element._splitLargeChunks(content);
@ -511,7 +511,7 @@ limitations under the License.
test('does not break-down common chunks w/ context', () => { test('does not break-down common chunks w/ context', () => {
const content = [{ const content = [{
ab: _.times(75, () => { return `${Math.random()}`; }), ab: _.times(75, () => `${Math.random()}`),
}]; }];
element.context = 4; element.context = 4;
const result = const result =
@ -897,7 +897,7 @@ limitations under the License.
assert.isAtMost(subResult.length, size); assert.isAtMost(subResult.length, size);
} }
const flattened = result const flattened = result
.reduce((a, b) => { return a.concat(b); }, []); .reduce((a, b) => a.concat(b), []);
assert.deepEqual(flattened, array); assert.deepEqual(flattened, array);
}); });

View File

@ -169,7 +169,7 @@
}, },
_panelFloatingDisabled: { _panelFloatingDisabled: {
type: Boolean, type: Boolean,
value: () => { return window.PANEL_FLOATING_DISABLED; }, value: () => window.PANEL_FLOATING_DISABLED,
}, },
_editMode: { _editMode: {
type: Boolean, type: Boolean,
@ -678,23 +678,25 @@
promises.push(this._getChangeEdit(this._changeNum)); promises.push(this._getChangeEdit(this._changeNum));
this._loading = true; this._loading = true;
return Promise.all(promises).then(r => { return Promise.all(promises)
const edit = r[4]; .then(r => {
if (edit) { const edit = r[4];
this.set('_change.revisions.' + edit.commit.commit, { if (edit) {
_number: this.EDIT_NAME, this.set('_change.revisions.' + edit.commit.commit, {
basePatchNum: edit.base_patch_set_number, _number: this.EDIT_NAME,
commit: edit.commit, basePatchNum: edit.base_patch_set_number,
commit: edit.commit,
});
}
this._loading = false;
this.$.diffHost.comments = this._commentsForDiff;
return this.$.diffHost.reload(true);
})
.then(() => {
this.$.reporting.diffViewFullyLoaded();
// If diff view displayed has not ended yet, it ends here.
this.$.reporting.diffViewDisplayed();
}); });
}
this._loading = false;
this.$.diffHost.comments = this._commentsForDiff;
return this.$.diffHost.reload(true);
}).then(() => {
this.$.reporting.diffViewFullyLoaded();
// If diff view displayed has not ended yet, it ends here.
this.$.reporting.diffViewDisplayed();
});
} }
_changeViewStateChanged(changeViewState) { _changeViewStateChanged(changeViewState) {

View File

@ -281,8 +281,11 @@ limitations under the License.
MockInteractions.pressAndReleaseKeyOn(element, 219, null, '['); MockInteractions.pressAndReleaseKeyOn(element, 219, null, '[');
assert.isTrue(element._loading); assert.isTrue(element._loading);
assert(diffNavStub.lastCall.calledWithExactly(element._change, 'chell.go', assert(diffNavStub.lastCall.calledWithExactly(
'10', '5'), element._change,
'chell.go',
'10',
'5'),
'Should navigate to /c/42/5..10/chell.go'); 'Should navigate to /c/42/5..10/chell.go');
element._path = 'chell.go'; element._path = 'chell.go';
@ -342,8 +345,11 @@ limitations under the License.
element._path = 'glados.txt'; element._path = 'glados.txt';
MockInteractions.pressAndReleaseKeyOn(element, 219, null, '['); MockInteractions.pressAndReleaseKeyOn(element, 219, null, '[');
assert(diffNavStub.lastCall.calledWithExactly(element._change, 'chell.go', assert(diffNavStub.lastCall.calledWithExactly(
'1', PARENT), 'Should navigate to /c/42/1/chell.go'); element._change,
'chell.go',
'1',
PARENT), 'Should navigate to /c/42/1/chell.go');
element._path = 'chell.go'; element._path = 'chell.go';
MockInteractions.pressAndReleaseKeyOn(element, 219, null, '['); MockInteractions.pressAndReleaseKeyOn(element, 219, null, '[');
@ -429,12 +435,14 @@ limitations under the License.
suite('url params', () => { suite('url params', () => {
setup(() => { setup(() => {
sandbox.stub(Gerrit.Nav, 'getUrlForDiff', (c, p, pn, bpn) => { sandbox.stub(
return `${c._number}-${p}-${pn}-${bpn}`; Gerrit.Nav,
}); 'getUrlForDiff',
sandbox.stub(Gerrit.Nav, 'getUrlForChange', (c, pn, bpn) => { (c, p, pn, bpn) => `${c._number}-${p}-${pn}-${bpn}`);
return `${c._number}-${pn}-${bpn}`; sandbox.stub(
}); Gerrit.Nav
, 'getUrlForChange',
(c, pn, bpn) => `${c._number}-${pn}-${bpn}`);
}); });
test('_formattedFiles', () => { test('_formattedFiles', () => {

View File

@ -374,10 +374,11 @@
.map(commentRangeFromThreadEl) .map(commentRangeFromThreadEl)
.filter(({range}) => range); .filter(({range}) => range);
for (const removedCommentRange of removedCommentRanges) { for (const removedCommentRange of removedCommentRanges) {
const i = this._commentRanges.findIndex(commentRange => { const i = this._commentRanges
return commentRange.side === removedCommentRange.side && .findIndex(
Gerrit.rangesEqual(commentRange.range, removedCommentRange.range); cr => cr.side === removedCommentRange.side &&
}); Gerrit.rangesEqual(cr.range, removedCommentRange.range)
);
this.splice('_commentRanges', i, 1); this.splice('_commentRanges', i, 1);
} }
@ -584,7 +585,7 @@
* @param {string=} side * @param {string=} side
* @param {!Object=} range * @param {!Object=} range
*/ */
_createComment(lineEl, lineNum=undefined, side=undefined, range=undefined) { _createComment(lineEl, lineNum, side, range) {
const contentText = this.$.diffBuilder.getContentByLineEl(lineEl); const contentText = this.$.diffBuilder.getContentByLineEl(lineEl);
const contentEl = contentText.parentElement; const contentEl = contentText.parentElement;
side = side || side = side ||
@ -870,13 +871,12 @@
_computeDiffHeaderItems(diffInfoRecord) { _computeDiffHeaderItems(diffInfoRecord) {
const diffInfo = diffInfoRecord.base; const diffInfo = diffInfoRecord.base;
if (!diffInfo || !diffInfo.diff_header) { return []; } if (!diffInfo || !diffInfo.diff_header) { return []; }
return diffInfo.diff_header.filter(item => { return diffInfo.diff_header
return !(item.startsWith('diff --git ') || .filter(item => !(item.startsWith('diff --git ') ||
item.startsWith('index ') || item.startsWith('index ') ||
item.startsWith('+++ ') || item.startsWith('+++ ') ||
item.startsWith('--- ') || item.startsWith('--- ') ||
item === 'Binary files differ'); item === 'Binary files differ'));
});
} }
/** @return {boolean} */ /** @return {boolean} */

View File

@ -235,10 +235,11 @@ limitations under the License.
// Should be recomputed for each available patch // Should be recomputed for each available patch
sandbox.stub(element, '_computeBaseDropdownContent'); sandbox.stub(element, '_computeBaseDropdownContent');
assert.equal(element._computeBaseDropdownContent.callCount, 0); assert.equal(element._computeBaseDropdownContent.callCount, 0);
commentApiWrapper.loadComments().then().then(() => { commentApiWrapper.loadComments().then()
assert.equal(element._computeBaseDropdownContent.callCount, 1); .then(() => {
done(); assert.equal(element._computeBaseDropdownContent.callCount, 1);
}); done();
});
}); });
test('_computePatchDropdownContent called when basePatchNum updates', () => { test('_computePatchDropdownContent called when basePatchNum updates', () => {
@ -286,9 +287,10 @@ limitations under the License.
// Should be recomputed for each available patch // Should be recomputed for each available patch
sandbox.stub(element, '_computePatchDropdownContent'); sandbox.stub(element, '_computePatchDropdownContent');
assert.equal(element._computePatchDropdownContent.callCount, 0); assert.equal(element._computePatchDropdownContent.callCount, 0);
commentApiWrapper.loadComments().then().then(() => { commentApiWrapper.loadComments().then()
done(); .then(() => {
}); done();
});
}); });
test('_computePatchDropdownContent', () => { test('_computePatchDropdownContent', () => {

View File

@ -208,7 +208,7 @@
return range; return range;
}) })
// Sort the ranges so that hovering highlights are on top. // Sort the ranges so that hovering highlights are on top.
.sort((a, b) => a.hovering && !b.hovering ? 1 : 0); .sort((a, b) => (a.hovering && !b.hovering ? 1 : 0));
} }
} }

View File

@ -271,39 +271,37 @@
const rangesCache = new Map(); const rangesCache = new Map();
this._processPromise = util.makeCancelable(this._loadHLJS() this._processPromise = util.makeCancelable(this._loadHLJS()
.then(() => { .then(() => new Promise(resolve => {
return new Promise(resolve => { const nextStep = () => {
const nextStep = () => { this._processHandle = null;
this._processHandle = null; this._processNextLine(state, rangesCache);
this._processNextLine(state, rangesCache);
// Move to the next line in the section. // Move to the next line in the section.
state.lineIndex++; state.lineIndex++;
// If the section has been exhausted, move to the next one. // If the section has been exhausted, move to the next one.
if (this._isSectionDone(state)) { if (this._isSectionDone(state)) {
state.lineIndex = 0; state.lineIndex = 0;
state.sectionIndex++; state.sectionIndex++;
} }
// If all sections have been exhausted, finish. // If all sections have been exhausted, finish.
if (state.sectionIndex >= this.diff.content.length) { if (state.sectionIndex >= this.diff.content.length) {
resolve(); resolve();
this._notify(state); this._notify(state);
return; return;
} }
if (state.lineIndex % 100 === 0) { if (state.lineIndex % 100 === 0) {
this._notify(state); this._notify(state);
this._processHandle = this.async(nextStep, ASYNC_DELAY); this._processHandle = this.async(nextStep, ASYNC_DELAY);
} else { } else {
nextStep.call(this); nextStep.call(this);
} }
}; };
this._processHandle = this.async(nextStep, 1); this._processHandle = this.async(nextStep, 1);
}); })));
}));
return this._processPromise return this._processPromise
.finally(() => { this._processPromise = null; }); .finally(() => { this._processPromise = null; });
} }

View File

@ -194,7 +194,7 @@ limitations under the License.
const mockHLJS = getMockHLJS(); const mockHLJS = getMockHLJS();
const highlightSpy = sinon.spy(mockHLJS, 'highlight'); const highlightSpy = sinon.spy(mockHLJS, 'highlight');
sandbox.stub(element.$.libLoader, 'getHLJS', sandbox.stub(element.$.libLoader, 'getHLJS',
() => { return Promise.resolve(mockHLJS); }); () => Promise.resolve(mockHLJS));
const processNextSpy = sandbox.spy(element, '_processNextLine'); const processNextSpy = sandbox.spy(element, '_processNextLine');
const processPromise = element.process(); const processPromise = element.process();

View File

@ -90,9 +90,10 @@ limitations under the License.
}); });
test('_paramsChanged', done => { test('_paramsChanged', done => {
sandbox.stub(element.$.restAPI, 'getDocumentationSearches', () => { sandbox.stub(
return Promise.resolve(documentationSearches); element.$.restAPI,
}); 'getDocumentationSearches',
() => Promise.resolve(documentationSearches));
const value = { const value = {
filter: 'test', filter: 'test',
}; };

View File

@ -336,13 +336,12 @@ suite('gr-edit-controls tests', () => {
}); });
}); });
test('openOpenDialog', () => { test('openOpenDialog', () => element.openOpenDialog('test/path.cpp')
return element.openOpenDialog('test/path.cpp').then(() => { .then(() => {
assert.isFalse(element.$.openDialog.hasAttribute('hidden')); assert.isFalse(element.$.openDialog.hasAttribute('hidden'));
assert.equal(element.$.openDialog.querySelector('gr-autocomplete').text, assert.equal(element.$.openDialog.querySelector('gr-autocomplete').text,
'test/path.cpp'); 'test/path.cpp');
}); }));
});
test('_getDialogFromEvent', () => { test('_getDialogFromEvent', () => {
const spy = sandbox.spy(element, '_getDialogFromEvent'); const spy = sandbox.spy(element, '_getDialogFromEvent');

View File

@ -82,9 +82,7 @@ limitations under the License.
sandbox.restore(); sandbox.restore();
}); });
appElement = () => { appElement = () => element.$['app-element'];
return element.$['app-element'];
};
test('reporting', () => { test('reporting', () => {
assert.isTrue(appElement().$.reporting.appStarted.calledOnce); assert.isTrue(appElement().$.reporting.appStarted.calledOnce);

View File

@ -148,14 +148,16 @@
ready() { ready() {
super.ready(); super.ready();
Gerrit._endpoints.onNewEndpoint(this.name, this._initModule.bind(this)); Gerrit._endpoints.onNewEndpoint(this.name, this._initModule.bind(this));
Gerrit.awaitPluginsLoaded().then(() => Promise.all( Gerrit.awaitPluginsLoaded()
Gerrit._endpoints.getPlugins(this.name).map( .then(() => Promise.all(
pluginUrl => this._import(pluginUrl))) Gerrit._endpoints.getPlugins(this.name).map(
).then(() => pluginUrl => this._import(pluginUrl)))
Gerrit._endpoints )
.getDetails(this.name) .then(() =>
.forEach(this._initModule, this) Gerrit._endpoints
); .getDetails(this.name)
.forEach(this._initModule, this)
);
} }
} }

View File

@ -96,10 +96,11 @@ limitations under the License.
assert.equal(module['someparam'], 'barbar'); assert.equal(module['someparam'], 'barbar');
return decorationHook.getLastAttached().then(element => { return decorationHook.getLastAttached().then(element => {
assert.strictEqual(element, module); assert.strictEqual(element, module);
}).then(() => { })
element.remove(); .then(() => {
assert.equal(decorationHook.getAllAttached().length, 0); element.remove();
}); assert.equal(decorationHook.getAllAttached().length, 0);
});
}); });
test('replacement', () => { test('replacement', () => {
@ -109,12 +110,14 @@ limitations under the License.
element => element.nodeName === 'OTHER-MODULE'); element => element.nodeName === 'OTHER-MODULE');
assert.isOk(module); assert.isOk(module);
assert.equal(module['someparam'], 'foofoo'); assert.equal(module['someparam'], 'foofoo');
return replacementHook.getLastAttached().then(element => { return replacementHook.getLastAttached()
assert.strictEqual(element, module); .then(element => {
}).then(() => { assert.strictEqual(element, module);
element.remove(); })
assert.equal(replacementHook.getAllAttached().length, 0); .then(() => {
}); element.remove();
assert.equal(replacementHook.getAllAttached().length, 0);
});
}); });
test('late registration', done => { test('late registration', done => {

View File

@ -81,7 +81,8 @@ limitations under the License.
test('skip theme if preloaded', () => { test('skip theme if preloaded', () => {
sandbox.stub(Gerrit, '_isPluginPreloaded') sandbox.stub(Gerrit, '_isPluginPreloaded')
.withArgs('preloaded:gerrit-theme').returns(true); .withArgs('preloaded:gerrit-theme')
.returns(true);
sandbox.stub(Gerrit, '_loadPlugins'); sandbox.stub(Gerrit, '_loadPlugins');
element.config = { element.config = {
default_theme: '/oof', default_theme: '/oof',

View File

@ -56,11 +56,9 @@ limitations under the License.
assert.isOk(element); assert.isOk(element);
}); });
test('open uses open() from gr-overlay', () => { test('open uses open() from gr-overlay', () => element.open().then(() => {
return element.open().then(() => { assert.isTrue(element.$.overlay.open.called);
assert.isTrue(element.$.overlay.open.called); }));
});
});
test('close uses close() from gr-overlay', () => { test('close uses close() from gr-overlay', () => {
element.close(); element.close();

View File

@ -69,26 +69,22 @@ limitations under the License.
instance = new GrPopupInterface(plugin); instance = new GrPopupInterface(plugin);
}); });
test('open', () => { test('open', () => instance.open().then(api => {
return instance.open().then(api => { assert.strictEqual(api, instance);
assert.strictEqual(api, instance); const manual = document.createElement('div');
const manual = document.createElement('div'); manual.id = 'foobar';
manual.id = 'foobar'; manual.innerHTML = 'manual content';
manual.innerHTML = 'manual content'; api._getElement().appendChild(manual);
api._getElement().appendChild(manual); flushAsynchronousOperations();
flushAsynchronousOperations(); assert.equal(
assert.equal( container.querySelector('#foobar').textContent, 'manual content');
container.querySelector('#foobar').textContent, 'manual content'); }));
});
});
test('close', () => { test('close', () => instance.open().then(api => {
return instance.open().then(api => { assert.isTrue(api._getElement().node.opened);
assert.isTrue(api._getElement().node.opened); api.close();
api.close(); assert.isFalse(api._getElement().node.opened);
assert.isFalse(api._getElement().node.opened); }));
});
});
}); });
suite('components', () => { suite('components', () => {
@ -96,20 +92,16 @@ limitations under the License.
instance = new GrPopupInterface(plugin, 'gr-user-test-popup'); instance = new GrPopupInterface(plugin, 'gr-user-test-popup');
}); });
test('open', () => { test('open', () => instance.open().then(api => {
return instance.open().then(api => { assert.isNotNull(
assert.isNotNull( Polymer.dom(container).querySelector('gr-user-test-popup'));
Polymer.dom(container).querySelector('gr-user-test-popup')); }));
});
});
test('close', () => { test('close', () => instance.open().then(api => {
return instance.open().then(api => { assert.isTrue(api._getElement().node.opened);
assert.isTrue(api._getElement().node.opened); api.close();
api.close(); assert.isFalse(api._getElement().node.opened);
assert.isFalse(api._getElement().node.opened); }));
});
});
}); });
}); });
</script> </script>

View File

@ -22,7 +22,8 @@
this._title = '(no title)'; this._title = '(no title)';
// Generate default screen URL token, specific to plugin, and unique(ish). // Generate default screen URL token, specific to plugin, and unique(ish).
this._token = this._token =
plugin.getPluginName() + Math.random().toString(36).substr(5); plugin.getPluginName() + Math.random().toString(36)
.substr(5);
this.plugin = plugin; this.plugin = plugin;
} }

View File

@ -59,9 +59,7 @@
})); }));
promises.push(this.$.restAPI.getAccountGroups().then(groups => { promises.push(this.$.restAPI.getAccountGroups().then(groups => {
this._groups = groups.sort((a, b) => { this._groups = groups.sort((a, b) => a.name.localeCompare(b.name));
return a.name.localeCompare(b.name);
});
})); }));
promises.push(this.$.restAPI.getAccountAgreements().then(agreements => { promises.push(this.$.restAPI.getAccountAgreements().then(agreements => {

View File

@ -96,7 +96,8 @@
this.$.newKey.disabled = false; this.$.newKey.disabled = false;
this._newKey = ''; this._newKey = '';
this.loadData(); this.loadData();
}).catch(() => { })
.catch(() => {
this.$.addButton.disabled = false; this.$.addButton.disabled = false;
this.$.newKey.disabled = false; this.$.newKey.disabled = false;
}); });

View File

@ -90,7 +90,7 @@ limitations under the License.
const lastKey = keys[Object.keys(keys)[1]]; const lastKey = keys[Object.keys(keys)[1]];
const saveStub = sinon.stub(element.$.restAPI, 'deleteAccountGPGKey', const saveStub = sinon.stub(element.$.restAPI, 'deleteAccountGPGKey',
() => { return Promise.resolve(); }); () => Promise.resolve());
assert.equal(element._keysToRemove.length, 0); assert.equal(element._keysToRemove.length, 0);
assert.isFalse(element.hasUnsavedChanges); assert.isFalse(element.hasUnsavedChanges);
@ -146,7 +146,7 @@ limitations under the License.
}; };
const addStub = sinon.stub(element.$.restAPI, 'addAccountGPGKey', const addStub = sinon.stub(element.$.restAPI, 'addAccountGPGKey',
() => { return Promise.resolve(newKeyObject); }); () => Promise.resolve(newKeyObject));
element._newKey = newKeyString; element._newKey = newKeyString;
@ -171,7 +171,7 @@ limitations under the License.
const newKeyString = 'not even close to valid'; const newKeyString = 'not even close to valid';
const addStub = sinon.stub(element.$.restAPI, 'addAccountGPGKey', const addStub = sinon.stub(element.$.restAPI, 'addAccountGPGKey',
() => { return Promise.reject(new Error('error')); }); () => Promise.reject(new Error('error')));
element._newKey = newKeyString; element._newKey = newKeyString;

View File

@ -30,9 +30,7 @@
loadData() { loadData() {
return this.$.restAPI.getAccountGroups().then(groups => { return this.$.restAPI.getAccountGroups().then(groups => {
this._groups = groups.sort((a, b) => { this._groups = groups.sort((a, b) => a.name.localeCompare(b.name));
return a.name.localeCompare(b.name);
});
}); });
} }

View File

@ -58,11 +58,9 @@ limitations under the License.
const nextPassword = 'the new password'; const nextPassword = 'the new password';
let generateResolve; let generateResolve;
const generateStub = sinon.stub(element.$.restAPI, const generateStub = sinon.stub(element.$.restAPI,
'generateAccountHttpPassword', () => { 'generateAccountHttpPassword', () => new Promise(resolve => {
return new Promise(resolve => { generateResolve = resolve;
generateResolve = resolve; }));
});
});
assert.isNotOk(element._generatedPassword); assert.isNotOk(element._generatedPassword);

View File

@ -40,7 +40,7 @@ limitations under the License.
let menu; let menu;
function assertMenuNamesEqual(element, expected) { function assertMenuNamesEqual(element, expected) {
const names = element.menuItems.map(i => { return i.name; }); const names = element.menuItems.map(i => i.name);
assert.equal(names.length, expected.length); assert.equal(names.length, expected.length);
for (let i = 0; i < names.length; i++) { for (let i = 0; i < names.length; i++) {
assert.equal(names[i], expected[i]); assert.equal(names[i], expected[i]);
@ -53,7 +53,8 @@ limitations under the License.
const selector = 'tr:nth-child(' + (index + 1) + ') .move' + const selector = 'tr:nth-child(' + (index + 1) + ') .move' +
direction + 'Button'; direction + 'Button';
const button = const button =
element.$$('tbody').querySelector(selector).$$('paper-button'); element.$$('tbody').querySelector(selector)
.$$('paper-button');
MockInteractions.tap(button); MockInteractions.tap(button);
} }
@ -147,14 +148,16 @@ limitations under the License.
// Tap the delete button for the middle item. // Tap the delete button for the middle item.
MockInteractions.tap(element.$$('tbody') MockInteractions.tap(element.$$('tbody')
.querySelector('tr:nth-child(2) .remove-button').$$('paper-button')); .querySelector('tr:nth-child(2) .remove-button')
.$$('paper-button'));
assertMenuNamesEqual(element, ['first name', 'third name']); assertMenuNamesEqual(element, ['first name', 'third name']);
// Delete remaining items. // Delete remaining items.
for (let i = 0; i < 2; i++) { for (let i = 0; i < 2; i++) {
MockInteractions.tap(element.$$('tbody') MockInteractions.tap(element.$$('tbody')
.querySelector('tr:first-child .remove-button').$$('paper-button')); .querySelector('tr:first-child .remove-button')
.$$('paper-button'));
} }
assertMenuNamesEqual(element, []); assertMenuNamesEqual(element, []);

View File

@ -146,11 +146,13 @@ limitations under the License.
assert.equal(account.email, 'email'); assert.equal(account.email, 'email');
// Save and verify new values are committed. // Save and verify new values are committed.
save().then(() => { save()
assert.equal(account.name, 'new name'); .then(() => {
assert.equal(account.username, 'new username'); assert.equal(account.name, 'new name');
assert.equal(account.email, 'email3'); assert.equal(account.username, 'new username');
}).then(done); assert.equal(account.email, 'email3');
})
.then(done);
}); });
}); });

View File

@ -70,7 +70,7 @@ limitations under the License.
function stubAddAccountEmail(statusCode) { function stubAddAccountEmail(statusCode) {
return sandbox.stub(element.$.restAPI, 'addAccountEmail', return sandbox.stub(element.$.restAPI, 'addAccountEmail',
() => { return Promise.resolve({status: statusCode}); }); () => Promise.resolve({status: statusCode}));
} }
setup(done => { setup(done => {
@ -487,9 +487,10 @@ limitations under the License.
setup(() => { setup(() => {
sandbox.stub(element.$.emailEditor, 'loadData'); sandbox.stub(element.$.emailEditor, 'loadData');
sandbox.stub(element.$.restAPI, 'confirmEmail', () => { sandbox.stub(
return new Promise(resolve => { resolveConfirm = resolve; }); element.$.restAPI,
}); 'confirmEmail',
() => new Promise(resolve => { resolveConfirm = resolve; }));
element.params = {emailToken: 'foo'}; element.params = {emailToken: 'foo'};
element.attached(); element.attached();
}); });

View File

@ -91,7 +91,8 @@
this.$.newKey.disabled = false; this.$.newKey.disabled = false;
this._newKey = ''; this._newKey = '';
this.push('_keys', key); this.push('_keys', key);
}).catch(() => { })
.catch(() => {
this.$.addButton.disabled = false; this.$.addButton.disabled = false;
this.$.newKey.disabled = false; this.$.newKey.disabled = false;
}); });

View File

@ -81,7 +81,7 @@ limitations under the License.
const lastKey = keys[1]; const lastKey = keys[1];
const saveStub = sinon.stub(element.$.restAPI, 'deleteAccountSSHKey', const saveStub = sinon.stub(element.$.restAPI, 'deleteAccountSSHKey',
() => { return Promise.resolve(); }); () => Promise.resolve());
assert.equal(element._keysToRemove.length, 0); assert.equal(element._keysToRemove.length, 0);
assert.isFalse(element.hasUnsavedChanges); assert.isFalse(element.hasUnsavedChanges);
@ -132,7 +132,7 @@ limitations under the License.
}; };
const addStub = sinon.stub(element.$.restAPI, 'addAccountSSHKey', const addStub = sinon.stub(element.$.restAPI, 'addAccountSSHKey',
() => { return Promise.resolve(newKeyObject); }); () => Promise.resolve(newKeyObject));
element._newKey = newKeyString; element._newKey = newKeyString;
@ -157,7 +157,7 @@ limitations under the License.
const newKeyString = 'not even close to valid'; const newKeyString = 'not even close to valid';
const addStub = sinon.stub(element.$.restAPI, 'addAccountSSHKey', const addStub = sinon.stub(element.$.restAPI, 'addAccountSSHKey',
() => { return Promise.reject(new Error('error')); }); () => Promise.reject(new Error('error')));
element._newKey = newKeyString; element._newKey = newKeyString;

View File

@ -68,9 +68,7 @@
} }
return deletePromise return deletePromise
.then(() => { .then(() => this.$.restAPI.saveWatchedProjects(this._projects))
return this.$.restAPI.saveWatchedProjects(this._projects);
})
.then(projects => { .then(projects => {
this._projects = projects; this._projects = projects;
this._projectsToRemove = []; this._projectsToRemove = [];

View File

@ -88,7 +88,7 @@ limitations under the License.
function getKeysOfRow(row) { function getKeysOfRow(row) {
const boxes = rows[row].querySelectorAll('input[checked]'); const boxes = rows[row].querySelectorAll('input[checked]');
return Array.prototype.map.call(boxes, return Array.prototype.map.call(boxes,
e => { return e.getAttribute('data-key'); }); e => e.getAttribute('data-key'));
} }
let checkedKeys = getKeysOfRow(0); let checkedKeys = getKeysOfRow(0);

View File

@ -80,9 +80,10 @@
} }
_getHasAvatars() { _getHasAvatars() {
return this.$.restAPI.getConfig().then(cfg => { return this.$.restAPI.getConfig()
return Promise.resolve(!!(cfg && cfg.plugin && cfg.plugin.has_avatars)); .then(cfg => Promise.resolve(!!(
}); cfg && cfg.plugin && cfg.plugin.has_avatars
)));
} }
} }

View File

@ -67,13 +67,11 @@ limitations under the License.
suite('stubbed values for querySuggestions', () => { suite('stubbed values for querySuggestions', () => {
setup(() => { setup(() => {
element.querySuggestions = input => { element.querySuggestions = input => Promise.resolve([
return Promise.resolve([ suggestion1,
suggestion1, suggestion2,
suggestion2, suggestion3,
suggestion3, ]);
]);
};
}); });
}); });

View File

@ -333,15 +333,15 @@
} }
additions() { additions() {
return this.accounts.filter(account => { return this.accounts
return account._pendingAdd; .filter(account => account._pendingAdd)
}).map(account => { .map(account => {
if (account._group) { if (account._group) {
return {group: account}; return {group: account};
} else { } else {
return {account}; return {account};
} }
}); });
} }
_computeEntryHidden(maxCount, accountsRecord, readonly) { _computeEntryHidden(maxCount, accountsRecord, readonly) {

View File

@ -197,11 +197,13 @@ limitations under the License.
return suggestion._account_id === accountId; return suggestion._account_id === accountId;
}; };
element._getSuggestions().then(suggestions => { element._getSuggestions()
assert.deepEqual(suggestions, .then(suggestions => {
[{name: originalSuggestions[0].email, assert.deepEqual(suggestions,
value: originalSuggestions[0]._account_id}]); [{name: originalSuggestions[0].email,
}).then(done); value: originalSuggestions[0]._account_id}]);
})
.then(done);
}); });
}); });

Some files were not shown because too many files have changed in this diff Show More