Hide the hcp link banner behind an env variable (#20392)

This commit is contained in:
Chris Hut 2024-01-29 15:38:21 -08:00 committed by GitHub
parent 9f90060b0f
commit da42f7a00b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 28 additions and 7 deletions

View File

@ -3,17 +3,19 @@
* SPDX-License-Identifier: BUSL-1.1 * SPDX-License-Identifier: BUSL-1.1
*/ */
import Service from '@ember/service'; import Service, { inject as service } from '@ember/service';
import { tracked } from '@glimmer/tracking'; import { tracked } from '@glimmer/tracking';
const LOCAL_STORAGE_KEY = 'consul:hideHcpLinkBanner'; const LOCAL_STORAGE_KEY = 'consul:hideHcpLinkBanner';
export default class HcpLinkStatus extends Service { export default class HcpLinkStatus extends Service {
@service('env') env;
@tracked @tracked
userDismissedBanner = false; userDismissedBanner = false;
get shouldDisplayBanner() { get shouldDisplayBanner() {
return !this.userDismissedBanner; const hcpLinkEnabled = this.env.var('CONSUL_HCP_LINK_ENABLED');
return !this.userDismissedBanner && hcpLinkEnabled;
} }
constructor() { constructor() {

View File

@ -146,7 +146,7 @@ export default function (config = {}, win = window, doc = document) {
case 'CONSUL_API_PREFIX': case 'CONSUL_API_PREFIX':
// we want API prefix to look like an env var for if we ever change // we want API prefix to look like an env var for if we ever change
// operator config to be an API request, we need this variable before we // operator config to be an API request, we need this variable before we
// make and API request so this specific variable should never be be // make and API request so this specific variable should never be
// retrived via an API request // retrived via an API request
return operatorConfig.APIPrefix; return operatorConfig.APIPrefix;
case 'CONSUL_HCP_URL': case 'CONSUL_HCP_URL':

View File

@ -6,6 +6,7 @@
import { module, test } from 'qunit'; import { module, test } from 'qunit';
import { click, visit } from '@ember/test-helpers'; import { click, visit } from '@ember/test-helpers';
import { setupApplicationTest } from 'ember-qunit'; import { setupApplicationTest } from 'ember-qunit';
import { EnvStub } from 'consul-ui/services/env';
const bannerSelector = '[data-test-link-to-hcp-banner]'; const bannerSelector = '[data-test-link-to-hcp-banner]';
module('Acceptance | link to hcp banner', function (hooks) { module('Acceptance | link to hcp banner', function (hooks) {
@ -14,9 +15,14 @@ module('Acceptance | link to hcp banner', function (hooks) {
hooks.beforeEach(function () { hooks.beforeEach(function () {
// clear local storage so we don't have any settings // clear local storage so we don't have any settings
window.localStorage.clear(); window.localStorage.clear();
// setupTestEnv(this.owner, { this.owner.register(
// CONSUL_ACLS_ENABLED: true, 'service:env',
// }); class Stub extends EnvStub {
stubEnv = {
CONSUL_HCP_LINK_ENABLED: true,
};
}
);
}); });
test('the banner is initially displayed on services page', async function (assert) { test('the banner is initially displayed on services page', async function (assert) {
@ -32,4 +38,17 @@ module('Acceptance | link to hcp banner', function (hooks) {
await visit('/'); await visit('/');
assert.dom(bannerSelector).doesNotExist('Banner is still gone after refresh'); assert.dom(bannerSelector).doesNotExist('Banner is still gone after refresh');
}); });
test('the banner is not displayed if the env var is not set', async function (assert) {
this.owner.register(
'service:env',
class Stub extends EnvStub {
stubEnv = {};
}
);
// default route is services page so we're good here
await visit('/');
// Expect the banner to be visible by default
assert.dom(bannerSelector).doesNotExist('Banner is not here');
});
}); });

View File

@ -31,7 +31,7 @@ module('Integration | Component | link-to-hcp-banner', function (hooks) {
'service:env', 'service:env',
class Stub extends EnvStub { class Stub extends EnvStub {
stubEnv = { stubEnv = {
isEnterprise: false, CONSUL_HCP_LINK_ENABLED: true,
}; };
} }
); );