mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-14 08:34:07 -08:00
Add tests
This commit is contained in:
parent
f52792921f
commit
1a41dccc1a
|
@ -0,0 +1,70 @@
|
||||||
|
import { createComponentRenderer } from '@/__tests__/render';
|
||||||
|
import CredentialEdit from '@/components/CredentialEdit/CredentialEdit.vue';
|
||||||
|
import { createTestingPinia } from '@pinia/testing';
|
||||||
|
import { CREDENTIAL_EDIT_MODAL_KEY, STORES } from '@/constants';
|
||||||
|
import { cleanupAppModals, createAppModals, retry } from '@/__tests__/utils';
|
||||||
|
|
||||||
|
vi.mock('@/permissions', () => ({
|
||||||
|
getResourcePermissions: vi.fn(() => ({
|
||||||
|
credential: {
|
||||||
|
create: true,
|
||||||
|
update: true,
|
||||||
|
},
|
||||||
|
})),
|
||||||
|
}));
|
||||||
|
|
||||||
|
const renderComponent = createComponentRenderer(CredentialEdit, {
|
||||||
|
pinia: createTestingPinia({
|
||||||
|
initialState: {
|
||||||
|
[STORES.UI]: {
|
||||||
|
modalsById: {
|
||||||
|
[CREDENTIAL_EDIT_MODAL_KEY]: { open: true },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
[STORES.SETTINGS]: {
|
||||||
|
settings: {
|
||||||
|
templates: {
|
||||||
|
host: '',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
describe('CredentialEdit', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
createAppModals();
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
cleanupAppModals();
|
||||||
|
vi.clearAllMocks();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('shows the save button when credentialId is null', async () => {
|
||||||
|
const { queryByTestId } = renderComponent({
|
||||||
|
props: {
|
||||||
|
isTesting: false,
|
||||||
|
isSaving: false,
|
||||||
|
hasUnsavedChanges: false,
|
||||||
|
modalName: CREDENTIAL_EDIT_MODAL_KEY,
|
||||||
|
mode: 'new',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
await retry(() => expect(queryByTestId('credential-save-button')).toBeInTheDocument());
|
||||||
|
});
|
||||||
|
|
||||||
|
test('hides the save button when credentialId exists and there are no unsaved changes', async () => {
|
||||||
|
const { queryByTestId } = renderComponent({
|
||||||
|
props: {
|
||||||
|
activeId: '123', // credentialId will be set to this value in edit mode
|
||||||
|
isTesting: false,
|
||||||
|
isSaving: false,
|
||||||
|
hasUnsavedChanges: false,
|
||||||
|
modalName: CREDENTIAL_EDIT_MODAL_KEY,
|
||||||
|
mode: 'edit',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
await retry(() => expect(queryByTestId('credential-save-button')).not.toBeInTheDocument());
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue