mirror of https://github.com/hashicorp/consul
chor: change cluster name param to have datacenter.name as default value
parent
137c9c0973
commit
214abc386b
|
@ -52,7 +52,6 @@ export default class HcpLinkItemComponent extends Component {
|
|||
|
||||
@action
|
||||
onLinkToConsulCentral() {
|
||||
this.hcpLinkModal.setResourceId(this.args.linkData?.resourceId);
|
||||
this.hcpLinkModal.show();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -22,7 +22,6 @@ export default class LinkToHcpBannerComponent extends Component {
|
|||
}
|
||||
@action
|
||||
onClusterLink() {
|
||||
this.hcpLinkModal.setResourceId(this.args.linkData?.resourceId);
|
||||
this.hcpLinkModal.show();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -97,7 +97,7 @@
|
|||
@icon="external-link"
|
||||
@iconPosition="trailing"
|
||||
data-test-link-to-hcp-modal-next-button
|
||||
@href={{hcp-authentication-link this.hcpLinkModal.resourceId this.accessLevel}}
|
||||
@href={{hcp-authentication-link @dc this.accessLevel}}
|
||||
/>
|
||||
<Hds::Button type="button" @text="Cancel" @color="secondary"
|
||||
data-test-link-to-hcp-modal-cancel-button
|
||||
|
|
|
@ -18,17 +18,12 @@ export const HCP_PREFIX =
|
|||
'https://portal.cloud.hashicorp.com/services/consul/clusters/self-managed/link-existing';
|
||||
export default class hcpAuthenticationLink extends Helper {
|
||||
@service('env') env;
|
||||
compute([resourceId, accessMode], hash) {
|
||||
compute([datacenterName, accessMode]) {
|
||||
let url = new URL(HCP_PREFIX);
|
||||
const clusterVersion = this.env.var('CONSUL_VERSION');
|
||||
|
||||
// if resourceId is empty, we still might want the user to get to the HCP sign-in page
|
||||
if (resourceId) {
|
||||
// Array looks like: ["organization", organizationId, "project", projectId, "hashicorp.consul.global-network-manager.cluster", "Cluster Id"]
|
||||
const [, , , , , clusterName] = resourceId.split('/');
|
||||
if (clusterName) {
|
||||
url.searchParams.append('cluster_name', clusterName);
|
||||
}
|
||||
if (datacenterName) {
|
||||
url.searchParams.append('cluster_name', datacenterName);
|
||||
}
|
||||
|
||||
if (clusterVersion) {
|
||||
|
|
|
@ -8,7 +8,6 @@ import { tracked } from '@glimmer/tracking';
|
|||
|
||||
export default class HcpLinkModalService extends Service {
|
||||
@tracked isModalVisible = false;
|
||||
@tracked resourceId = null;
|
||||
|
||||
show(hcpLinkData) {
|
||||
this.isModalVisible = true;
|
||||
|
@ -17,7 +16,4 @@ export default class HcpLinkModalService extends Service {
|
|||
hide() {
|
||||
this.isModalVisible = false;
|
||||
}
|
||||
setResourceId(resourceId) {
|
||||
this.resourceId = resourceId;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,7 +6,6 @@
|
|||
import { module, test } from 'qunit';
|
||||
import { click, visit } from '@ember/test-helpers';
|
||||
import { setupApplicationTest } from 'ember-qunit';
|
||||
import HcpLinkModalService from 'consul-ui/services/hcp-link-modal';
|
||||
|
||||
const bannerSelector = '[data-test-link-to-hcp-banner]';
|
||||
const linkToHcpSelector = '[data-test-link-to-hcp]';
|
||||
|
@ -15,20 +14,10 @@ const linkToHcpModalSelector = '[data-test-link-to-hcp-modal]';
|
|||
const linkToHcpModalCancelButtonSelector = '[data-test-link-to-hcp-modal-cancel-button]';
|
||||
module('Acceptance | link to hcp', function (hooks) {
|
||||
setupApplicationTest(hooks);
|
||||
const correctResourceId =
|
||||
'organization/b4432207-bb9c-438e-a160-b98923efa979/project/4b09958c-fa91-43ab-8029-eb28d8cee9d4/hashicorp.consul.global-network-manager.cluster/test-from-api';
|
||||
|
||||
hooks.beforeEach(function () {
|
||||
// clear local storage so we don't have any settings
|
||||
window.localStorage.clear();
|
||||
this.owner.register(
|
||||
'service:hcp-link-modal',
|
||||
class extends HcpLinkModalService {
|
||||
setResourceId(resourceId) {
|
||||
super.setResourceId(correctResourceId);
|
||||
}
|
||||
}
|
||||
);
|
||||
});
|
||||
|
||||
test('the banner and nav item are initially displayed on services page', async function (assert) {
|
||||
|
|
|
@ -10,12 +10,9 @@ import { setupRenderingTest } from 'ember-qunit';
|
|||
import { HCP_PREFIX } from 'consul-ui/helpers/hcp-authentication-link';
|
||||
import { EnvStub } from 'consul-ui/services/env';
|
||||
|
||||
// organization/b4432207-bb9c-438e-a160-b98923efa979/project/4b09958c-fa91-43ab-8029-eb28d8cee9d4/hashicorp.consul.global-network-manager.cluster/test-from-api
|
||||
const clusterName = 'hello';
|
||||
const clusterVersion = '1.18.0';
|
||||
const accessMode = 'CONSUL_ACCESS_LEVEL_GLOBAL_READ_WRITE';
|
||||
const projectId = '4b09958c-fa91-43ab-8029-eb28d8cee9d4';
|
||||
const realResourceId = `organization/b4432207-bb9c-438e-a160-b98923efa979/project/${projectId}/hashicorp.consul.global-network-manager.cluster/${clusterName}`;
|
||||
module('Integration | Helper | hcp-authentication-link', function (hooks) {
|
||||
setupRenderingTest(hooks);
|
||||
hooks.beforeEach(function () {
|
||||
|
@ -29,9 +26,9 @@ module('Integration | Helper | hcp-authentication-link', function (hooks) {
|
|||
);
|
||||
});
|
||||
test('it makes a URL out of a real resourceId', async function (assert) {
|
||||
this.resourceId = realResourceId;
|
||||
this.dcName = clusterName;
|
||||
|
||||
await render(hbs`{{hcp-authentication-link resourceId}}`);
|
||||
await render(hbs`{{hcp-authentication-link dcName}}`);
|
||||
|
||||
assert.equal(
|
||||
this.element.textContent.trim(),
|
||||
|
@ -39,38 +36,21 @@ module('Integration | Helper | hcp-authentication-link', function (hooks) {
|
|||
);
|
||||
});
|
||||
|
||||
test('it returns correct link with invalid resourceId', async function (assert) {
|
||||
this.resourceId = 'invalid';
|
||||
test('it returns correct link without dc name', async function (assert) {
|
||||
this.dcName = null;
|
||||
|
||||
await render(hbs`{{hcp-authentication-link resourceId}}`);
|
||||
assert.equal(
|
||||
this.element.textContent.trim(),
|
||||
`${HCP_PREFIX}?cluster_version=${clusterVersion}`
|
||||
);
|
||||
|
||||
// not enough items in id
|
||||
this.resourceId =
|
||||
'`organization/b4432207-bb9c-438e-a160-b98923efa979/project/${projectId}/hashicorp.consul.global-network-manager.cluster`';
|
||||
await render(hbs`{{hcp-authentication-link resourceId}}`);
|
||||
assert.equal(
|
||||
this.element.textContent.trim(),
|
||||
`${HCP_PREFIX}?cluster_version=${clusterVersion}`
|
||||
);
|
||||
|
||||
// value is null
|
||||
this.resourceId = null;
|
||||
await render(hbs`{{hcp-authentication-link resourceId}}`);
|
||||
await render(hbs`{{hcp-authentication-link dcName}}`);
|
||||
assert.equal(
|
||||
this.element.textContent.trim(),
|
||||
`${HCP_PREFIX}?cluster_version=${clusterVersion}`
|
||||
);
|
||||
});
|
||||
|
||||
test('it makes a URL out of a real resourceId and accessLevel, if passed', async function (assert) {
|
||||
this.resourceId = realResourceId;
|
||||
test('it makes a URL out of a dc name and accessLevel, if passed', async function (assert) {
|
||||
this.dcName = clusterName;
|
||||
this.accessMode = accessMode;
|
||||
|
||||
await render(hbs`{{hcp-authentication-link resourceId accessMode}}`);
|
||||
await render(hbs`{{hcp-authentication-link dcName accessMode}}`);
|
||||
|
||||
assert.equal(
|
||||
this.element.textContent.trim(),
|
||||
|
|
Loading…
Reference in New Issue