Skip to content

Commit

Permalink
Add a test proving it fixes the above scenarios
Browse files Browse the repository at this point in the history
Signed-off-by: Derek Ho <[email protected]>
  • Loading branch information
derek-ho committed Jan 25, 2024
1 parent 099e5ce commit 602a2bf
Showing 1 changed file with 60 additions and 8 deletions.
68 changes: 60 additions & 8 deletions public/apps/account/test/account-app.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 +13,12 @@
* permissions and limitations under the License.
*/

import { shallow } from 'enzyme';
import React from 'react';
import { setupTopNavButton } from '../account-app';
import {
getShouldShowTenantPopup,
setShouldShowTenantPopup,
getSavedTenant,
} from '../../../utils/storage-utils';
import { setShouldShowTenantPopup, getSavedTenant } from '../../../utils/storage-utils';
import { fetchAccountInfoSafe } from '../utils';
import { fetchCurrentAuthType } from '../../../utils/logout-utils';
import { fetchCurrentTenant, selectTenant } from '../../configuration/utils/tenant-utils';
import { fetchCurrentTenant } from '../../configuration/utils/tenant-utils';
import { getDashboardsInfoSafe } from '../../../utils/dashboards-info-utils';

jest.mock('../../../utils/storage-utils', () => ({
getShouldShowTenantPopup: jest.fn(),
Expand All @@ -35,6 +30,10 @@ jest.mock('../utils', () => ({
fetchAccountInfoSafe: jest.fn(),
}));

jest.mock('../../../utils/dashboards-info-utils.tsx', () => ({
getDashboardsInfoSafe: jest.fn(),
}));

jest.mock('../../../utils/logout-utils', () => ({
fetchCurrentAuthType: jest.fn(),
}));
Expand All @@ -56,6 +55,7 @@ describe('Account app', () => {
const mockConfig = {
multitenancy: {
enable_aggregation_view: true,
enabled: true,
},
};

Expand All @@ -67,12 +67,18 @@ describe('Account app', () => {
},
};

const mockDashboardsInfo = {
default_tenant: '',
multitenancy_enabled: true,
};

const mockTenant = 'test1';

beforeAll(() => {
(fetchAccountInfoSafe as jest.Mock).mockResolvedValue(mockAccountInfo);
(fetchCurrentAuthType as jest.Mock).mockResolvedValue('dummy');
(fetchCurrentTenant as jest.Mock).mockResolvedValue(mockTenant);
(getDashboardsInfoSafe as jest.Mock).mockResolvedValue(mockDashboardsInfo);
});

it('Should skip if auto swich if securitytenant in url', (done) => {
Expand Down Expand Up @@ -116,4 +122,50 @@ describe('Account app', () => {
done();
});
});

it('Should not show tenant selection popup when multitenancy is disabled from security index', (done) => {
(getDashboardsInfoSafe as jest.Mock).mockResolvedValueOnce({
default_tenant: '',
multitenancy_enabled: false,
});

setupTopNavButton(mockCoreStart, mockConfig as any);

process.nextTick(() => {
expect(getSavedTenant).toBeCalledTimes(0);
expect(setShouldShowTenantPopup).toBeCalledWith(false);
done();
});
});

it('Should not show tenant selection popup when multitenancy is disabled dynamically', (done) => {
const multiTenancyDisabledConfig = {
multitenancy: {
enable_aggregation_view: true,
enabled: false,
},
};
setupTopNavButton(mockCoreStart, multiTenancyDisabledConfig as any);

process.nextTick(() => {
expect(getSavedTenant).toBeCalledTimes(0);
expect(setShouldShowTenantPopup).toBeCalledWith(false);
done();
});
});

it('Should not show tenant selection popup when default tenant is set from security index', (done) => {
(getDashboardsInfoSafe as jest.Mock).mockResolvedValueOnce({
default_tenant: 'Global',
multitenancy_enabled: true,
});

setupTopNavButton(mockCoreStart, mockConfig as any);

process.nextTick(() => {
expect(getSavedTenant).toBeCalledTimes(0);
expect(setShouldShowTenantPopup).toBeCalledWith(false);
done();
});
});
});

0 comments on commit 602a2bf

Please sign in to comment.