///////////////////////////////////////////////////////////// // // pgAdmin 4 - PostgreSQL Tools // // Copyright (C) 2013 - 2024, The pgAdmin Development Team // This software is released under the PostgreSQL Licence // ////////////////////////////////////////////////////////////// import BaseUISchema from 'sources/SchemaView/base_schema.ui'; import MViewSchema from '../../../pgadmin/browser/server_groups/servers/databases/schemas/views/static/js/mview.ui'; import {genericBeforeEach, getCreateView, getEditView, getPropertiesView} from '../genericFunctions'; import { initializeSchemaWithData } from './utils'; class MockSchema extends BaseUISchema { get baseFields() { return []; } } describe('MaterializedViewSchema', ()=>{ const createSchemaObject = () => new MViewSchema( ()=>new MockSchema(), ()=>new MockSchema(), { role: ()=>[], schema: ()=>[], spcname: ()=>[], }, { owner: 'postgres', schema: 'public' } ); let schemaObj = createSchemaObject(); let getInitData = ()=>Promise.resolve({}); beforeEach(()=>{ genericBeforeEach(); }); it('create', async ()=>{ await getCreateView(createSchemaObject()); }); it('edit', async ()=>{ await getEditView(createSchemaObject(), getInitData); }); it('properties', async ()=>{ await getPropertiesView(createSchemaObject(), getInitData); }); it('validate', ()=>{ initializeSchemaWithData(schemaObj, {}); let state = {}; let setError = jest.fn(); state.definition = null; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('definition', 'Please enter view code.'); state.definition = 'SELECT 1;'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('definition', null); state.definition = 'SELECT 1'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('definition', null); state.service = 'Test'; state.definition = 'SELECT 1'; schemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('definition', null); }); });