[ aws . apigateway ]

test-invoke-method

Description

Simulate the execution of a Method in your RestApi with headers, parameters, and an incoming request body.

See also: AWS API Documentation

See ‘aws help’ for descriptions of global parameters.

Synopsis

  test-invoke-method
--rest-api-id <value>
--resource-id <value>
--http-method <value>
[--path-with-query-string <value>]
[--body <value>]
[--headers <value>]
[--multi-value-headers <value>]
[--client-certificate-id <value>]
[--stage-variables <value>]
[--cli-input-json | --cli-input-yaml]
[--generate-cli-skeleton <value>]
[--cli-auto-prompt <value>]

Options

--rest-api-id (string)

[Required] The string identifier of the associated RestApi .

--resource-id (string)

[Required] Specifies a test invoke method request’s resource ID.

--http-method (string)

[Required] Specifies a test invoke method request’s HTTP method.

--path-with-query-string (string)

The URI path, including query string, of the simulated invocation request. Use this to specify path parameters and query string parameters.

--body (string)

The simulated request body of an incoming invocation request.

--headers (map)

A key-value map of headers to simulate an incoming invocation request.

key -> (string)

value -> (string)

Shorthand Syntax:

KeyName1=string,KeyName2=string

JSON Syntax:

{"string": "string"
  ...}

--multi-value-headers (map)

The headers as a map from string to list of values to simulate an incoming invocation request.

key -> (string)

value -> (list)

(string)

Shorthand Syntax:

KeyName1=string,string,KeyName2=string,string

JSON Syntax:

{"string": ["string", ...]
  ...}

--client-certificate-id (string)

A ClientCertificate identifier to use in the test invocation. API Gateway will use the certificate when making the HTTPS request to the defined back-end endpoint.

--stage-variables (map)

A key-value map of stage variables to simulate an invocation on a deployed Stage .

key -> (string)

value -> (string)

Shorthand Syntax:

KeyName1=string,KeyName2=string

JSON Syntax:

{"string": "string"
  ...}

--cli-input-json | --cli-input-yaml (string) Reads arguments from the JSON string provided. The JSON string follows the format provided by --generate-cli-skeleton. If other arguments are provided on the command line, those values will override the JSON-provided values. It is not possible to pass arbitrary binary values using a JSON-provided value as the string will be taken literally. This may not be specified along with --cli-input-yaml.

--generate-cli-skeleton (string) Prints a JSON skeleton to standard output without sending an API request. If provided with no value or the value input, prints a sample input JSON that can be used as an argument for --cli-input-json. Similarly, if provided yaml-input it will print a sample input YAML that can be used with --cli-input-yaml. If provided with the value output, it validates the command inputs and returns a sample output JSON for that command.

--cli-auto-prompt (boolean) Automatically prompt for CLI input parameters.

See ‘aws help’ for descriptions of global parameters.

Examples

To test invoke the root resource in an API by making a GET request

Command:

aws apigateway test-invoke-method --rest-api-id 1234123412 --resource-id avl5sg8fw8 --http-method GET --path-with-query-string '/'

To test invoke a sub-resource in an API by making a GET request with a path parameter value specified

Command:

aws apigateway test-invoke-method --rest-api-id 1234123412 --resource-id 3gapai --http-method GET --path-with-query-string '/pets/1'

Output

status -> (integer)

The HTTP status code.

body -> (string)

The body of the HTTP response.

headers -> (map)

The headers of the HTTP response.

key -> (string)

value -> (string)

multiValueHeaders -> (map)

The headers of the HTTP response as a map from string to list of values.

key -> (string)

value -> (list)

(string)

log -> (string)

The API Gateway execution log for the test invoke request.

latency -> (long)

The execution latency of the test invoke request.