-
Notifications
You must be signed in to change notification settings - Fork 39
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #93 from mistweaverco/feat/vscode-request-variables
feat(parser): named-requests + request-variables + `replay()`
- Loading branch information
Showing
13 changed files
with
302 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
# Request Variables | ||
|
||
The definition syntax of request variables is just like a single-line comment, | ||
and follows `# @name REQUEST_NAME` just as metadata. | ||
|
||
```http | ||
POST https://httpbin.org/post HTTP/1.1 | ||
Content-Type: application/x-www-form-urlencoded | ||
# @name THIS_IS_AN_EXAMPLE_REQUEST_NAME | ||
name=foo&password=bar | ||
``` | ||
|
||
You can think of request variable as attaching a name metadata to the underlying request, | ||
and this kind of requests can be called with Named Request, | ||
Other requests can use `THIS_IS_AN_EXAMPLE_REQUEST_NAME` as an | ||
identifier to reference the expected part of the named request or its latest response. | ||
|
||
**NOTE:** If you want to refer the response of a named request, | ||
you need to manually trigger the named request to retrieve its response first, | ||
otherwise the plain text of | ||
variable reference like `{{THIS_IS_AN_EXAMPLE_REQUEST_NAME.response.body.$.id}}` will be sent instead. | ||
|
||
The reference syntax of a request variable is a bit more complex than other kinds of custom variables. | ||
|
||
## Request Variable Reference Syntax | ||
|
||
The request variable reference syntax follows `{{REQUEST_NAME.(response|request).(body|headers).(*|JSONPath|XPath|Header Name)}}`. | ||
|
||
You have two reference part choices of the `response` or `request`: `body` and `headers`. | ||
|
||
For `body` part, you can use JSONPath and XPath to extract specific property or attribute. | ||
|
||
## Example | ||
|
||
if a JSON response returns `body` `{"id": "mock"}`, you can set the JSONPath part to `$.id` to reference the `id`. | ||
|
||
For `headers` part, you can specify the header name to extract the header value. | ||
|
||
The header name is case-sensitive for `response` part, and all lower-cased for `request` part. | ||
|
||
If the *JSONPath* or *XPath* of `body`, or *Header Name* of `headers` can't be resolved, | ||
the plain text of variable reference will be sent instead. | ||
And in this case, | ||
diagnostic information will be displayed to help you to inspect this. | ||
|
||
Below is a sample of request variable definitions and references in an http file. | ||
|
||
```http | ||
POST https://httpbin.org/post HTTP/1.1 | ||
accept: application/json | ||
# @name REQUEST_ONE | ||
{ | ||
"token": "foobar" | ||
} | ||
### | ||
POST https://httpbin.org/post HTTP/1.1 | ||
accept: application/json | ||
# @name REQUEST_TWO | ||
{ | ||
"token": "{{REQUEST_ONE.response.body.$.json.token}}" | ||
} | ||
### | ||
POST https://httpbin.org/post HTTP/1.1 | ||
accept: application/json | ||
{ | ||
"date_header": "{{REQUEST_TWO.response.headers['Date']}}" | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
local M = {} | ||
|
||
M.data = { | ||
env = {}, | ||
} | ||
|
||
return M |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.