diff options
Diffstat (limited to 'polygerrit-ui/app/elements/change/gr-commit-info/gr-commit-info_test.html')
-rw-r--r-- | polygerrit-ui/app/elements/change/gr-commit-info/gr-commit-info_test.html | 82 |
1 files changed, 36 insertions, 46 deletions
diff --git a/polygerrit-ui/app/elements/change/gr-commit-info/gr-commit-info_test.html b/polygerrit-ui/app/elements/change/gr-commit-info/gr-commit-info_test.html index aadd21b59d..438a3f300e 100644 --- a/polygerrit-ui/app/elements/change/gr-commit-info/gr-commit-info_test.html +++ b/polygerrit-ui/app/elements/change/gr-commit-info/gr-commit-info_test.html @@ -1,5 +1,6 @@ <!DOCTYPE html> <!-- +@license Copyright (C) 2015 The Android Open Source Project Licensed under the Apache License, Version 2.0 (the "License"); @@ -21,6 +22,7 @@ limitations under the License. <script src="../../../bower_components/webcomponentsjs/webcomponents-lite.min.js"></script> <script src="../../../bower_components/web-component-tester/browser.js"></script> <link rel="import" href="../../../test/common-test-setup.html"/> +<link rel="import" href="../../core/gr-router/gr-router.html"> <link rel="import" href="gr-commit-info.html"> <script>void(0);</script> @@ -34,22 +36,43 @@ limitations under the License. <script> suite('gr-commit-info tests', () => { let element; + let sandbox; setup(() => { + sandbox = sinon.sandbox.create(); element = fixture('basic'); }); + teardown(() => { + sandbox.restore(); + }); + + test('weblinks use Gerrit.Nav interface', () => { + const weblinksStub = sandbox.stub(Gerrit.Nav, '_generateWeblinks') + .returns([{name: 'stubb', url: '#s'}]); + element.change = {}; + element.commitInfo = {}; + element.serverConfig = {}; + assert.isTrue(weblinksStub.called); + }); + test('no web link when unavailable', () => { element.commitInfo = {}; element.serverConfig = {}; - element.change = {labels: []}; + element.change = {labels: [], project: ''}; assert.isNotOk(element._computeShowWebLink(element.change, element.commitInfo, element.serverConfig)); }); test('use web link when available', () => { - element.commitInfo = {web_links: [{name: 'gitweb', url: 'link-url'}]}; + const router = document.createElement('gr-router'); + sandbox.stub(Gerrit.Nav, '_generateWeblinks', + router._generateWeblinks.bind(router)); + + element.change = {labels: [], project: ''}; + element.commitInfo = + {commit: 'commitsha', web_links: [{name: 'gitweb', url: 'link-url'}]}; element.serverConfig = {}; assert.isOk(element._computeShowWebLink(element.change, @@ -59,7 +82,13 @@ limitations under the License. }); test('does not relativize web links that begin with scheme', () => { + const router = document.createElement('gr-router'); + sandbox.stub(Gerrit.Nav, '_generateWeblinks', + router._generateWeblinks.bind(router)); + + element.change = {labels: [], project: ''}; element.commitInfo = { + commit: 'commitsha', web_links: [{name: 'gitweb', url: 'https://link-url'}], }; element.serverConfig = {}; @@ -70,51 +99,13 @@ limitations under the License. element.serverConfig), 'https://link-url'); }); - test('use gitweb when available', () => { - element.commitInfo = {commit: 'commit-sha'}; - element.serverConfig = {gitweb: { - url: 'url-base/', - type: {revision: 'xx ${project} xx ${commit} xx'}, - }}; - element.change = { - project: 'project-name', - labels: [], - current_revision: element.commitInfo.commit, - }; - - assert.isOk(element._computeShowWebLink(element.change, - element.commitInfo, element.serverConfig)); - - assert.equal(element._computeWebLink(element.change, element.commitInfo, - element.serverConfig), 'url-base/xx project-name xx commit-sha xx'); - }); - - test('prefer gitweb when both are available', () => { - element.commitInfo = { - commit: 'commit-sha', - web_links: [{url: 'link-url'}], - }; - element.serverConfig = {gitweb: { - url: 'url-base/', - type: {revision: 'xx ${project} xx ${commit} xx'}, - }}; - element.change = { - project: 'project-name', - labels: [], - current_revision: element.commitInfo.commit, - }; - - assert.isOk(element._computeShowWebLink(element.change, - element.commitInfo, element.serverConfig)); - - const link = element._computeWebLink(element.change, element.commitInfo, - element.serverConfig); - - assert.equal(link, 'url-base/xx project-name xx commit-sha xx'); - assert.notEqual(link, '../../link-url'); - }); test('ignore web links that are neither gitweb nor gitiles', () => { + const router = document.createElement('gr-router'); + sandbox.stub(Gerrit.Nav, '_generateWeblinks', + router._generateWeblinks.bind(router)); + + element.change = {project: 'project-name'}; element.commitInfo = { commit: 'commit-sha', web_links: [ @@ -128,7 +119,6 @@ limitations under the License. }, ], }; - element.serverConfig = {}; assert.isOk(element._computeShowWebLink(element.change, element.commitInfo, element.serverConfig)); |