forked from extern/bruno
feat: bruno lang support for parsing xml body
This commit is contained in:
parent
a645d1459c
commit
5e1d6cba4a
@ -61,17 +61,11 @@ assert
|
|||||||
}
|
}
|
||||||
/assert
|
/assert
|
||||||
|
|
||||||
vars
|
docs
|
||||||
1 petId $res.data.id
|
|
||||||
/vars
|
|
||||||
|
|
||||||
readme
|
|
||||||
Documentation about the request
|
Documentation about the request
|
||||||
/readme
|
/docs
|
||||||
|
|
||||||
response-example
|
response-example(name="Created", status=201)
|
||||||
name Created
|
|
||||||
status 201
|
|
||||||
headers
|
headers
|
||||||
1 content-type application/json
|
1 content-type application/json
|
||||||
1 accept-language en-US,en;q=0.9,hi;q=0.8
|
1 accept-language en-US,en;q=0.9,hi;q=0.8
|
||||||
|
@ -15,7 +15,10 @@ const bodyGraphqlBegin = regex(/^body\s*\(\s*type\s*=\s*graphql\s*\)\s*\r?\n/);
|
|||||||
// body(type=text)
|
// body(type=text)
|
||||||
const bodyTextBegin = regex(/^body\s*\(\s*type\s*=\s*text\s*\)\s*\r?\n/);
|
const bodyTextBegin = regex(/^body\s*\(\s*type\s*=\s*text\s*\)\s*\r?\n/);
|
||||||
|
|
||||||
const bodyEnd = regex(/^\/body\s*[\r?\n]*/);
|
// body(type=xml)
|
||||||
|
const bodyXmlBegin = regex(/^body\s*\(\s*type\s*=\s*xml\s*\)\s*\r?\n/);
|
||||||
|
|
||||||
|
const bodyEnd = regex(/^[\r?\n]+\/body\s*[\r?\n]*/);
|
||||||
|
|
||||||
const bodyJsonTag = between(bodyJsonBegin)(bodyEnd)(everyCharUntil(bodyEnd)).map((bodyJson) => {
|
const bodyJsonTag = between(bodyJsonBegin)(bodyEnd)(everyCharUntil(bodyEnd)).map((bodyJson) => {
|
||||||
if(bodyJson && bodyJson.length) {
|
if(bodyJson && bodyJson.length) {
|
||||||
@ -62,8 +65,17 @@ const bodyTextTag = between(bodyTextBegin)(bodyEnd)(everyCharUntil(bodyEnd)).map
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const bodyXmlTag = between(bodyXmlBegin)(bodyEnd)(everyCharUntil(bodyEnd)).map((bodyXml) => {
|
||||||
|
return {
|
||||||
|
body: {
|
||||||
|
xml: bodyXml
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
bodyJsonTag,
|
bodyJsonTag,
|
||||||
bodyGraphqlTag,
|
bodyGraphqlTag,
|
||||||
bodyTextTag
|
bodyTextTag,
|
||||||
|
bodyXmlTag
|
||||||
};
|
};
|
||||||
|
@ -11,7 +11,8 @@ const headersTag = require('./headers-tag');
|
|||||||
const {
|
const {
|
||||||
bodyJsonTag,
|
bodyJsonTag,
|
||||||
bodyGraphqlTag,
|
bodyGraphqlTag,
|
||||||
bodyTextTag
|
bodyTextTag,
|
||||||
|
bodyXmlTag
|
||||||
} = require('./body-tag');
|
} = require('./body-tag');
|
||||||
|
|
||||||
const bruToJson = (fileContents) => {
|
const bruToJson = (fileContents) => {
|
||||||
@ -22,6 +23,7 @@ const bruToJson = (fileContents) => {
|
|||||||
bodyJsonTag,
|
bodyJsonTag,
|
||||||
bodyGraphqlTag,
|
bodyGraphqlTag,
|
||||||
bodyTextTag,
|
bodyTextTag,
|
||||||
|
bodyXmlTag,
|
||||||
anyChar
|
anyChar
|
||||||
]));
|
]));
|
||||||
|
|
||||||
|
@ -36,3 +36,7 @@ body(type=text)
|
|||||||
Hello, there. You must be from the past
|
Hello, there. You must be from the past
|
||||||
/body
|
/body
|
||||||
|
|
||||||
|
body(type=xml)
|
||||||
|
<body>back to the ice age</body>
|
||||||
|
/body
|
||||||
|
|
||||||
|
@ -53,9 +53,10 @@ describe('bruToJson', () => {
|
|||||||
"body": {
|
"body": {
|
||||||
"json": '{"apikey":"secret","numbers":"+91998877665"}',
|
"json": '{"apikey":"secret","numbers":"+91998877665"}',
|
||||||
"graphql": {
|
"graphql": {
|
||||||
"query": " {\n launchesPast {\n launch_success\n }\n }\n"
|
"query": " {\n launchesPast {\n launch_success\n }\n }"
|
||||||
},
|
},
|
||||||
"text": " Hello, there. You must be from the past\n"
|
"text": " Hello, there. You must be from the past",
|
||||||
|
"xml": " <body>back to the ice age</body>"
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user