57 lines
1.6 KiB
JavaScript
57 lines
1.6 KiB
JavaScript
/////////////////////////////////////////////////////////////
|
|
//
|
|
// pgAdmin 4 - PostgreSQL Tools
|
|
//
|
|
// Copyright (C) 2013 - 2025, The pgAdmin Development Team
|
|
// This software is released under the PostgreSQL Licence
|
|
//
|
|
//////////////////////////////////////////////////////////////
|
|
|
|
|
|
import {getNodePrivilegeRoleSchema} from '../../../pgadmin/browser/server_groups/servers/static/js/privilege.ui';
|
|
import PGSchema from '../../../pgadmin/browser/server_groups/servers/databases/schemas/static/js/schema.ui';
|
|
import {genericBeforeEach, getCreateView, getEditView, getPropertiesView} from '../genericFunctions';
|
|
|
|
describe('PGSchema', ()=>{
|
|
|
|
const createSchemaObject = () => new PGSchema(
|
|
()=>getNodePrivilegeRoleSchema({}, {server: {user: {name: 'postgres'}}}, {}),
|
|
{
|
|
roles:() => [],
|
|
namespaceowner: '',
|
|
}
|
|
);
|
|
let schemaObj = createSchemaObject();
|
|
let getInitData = ()=>Promise.resolve({});
|
|
|
|
|
|
beforeEach(()=>{
|
|
genericBeforeEach();
|
|
});
|
|
|
|
it('create', async ()=>{
|
|
await getCreateView(createSchemaObject());
|
|
});
|
|
|
|
it('schema validate', () => {
|
|
let state = { name: 'abc' };
|
|
let setError = jest.fn();
|
|
|
|
schemaObj.validate(state, setError);
|
|
expect(setError).toHaveBeenCalledWith('namespaceowner', 'Owner cannot be empty.');
|
|
|
|
state.namespaceowner = 'postgres';
|
|
let validate = schemaObj.validate(state, setError);
|
|
expect(validate).toBe(null);
|
|
});
|
|
|
|
it('edit', async ()=>{
|
|
await getEditView(createSchemaObject(), getInitData);
|
|
});
|
|
|
|
it('properties', async ()=>{
|
|
await getPropertiesView(createSchemaObject(), getInitData);
|
|
});
|
|
});
|
|
|