///////////////////////////////////////////////////////////// // // pgAdmin 4 - PostgreSQL Tools // // Copyright (C) 2013 - 2023, The pgAdmin Development Team // This software is released under the PostgreSQL Licence // ////////////////////////////////////////////////////////////// import '../helper/enzyme.helper'; import { createMount } from '@material-ui/core/test-utils'; import PgaJobStepSchema from '../../../pgadmin/browser/server_groups/servers/pgagent/steps/static/js/pga_jobstep.ui'; import {genericBeforeEach, getCreateView, getEditView, getPropertiesView} from '../genericFunctions'; describe('PgaJobStepSchema', ()=>{ let mount; let schemaObj = new PgaJobStepSchema( { databases: ()=>[], }, [], { jstdbname: 'postgres', } ); let getInitData = ()=>Promise.resolve({}); /* Use createMount so that material ui components gets the required context */ /* https://material-ui.com/guides/testing/#api */ beforeAll(()=>{ mount = createMount(); }); afterAll(() => { mount.cleanUp(); }); beforeEach(()=>{ genericBeforeEach(); }); it('create', ()=>{ mount(getCreateView(schemaObj)); }); it('edit', ()=>{ mount(getEditView(schemaObj, getInitData)); }); it('properties', ()=>{ mount(getPropertiesView(schemaObj, getInitData)); }); it('validate', ()=>{ let state = {}; let setError = jasmine.createSpy('setError'); state.name = 'my_step'; state.jstkind = true; state.jstconntype = true; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstdbname', 'Please select a database.'); state.jstdbname = 'postgres'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstdbname', null); state.jstconntype = false; state.jstconnstr = null; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstconnstr', 'Please enter a connection string.'); state.jstconnstr = '**!!'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstconnstr', 'Please enter a connection string.'); state.jstconnstr = 'host:\'192.168.1.7\''; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstconnstr', 'Please enter a valid connection string.'); state.jstconnstr = 'host:\'192.168.1.7\''; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstconnstr', 'Please enter a valid connection string.'); state.jstconnstr = 'hostaddrtest=\'192.168.1.7\''; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstconnstr', 'Invalid parameter in the connection string - hostaddrtest.'); state.jstconnstr = 'host=\'192.168.1.7\' port=5432'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstconnstr', null); state.jstcode = null; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstcode', 'Please specify code to execute.'); state.jstcode = 'PERFORM 1;'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstcode', null); state.jstonerror = null; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstonerror', 'Please select valid on error option.'); state.jstonerror = 'f'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('jstonerror', null); }); });