///////////////////////////////////////////////////////////// // // pgAdmin 4 - PostgreSQL Tools // // Copyright (C) 2013 - 2021, The pgAdmin Development Team // This software is released under the PostgreSQL Licence // ////////////////////////////////////////////////////////////// import jasmineEnzyme from 'jasmine-enzyme'; import React from 'react'; import '../helper/enzyme.helper'; import { createMount } from '@material-ui/core/test-utils'; import pgAdmin from 'sources/pgadmin'; import {messages} from '../fake_messages'; import SchemaView from '../../../pgadmin/static/js/SchemaView'; import * as nodeAjax from '../../../pgadmin/browser/static/js/node_ajax'; import IndexSchema, { getColumnSchema } from '../../../pgadmin/browser/server_groups/servers/databases/schemas/tables/indexes/static/js/index.ui'; describe('IndexSchema', ()=>{ let mount; describe('column schema describe', () => { let columnSchemaObj = getColumnSchema({}, {server: {user: {name: 'postgres'}}}, {}); it('column schema collection', ()=>{ spyOn(nodeAjax, 'getNodeAjaxOptions').and.returnValue([]); spyOn(nodeAjax, 'getNodeListByName').and.returnValue([]); mount({}} onClose={()=>{}} onHelp={()=>{}} onEdit={()=>{}} onDataChange={()=>{}} confirmOnCloseReset={false} hasSQL={false} disableSqlHelp={false} disableDialogHelp={false} />); mount({}} onClose={()=>{}} getInitData={getInitData} onHelp={()=>{}} onEdit={()=>{}} onDataChange={()=>{}} confirmOnCloseReset={false} hasSQL={false} disableSqlHelp={false} disableDialogHelp={false} />); }); it('column schema colname editable', ()=>{ columnSchemaObj._top = { _sessData: { amname: 'btree' } }; let cell = _.find(columnSchemaObj.fields, (f)=>f.id=='op_class').cell; cell(); }); it('column schema sort_order depChange', ()=>{ let topState = { amname: 'btree' }; let depChange = _.find(columnSchemaObj.fields, (f)=>f.id=='sort_order').depChange; let state = { sort_order: true }; depChange(state, {}, topState, { oldState: { sort_order: false } }); state.sort_order = false; topState.amname = 'abc'; depChange(state, {}, topState, { oldState: { sort_order: false } }); expect(state.is_sort_nulls_applicable).toBe(false); }); it('column schema sort_order editable', ()=>{ columnSchemaObj._top = { _sessData: { amname: 'btree' } }; let state = {}; spyOn(columnSchemaObj, 'inSchemaWithModelCheck').and.returnValue(true); let editable = _.find(columnSchemaObj.fields, (f)=>f.id=='sort_order').editable; let status = editable(state); expect(status).toBe(false); spyOn(columnSchemaObj, 'inSchemaWithModelCheck').and.returnValue(false); status = editable(state); expect(status).toBe(true); columnSchemaObj._top._sessData.amname = 'abc'; status = editable(state); expect(status).toBe(false); }); it('column schema nulls editable', ()=>{ columnSchemaObj._top = { _sessData: { amname: 'btree' } }; let state = {}; spyOn(columnSchemaObj, 'inSchemaWithModelCheck').and.returnValue(true); let editable = _.find(columnSchemaObj.fields, (f)=>f.id=='nulls').editable; let status = editable(state); expect(status).toBe(false); spyOn(columnSchemaObj, 'inSchemaWithModelCheck').and.returnValue(false); status = editable(state); expect(status).toBe(true); columnSchemaObj._top._sessData.amname = 'abc'; status = editable(state); expect(status).toBe(false); }); it('column schema setOpClassTypes', ()=>{ columnSchemaObj._top = { _sessData: { amname: 'btree' } }; let options = []; columnSchemaObj.op_class_types = []; let status = columnSchemaObj.setOpClassTypes(options); expect(status).toEqual([]); columnSchemaObj.op_class_types = []; options.push({label: '', value: ''}); status = columnSchemaObj.setOpClassTypes(options); expect(columnSchemaObj.op_class_types.length).toBe(1); }); }); let indexSchemaObj = new IndexSchema( ()=>getColumnSchema({}, {server: {user: {name: 'postgres'}}}, {}), { tablespaceList: ()=>[], amnameList : ()=>[{label:'abc', value:'abc'}], columnList: ()=>[{label:'abc', value:'abc'}], }, { node_info: {'server': { 'version': 110000} } }, { amname: 'btree' } ); 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(()=>{ jasmineEnzyme(); /* messages used by validators */ pgAdmin.Browser = pgAdmin.Browser || {}; pgAdmin.Browser.messages = pgAdmin.Browser.messages || messages; pgAdmin.Browser.utils = pgAdmin.Browser.utils || {}; }); it('create', ()=>{ mount({}} onClose={()=>{}} onHelp={()=>{}} onEdit={()=>{}} onDataChange={()=>{}} confirmOnCloseReset={false} hasSQL={false} disableSqlHelp={false} disableDialogHelp={false} />); }); it('edit', ()=>{ mount({}} onClose={()=>{}} onHelp={()=>{}} onEdit={()=>{}} onDataChange={()=>{}} confirmOnCloseReset={false} hasSQL={false} disableSqlHelp={false} disableDialogHelp={false} />); }); it('properties', ()=>{ mount({}} onEdit={()=>{}} />); }); it('validate', ()=>{ let state = { columns: [] }; let setError = jasmine.createSpy('setError'); indexSchemaObj.validate(state, setError); expect(setError).toHaveBeenCalledWith('columns', 'You must specify at least one column.'); state.columns.push({}); let status = indexSchemaObj.validate(state, setError); expect(status).toBe(null); }); });