passbolt-styleguide
Version:
Passbolt styleguide contains common styling assets used by the different sites, plugin, etc.
75 lines (68 loc) • 3.72 kB
JavaScript
/**
* Passbolt ~ Open source password manager for teams
* Copyright (c) 2020 Passbolt SA (https://www.passbolt.com)
*
* Licensed under GNU Affero General Public License version 3 of the or any later version.
* For full copyright and license information, please see the LICENSE.txt
* Redistributions of files must retain the above copyright notice.
*
* @copyright Copyright (c) 2020 Passbolt SA (https://www.passbolt.com)
* @license https://opensource.org/licenses/AGPL-3.0 AGPL License
* @link https://www.passbolt.com Passbolt(tm)
* @since 2.11.0
*/
/**
* Unit tests on DisplaySynchronizeUserDirectoryAdministrationDialog in regard of specifications
*/
import {
defaultProps,
mockSynchronizeBody,
} from "./DisplaySynchronizeUserDirectoryAdministration.test.data";
import {mockApiResponse} from '../../../../../test/mocks/mockApiResponse';
import DisplaySynchronizeUserDirectoryAdministrationPage from './DisplaySynchronizeUserDirectoryAdministration.test.page';
import {enableFetchMocks} from 'jest-fetch-mock';
import {defaultAppContext} from "../../../contexts/ApiAppContext.test.data";
import {waitFor} from '@testing-library/react';
beforeEach(() => {
enableFetchMocks();
jest.resetModules();
});
describe("See the synchronize user directory administration dialog", () => {
let page; // The page to test against
const context = defaultAppContext(); // The applicative context
const props = defaultProps(); // The props to pass
describe('As Ad I should see a dialog for my synchronize report', () => {
/**
* I should see the simulate synchronize report dialog page
*/
beforeEach(() => {
fetch.doMockOnceIf(/directorysync\/synchronize*/, () => mockApiResponse(mockSynchronizeBody));
page = new DisplaySynchronizeUserDirectoryAdministrationPage(context, props);
});
it('As AD I should see The full report in the dialog for my synchronize report', async() => {
await waitFor(() => {});
expect(page.title.hyperlink.textContent).toBe("Synchronize report");
expect(page.displaySynchronizeUserDirectoryAdministrationDialog.exists()).toBeTruthy();
expect(page.displaySynchronizeUserDirectoryAdministrationDialog.resourceSynchronize).toBe('2 users have been synchronized.60 groups have been synchronized.');
expect(page.displaySynchronizeUserDirectoryAdministrationDialog.error).toBe('Some resources will not be synchronized and will require your attention, see the full report.');
expect(page.displaySynchronizeUserDirectoryAdministrationDialog.noResource).toBeNull();
await page.displaySynchronizeUserDirectoryAdministrationDialog.click(page.displaySynchronizeUserDirectoryAdministrationDialog.fullReport);
expect(page.displaySynchronizeUserDirectoryAdministrationDialog.textareaReport).not.toBeNull();
await page.displaySynchronizeUserDirectoryAdministrationDialog.click(page.displaySynchronizeUserDirectoryAdministrationDialog.synchronize);
expect(props.onClose).toBeCalled();
expect.assertions(7);
});
});
describe('As Ad I should see a loading dialog for my synchronize report if it\'s not yet loaded', () => {
/**
* I should see the simulate synchronize report loading dialog page
*/
it('As AD I should see the loading dialog', async() => {
page = new DisplaySynchronizeUserDirectoryAdministrationPage(context, props);
expect(page.title.hyperlink.textContent).toBe("Synchronize");
await page.displaySynchronizeUserDirectoryAdministrationDialog.click(page.displaySynchronizeUserDirectoryAdministrationDialog.dialogClose);
expect(props.onClose).toBeCalled();
expect.assertions(2);
});
});
});