mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-15 17:31:56 +03:00
e063835b83
https://github.com/hasura/graphql-engine-mono/pull/1940 GitOrigin-RevId: 97fca7b6423309c22a1072b9e380ba724d7bad00
265 lines
5.9 KiB
TypeScript
265 lines
5.9 KiB
TypeScript
import { QueryType } from './../integration/validators/validators';
|
|
import { ADMIN_SECRET_HEADER_KEY } from './constants';
|
|
|
|
export const baseUrl = Cypress.config('baseUrl');
|
|
|
|
export const getDbRoute = (sourceName = 'default') => `/data/${sourceName}`;
|
|
|
|
export const getIndexRoute = (sourceName = 'default', schemaName = 'public') =>
|
|
`${getDbRoute(sourceName)}/schema/${schemaName}/`;
|
|
|
|
export const createVolatileFunction = (name: string) => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: `CREATE OR REPLACE FUNCTION public.${name}()
|
|
RETURNS SETOF text_result
|
|
LANGUAGE sql
|
|
AS $function$
|
|
SELECT * FROM text_result;
|
|
$function$`,
|
|
cascade: false,
|
|
},
|
|
};
|
|
};
|
|
|
|
export const dataTypes = [
|
|
'serial',
|
|
'bigserial',
|
|
'integer',
|
|
'bigint',
|
|
'uuid',
|
|
'text',
|
|
'numeric',
|
|
'date',
|
|
'timestamptz',
|
|
'timetz',
|
|
'boolean',
|
|
];
|
|
|
|
export const typeDefaults: { [key: string]: string } = {
|
|
integer: '5555',
|
|
bigint: '5555555555',
|
|
uuid: 'gen_random_uuid()',
|
|
text: 'test-text',
|
|
numeric: '0.55555',
|
|
date: 'now()',
|
|
timestamptz: 'now()',
|
|
timetz: 'now()',
|
|
boolean: 'false',
|
|
};
|
|
|
|
export const queryTypes: QueryType[] = ['insert', 'select', 'update', 'delete'];
|
|
|
|
export const getColName = (i: number) => `Apic_test_column_${i}`;
|
|
|
|
export const getTableName = (i: number, testName = '') =>
|
|
`Apic_test_table_${testName}_${i}`;
|
|
|
|
export const getElementFromAlias = (alias: string) => `[data-test="${alias}"]`;
|
|
|
|
export const getElementFromClassName = (cn: string) => `.${cn}`;
|
|
|
|
export const tableColumnTypeSelector = (alias: string) => {
|
|
cy.get(`${getElementFromAlias(alias)}`)
|
|
.children('div')
|
|
.click()
|
|
.find('input')
|
|
.focus();
|
|
};
|
|
|
|
export const makeDataAPIUrl = (
|
|
dataApiUrl: string,
|
|
queryEndpoint: QueryEndpoint = 'query'
|
|
) => {
|
|
if (queryEndpoint === 'query') {
|
|
return `${dataApiUrl}/v2/query`;
|
|
}
|
|
return `${dataApiUrl}/v1/metadata`;
|
|
};
|
|
|
|
interface APIPayload {
|
|
[key: string]: any;
|
|
}
|
|
|
|
export const queryEndpoints = {
|
|
query: 'query',
|
|
metadata: 'metadata',
|
|
} as const;
|
|
|
|
export type QueryEndpoint = keyof typeof queryEndpoints;
|
|
|
|
export const makeDataAPIOptions = (
|
|
dataApiUrl: string,
|
|
key: string,
|
|
body: APIPayload,
|
|
queryType: QueryEndpoint = 'query'
|
|
) => ({
|
|
method: 'POST',
|
|
url: makeDataAPIUrl(dataApiUrl, queryType),
|
|
headers: {
|
|
[ADMIN_SECRET_HEADER_KEY]: key,
|
|
},
|
|
body,
|
|
failOnStatusCode: false,
|
|
});
|
|
|
|
export const testCustomFunctionDefinition = (
|
|
i: string
|
|
) => `create function search_posts${`_${i}`} (search text) returns setof post as $$ select * from post where title ilike ('%' || search || '%') or content ilike ('%' || search || '%') $$ language sql stable;
|
|
`;
|
|
|
|
export const getCustomFunctionName = (i: number) => `search_posts${`_${i}`}`;
|
|
|
|
export const getCreateTestFunctionQuery = (i: number) => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: `CREATE OR REPLACE FUNCTION public.search_posts_${i}(search text)\n RETURNS SETOF post\n LANGUAGE sql\n STABLE\nAS $function$\n select *\n from post\n where\n title ilike ('%' || search || '%') or\n content ilike ('%' || search || '%')\n $function$\n`,
|
|
cascade: false,
|
|
},
|
|
};
|
|
};
|
|
|
|
export const getTrackTestFunctionQuery = (i: number) => {
|
|
return {
|
|
type: 'pg_track_function',
|
|
args: {
|
|
function: `search_posts_${i}`,
|
|
schema: 'public',
|
|
source: 'default',
|
|
},
|
|
};
|
|
};
|
|
|
|
export const testCustomFunctionSQLWithSessArg = (
|
|
name = 'customFunctionWithSessionArg'
|
|
) => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: `CREATE OR REPLACE FUNCTION ${name}(
|
|
hasura_session json, name text
|
|
) RETURNS SETOF text_result LANGUAGE sql STABLE AS $$
|
|
SELECT
|
|
q.*
|
|
FROM
|
|
(
|
|
VALUES
|
|
(hasura_session ->> 'x-hasura-role')
|
|
) q $$`,
|
|
cascade: false,
|
|
},
|
|
};
|
|
};
|
|
|
|
export const createUntrackedFunctionSQL = (
|
|
fnName: string,
|
|
tableName: string
|
|
) => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: `
|
|
CREATE OR REPLACE FUNCTION ${fnName}(table_row "${tableName}")
|
|
RETURNS int
|
|
LANGUAGE sql
|
|
STABLE
|
|
AS $function$
|
|
SELECT table_row.id
|
|
$function$
|
|
`,
|
|
cascade: false,
|
|
},
|
|
};
|
|
};
|
|
|
|
export const dropUntrackedFunctionSQL = (fnName: string) => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: `
|
|
DROP FUNCTION public.${fnName};
|
|
`,
|
|
cascade: false,
|
|
},
|
|
};
|
|
};
|
|
|
|
export const getTrackFnPayload = (name = 'customfunctionwithsessionarg') => ({
|
|
type: 'pg_track_function',
|
|
args: {
|
|
function: name,
|
|
source: 'default',
|
|
schema: 'public',
|
|
},
|
|
});
|
|
|
|
// has to go to query
|
|
export const createFunctionTable = () => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: 'create table post (id serial PRIMARY KEY,title TEXT,content TEXT);',
|
|
cascade: false,
|
|
},
|
|
};
|
|
};
|
|
// has to go to metadata
|
|
export const trackCreateFunctionTable = () => {
|
|
return {
|
|
type: 'pg_track_table',
|
|
args: {
|
|
table: {
|
|
name: 'post',
|
|
schema: 'public',
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
export const createSampleTable = () => ({
|
|
type: 'run_sql',
|
|
source: 'default',
|
|
args: {
|
|
sql: 'CREATE TABLE text_result(result text);',
|
|
cascade: false,
|
|
},
|
|
});
|
|
|
|
export const dropTableIfExists = (
|
|
table: { name: string; schema: string },
|
|
source = 'default'
|
|
) => ({
|
|
type: 'run_sql',
|
|
source,
|
|
args: {
|
|
sql: `DROP TABLE IF EXISTS "${table.schema}"."${table.name}";`,
|
|
cascade: false,
|
|
},
|
|
});
|
|
|
|
export const getTrackSampleTableQuery = () => {
|
|
return {
|
|
type: 'pg_track_table',
|
|
source: 'default',
|
|
args: {
|
|
table: {
|
|
name: 'text_result',
|
|
schema: 'public',
|
|
},
|
|
},
|
|
};
|
|
};
|
|
export const dropTable = (table = 'post', cascade = false) => {
|
|
return {
|
|
type: 'run_sql',
|
|
args: {
|
|
sql: `DROP table "public"."${table}"${cascade ? ' CASCADE;' : ';'}`,
|
|
cascade,
|
|
},
|
|
};
|
|
};
|
|
|
|
export const getSchema = () => 'public';
|