mirror of
https://github.com/usebruno/bruno.git
synced 2025-01-13 09:28:17 +01:00
fix/collection export import (#2601)
* pr review changes * collection root object in export json * import environment updates * tests run execution order fix for collection runs * headers schema update, export only required parts of request * update auth in object spread * docs not present in folder level settings * docs not present in folder level settings --------- Co-authored-by: Anoop M D <anoop.md1421@gmail.com>
This commit is contained in:
parent
e5425299a2
commit
58c8085a64
@ -383,17 +383,51 @@ export const transformCollectionToSaveToExportAsFile = (collection, options = {}
|
|||||||
|
|
||||||
if (si.type == 'folder' && si?.root) {
|
if (si.type == 'folder' && si?.root) {
|
||||||
di.root = {
|
di.root = {
|
||||||
request: {
|
request: {}
|
||||||
headers: si?.root?.request?.headers,
|
|
||||||
script: si?.root?.request?.script,
|
|
||||||
vars: si?.root?.request?.vars,
|
|
||||||
tests: si?.root?.request?.tests
|
|
||||||
},
|
|
||||||
docs: si?.root?.request?.docs,
|
|
||||||
meta: {
|
|
||||||
name: si?.root?.meta?.name
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let { request, meta } = si?.root || {};
|
||||||
|
let { headers, script, vars, tests } = request || {};
|
||||||
|
|
||||||
|
// folder level headers
|
||||||
|
if (headers?.length) {
|
||||||
|
di.root.request.headers = headers;
|
||||||
|
}
|
||||||
|
// folder level script
|
||||||
|
if (Object.keys(script)?.length) {
|
||||||
|
di.root.request.script = {};
|
||||||
|
if (script?.req?.length) {
|
||||||
|
di.root.request.script.req = script?.req;
|
||||||
|
}
|
||||||
|
if (script?.res?.length) {
|
||||||
|
di.root.request.script.res = script?.res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// folder level vars
|
||||||
|
if (Object.keys(vars)?.length) {
|
||||||
|
di.root.request.vars = {};
|
||||||
|
if (vars?.req?.length) {
|
||||||
|
di.root.request.vars.req = vars?.req;
|
||||||
|
}
|
||||||
|
if (vars?.res?.length) {
|
||||||
|
di.root.request.vars.res = vars?.res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// folder level tests
|
||||||
|
if (tests?.length) {
|
||||||
|
di.root.request.tests = tests;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (meta?.name) {
|
||||||
|
di.root.meta = {};
|
||||||
|
di.root.meta.name = meta?.name;
|
||||||
|
}
|
||||||
|
if (!Object.keys(di.root.request)?.length) {
|
||||||
|
delete di.root.request;
|
||||||
|
}
|
||||||
|
if (!Object.keys(di.root)?.length) {
|
||||||
|
delete di.root;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (si.type === 'js') {
|
if (si.type === 'js') {
|
||||||
@ -418,24 +452,59 @@ export const transformCollectionToSaveToExportAsFile = (collection, options = {}
|
|||||||
collectionToSave.items = [];
|
collectionToSave.items = [];
|
||||||
collectionToSave.activeEnvironmentUid = collection.activeEnvironmentUid;
|
collectionToSave.activeEnvironmentUid = collection.activeEnvironmentUid;
|
||||||
collectionToSave.environments = collection.environments || [];
|
collectionToSave.environments = collection.environments || [];
|
||||||
|
|
||||||
collectionToSave.root = {
|
collectionToSave.root = {
|
||||||
request: {
|
request: {}
|
||||||
auth: collection?.root?.request?.auth,
|
|
||||||
headers: collection?.root?.request?.headers,
|
|
||||||
script: collection?.root?.request?.script,
|
|
||||||
vars: collection?.root?.request?.vars,
|
|
||||||
tests: collection?.root?.request?.tests
|
|
||||||
},
|
|
||||||
docs: collection?.root?.request?.docs,
|
|
||||||
meta: {
|
|
||||||
name: collection?.root?.meta?.name || collection?.name
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!collection?.root?.request?.auth?.mode) {
|
let { request, docs, meta } = collection?.root || {};
|
||||||
collectionToSave.root.request.auth = {
|
let { auth, headers, script, vars, tests } = request || {};
|
||||||
mode: 'none'
|
|
||||||
};
|
// collection level auth
|
||||||
|
if (auth?.mode) {
|
||||||
|
collectionToSave.root.request.auth = auth;
|
||||||
|
}
|
||||||
|
// collection level headers
|
||||||
|
if (headers?.length) {
|
||||||
|
collectionToSave.root.request.headers = headers;
|
||||||
|
}
|
||||||
|
// collection level script
|
||||||
|
if (Object.keys(script)?.length) {
|
||||||
|
collectionToSave.root.request.script = {};
|
||||||
|
if (script?.req?.length) {
|
||||||
|
collectionToSave.root.request.script.req = script?.req;
|
||||||
|
}
|
||||||
|
if (script?.res?.length) {
|
||||||
|
collectionToSave.root.request.script.res = script?.res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// collection level vars
|
||||||
|
if (Object.keys(vars)?.length) {
|
||||||
|
collectionToSave.root.request.vars = {};
|
||||||
|
if (vars?.req?.length) {
|
||||||
|
collectionToSave.root.request.vars.req = vars?.req;
|
||||||
|
}
|
||||||
|
if (vars?.res?.length) {
|
||||||
|
collectionToSave.root.request.vars.res = vars?.res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// collection level tests
|
||||||
|
if (tests?.length) {
|
||||||
|
collectionToSave.root.request.tests = tests;
|
||||||
|
}
|
||||||
|
// collection level docs
|
||||||
|
if (docs?.length) {
|
||||||
|
collectionToSave.root.docs = docs;
|
||||||
|
}
|
||||||
|
if (meta?.name) {
|
||||||
|
collectionToSave.root.meta = {};
|
||||||
|
collectionToSave.root.meta.name = meta?.name;
|
||||||
|
}
|
||||||
|
if (!Object.keys(collectionToSave.root.request)?.length) {
|
||||||
|
delete collectionToSave.root.request;
|
||||||
|
}
|
||||||
|
if (!Object.keys(collectionToSave.root)?.length) {
|
||||||
|
delete collectionToSave.root;
|
||||||
}
|
}
|
||||||
|
|
||||||
collectionToSave.brunoConfig = cloneDeep(collection?.brunoConfig);
|
collectionToSave.brunoConfig = cloneDeep(collection?.brunoConfig);
|
||||||
|
@ -1030,8 +1030,8 @@ const registerNetworkIpc = (mainWindow) => {
|
|||||||
|
|
||||||
// run tests
|
// run tests
|
||||||
const testFile = compact([
|
const testFile = compact([
|
||||||
get(collectionRoot, 'request.tests'),
|
item.draft ? get(item.draft, 'request.tests') : get(item, 'request.tests'),
|
||||||
item.draft ? get(item.draft, 'request.tests') : get(item, 'request.tests')
|
get(collectionRoot, 'request.tests')
|
||||||
]).join(os.EOL);
|
]).join(os.EOL);
|
||||||
if (typeof testFile === 'string') {
|
if (typeof testFile === 'string') {
|
||||||
const testRuntime = new TestRuntime();
|
const testRuntime = new TestRuntime();
|
||||||
|
@ -188,7 +188,8 @@ const authSchema = Yup.object({
|
|||||||
oauth2: oauth2Schema.nullable()
|
oauth2: oauth2Schema.nullable()
|
||||||
})
|
})
|
||||||
.noUnknown(true)
|
.noUnknown(true)
|
||||||
.strict();
|
.strict()
|
||||||
|
.nullable();
|
||||||
|
|
||||||
const requestParamsSchema = Yup.object({
|
const requestParamsSchema = Yup.object({
|
||||||
uid: uidSchema,
|
uid: uidSchema,
|
||||||
@ -233,14 +234,15 @@ const requestSchema = Yup.object({
|
|||||||
|
|
||||||
const folderRootSchema = Yup.object({
|
const folderRootSchema = Yup.object({
|
||||||
request: Yup.object({
|
request: Yup.object({
|
||||||
headers: Yup.array().of(keyValueSchema),
|
headers: Yup.array().of(keyValueSchema).nullable(),
|
||||||
auth: authSchema,
|
auth: authSchema,
|
||||||
script: Yup.object({
|
script: Yup.object({
|
||||||
req: Yup.string().nullable(),
|
req: Yup.string().nullable(),
|
||||||
res: Yup.string().nullable()
|
res: Yup.string().nullable()
|
||||||
})
|
})
|
||||||
.noUnknown(true)
|
.noUnknown(true)
|
||||||
.strict(),
|
.strict()
|
||||||
|
.nullable(),
|
||||||
vars: Yup.object({
|
vars: Yup.object({
|
||||||
req: Yup.array().of(varsSchema).nullable(),
|
req: Yup.array().of(varsSchema).nullable(),
|
||||||
res: Yup.array().of(varsSchema).nullable()
|
res: Yup.array().of(varsSchema).nullable()
|
||||||
|
Loading…
Reference in New Issue
Block a user