UNPKG

@microsoft.azure/autorest.testserver

Version:

This project contains a set of OpenAPI definitions and a server implementing the corresponding API. Use this to test compliance of AutoRest generators.

621 lines (620 loc) 19.7 kB
{ "swagger": "2.0", "info": { "title": "AutoRest Paging Test Service", "description": "Long-running Operation for AutoRest", "version": "1.0.0" }, "host": "localhost:3000", "schemes": [ "http" ], "produces": [ "application/json" ], "consumes": [ "application/json" ], "paths": { "/paging/noitemname": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink"}, "operationId": "Paging_getNoItemNamePages", "description": "A paging operation that must return result of the default 'value' node.", "responses": { "200": { "description": "A list of products", "schema": { "$ref": "#/definitions/ProductResultValue" } }, "default": { "description": "Unexpected error" } } } }, "/paging/nullnextlink": { "get": { "x-ms-pageable": { "nextLinkName": null, "itemName": "values" }, "operationId": "Paging_getNullNextLinkNamePages", "description": "A paging operation that must ignore any kind of nextLink, and stop after page 1.", "responses": { "200": { "description": "A list of products", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/single": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getSinglePages", "description": "A paging operation that finishes on the first call without a nextlink", "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getMultiplePages", "description": "A paging operation that includes a nextLink that has 10 pages", "parameters": [ { "name": "client-request-id", "in": "header", "required": false, "type": "string" }, { "name": "maxresults", "in": "header", "required": false, "type": "integer", "format": "int32", "description": "Sets the maximum number of items to return in the response.", "x-ms-parameter-grouping": { "postfix": "Options" } }, { "name": "timeout", "in": "header", "required": false, "type": "integer", "format": "int32", "default": 30, "description": "Sets the maximum time that the server can spend processing the request, in seconds. The default is 30 seconds.", "x-ms-parameter-grouping": { "postfix": "Options" } } ], "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/odata": { "get": { "x-ms-pageable": { "nextLinkName": "odata.nextLink", "itemName": "values" }, "operationId": "Paging_getOdataMultiplePages", "description": "A paging operation that includes a nextLink in odata format that has 10 pages", "parameters": [ { "name": "client-request-id", "in": "header", "required": false, "type": "string" }, { "name": "maxresults", "in": "header", "required": false, "type": "integer", "format": "int32", "description": "Sets the maximum number of items to return in the response.", "x-ms-parameter-grouping": { "postfix": "Options" } }, { "name": "timeout", "in": "header", "required": false, "type": "integer", "format": "int32", "default": 30, "description": "Sets the maximum time that the server can spend processing the request, in seconds. The default is 30 seconds.", "x-ms-parameter-grouping": { "postfix": "Options" } } ], "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/OdataProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/withpath/{offset}": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getMultiplePagesWithOffset", "description": "A paging operation that includes a nextLink that has 10 pages", "parameters": [ { "name": "client-request-id", "in": "header", "required": false, "type": "string" }, { "name": "maxresults", "in": "header", "required": false, "type": "integer", "format": "int32", "description": "Sets the maximum number of items to return in the response.", "x-ms-parameter-grouping": { "postfix": "Options" } }, { "name": "offset", "in": "path", "required": true, "type": "integer", "format": "int32", "description": "Offset of return value", "x-ms-parameter-grouping": { "postfix": "Options" } }, { "name": "timeout", "in": "header", "required": false, "type": "integer", "format": "int32", "default": 30, "description": "Sets the maximum time that the server can spend processing the request, in seconds. The default is 30 seconds.", "x-ms-parameter-grouping": { "postfix": "Options" } } ], "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/retryfirst": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getMultiplePagesRetryFirst", "description": "A paging operation that fails on the first call with 500 and then retries and then get a response including a nextLink that has 10 pages", "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/retrysecond": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getMultiplePagesRetrySecond", "description": "A paging operation that includes a nextLink that has 10 pages, of which the 2nd call fails first with 500. The client should retry and finish all 10 pages eventually.", "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/single/failure": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getSinglePagesFailure", "description": "A paging operation that receives a 400 on the first call", "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/failure": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getMultiplePagesFailure", "description": "A paging operation that receives a 400 on the second call", "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/failureuri": { "get": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "operationId": "Paging_getMultiplePagesFailureUri", "description": "A paging operation that receives an invalid nextLink", "responses": { "200": { "description": "Initial response with ProvisioningState='Canceled'", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/fragment/{tenant}": { "get": { "x-ms-pageable": { "nextLinkName": "odata.nextLink", "itemName": "values", "operationName": "Paging_nextFragment" }, "operationId": "Paging_getMultiplePagesFragmentNextLink", "description": "A paging operation that doesn't return a full URL, just a fragment", "parameters": [ { "name": "api_version", "in": "query", "required": true, "type": "string", "description": "Sets the api version to use." }, { "name": "tenant", "in": "path", "required": true, "type": "string", "description": "Sets the tenant to use." } ], "responses": { "200": { "description": "Paging response with a fragment nextLink", "schema": { "$ref": "#/definitions/OdataProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/fragmentwithgrouping/{tenant}": { "get": { "x-ms-pageable": { "nextLinkName": "odata.nextLink", "itemName": "values", "operationName": "Paging_nextFragmentWithGrouping" }, "operationId": "Paging_getMultiplePagesFragmentWithGroupingNextLink", "description": "A paging operation that doesn't return a full URL, just a fragment with parameters grouped", "parameters": [ { "name": "api_version", "in": "query", "required": true, "type": "string", "description": "Sets the api version to use.", "x-ms-parameter-grouping": { "name": "custom-parameter-group" } }, { "name": "tenant", "in": "path", "required": true, "type": "string", "description": "Sets the tenant to use.", "x-ms-parameter-grouping": { "name": "custom-parameter-group" } } ], "responses": { "200": { "description": "Paging response with a fragment nextLink", "schema": { "$ref": "#/definitions/OdataProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/lro": { "post": { "x-ms-pageable": { "nextLinkName": "nextLink", "itemName": "values" }, "x-ms-long-running-operation": true, "operationId": "Paging_GetMultiplePagesLRO", "description": "A long-running paging operation that includes a nextLink that has 10 pages", "parameters": [ { "name": "client-request-id", "in": "header", "required": false, "type": "string" }, { "name": "maxresults", "in": "header", "required": false, "type": "integer", "format": "int32", "description": "Sets the maximum number of items to return in the response.", "x-ms-parameter-grouping": { "postfix": "Options" } }, { "name": "timeout", "in": "header", "required": false, "type": "integer", "format": "int32", "default": 30, "description": "Sets the maximum time that the server can spend processing the request, in seconds. The default is 30 seconds.", "x-ms-parameter-grouping": { "postfix": "Options" } } ], "responses": { "202": { "description": "Operation is in progress.", "schema": { "$ref": "#/definitions/ProductResult" } }, "default": { "description": "Unexpected error" } } } } }, "x-ms-paths": { "/paging/multiple/fragment/{tenant}/{nextLink}": { "get": { "x-ms-pageable": { "nextLinkName": "odata.nextLink", "itemName": "values", "operationName": "Paging_nextFragment" }, "operationId": "Paging_nextFragment", "description": "A paging operation that doesn't return a full URL, just a fragment", "parameters": [ { "name": "api_version", "in": "query", "required": true, "type": "string", "description": "Sets the api version to use." }, { "name": "tenant", "in": "path", "required": true, "type": "string", "description": "Sets the tenant to use." }, { "name": "nextLink", "in": "path", "required": true, "type": "string", "description": "Next link for list operation.", "x-ms-skip-url-encoding": true } ], "responses": { "200": { "description": "Paging response with a fragment nextLink", "schema": { "$ref": "#/definitions/OdataProductResult" } }, "default": { "description": "Unexpected error" } } } }, "/paging/multiple/fragmentwithgrouping/{tenant}/{nextLink}": { "get": { "x-ms-pageable": { "nextLinkName": "odata.nextLink", "itemName": "values", "operationName": "Paging_nextFragmentWithGrouping" }, "operationId": "Paging_nextFragmentWithGrouping", "description": "A paging operation that doesn't return a full URL, just a fragment", "parameters": [ { "name": "api_version", "in": "query", "required": true, "type": "string", "description": "Sets the api version to use.", "x-ms-parameter-grouping": { "name": "custom-parameter-group" } }, { "name": "tenant", "in": "path", "required": true, "type": "string", "description": "Sets the tenant to use.", "x-ms-parameter-grouping": { "name": "custom-parameter-group" } }, { "name": "nextLink", "in": "path", "required": true, "type": "string", "description": "Next link for list operation.", "x-ms-skip-url-encoding": true } ], "responses": { "200": { "description": "Paging response with a fragment nextLink", "schema": { "$ref": "#/definitions/OdataProductResult" } }, "default": { "description": "Unexpected error" } } } } }, "definitions": { "ProductResultValue": { "type": "object", "properties": { "value": { "type": "array", "items": { "$ref": "#/definitions/Product" } }, "nextLink": { "type": "string" } } }, "ProductResult": { "type": "object", "properties": { "values": { "type": "array", "items": { "$ref": "#/definitions/Product" } }, "nextLink": { "type": "string" } } }, "OdataProductResult": { "type": "object", "properties": { "values": { "type": "array", "items": { "$ref": "#/definitions/Product" } }, "odata.nextLink": { "type": "string" } } }, "Product": { "type": "object", "properties": { "properties": { "type": "object", "properties": { "id": { "type": "integer" }, "name": { "type": "string" } } } } }, "OperationResult": { "type": "object", "properties": { "status": { "description": "The status of the request", "type": "string", "enum": [ "Succeeded", "Failed", "canceled", "Accepted", "Creating", "Created", "Updating", "Updated", "Deleting", "Deleted", "OK" ] } } } } }