muonsoft / openapi-mock

OpenAPI mock server with random data generation
MIT License
487 stars 55 forks source link

Response generation hangs indefinitely #62

Open crizzis opened 3 years ago

crizzis commented 3 years ago

Using the following config:

covidbevis-mock:
    image: muonsoft/openapi-mock
    environment:
      OPENAPI_MOCK_SPECIFICATION_URL: '/data/covidBevisApiSchema.json'
      OPENAPI_MOCK_PORT: 8453
      OPENAPI_MOCK_RESPONSE_TIMEOUT: '30.0'
      OPENAPI_MOCK_DEBUG: 'true'
      OPENAPI_MOCK_USE_EXAMPLES: 'if_present'
    ports:
      - '8453:8453'
    volumes:
      - ./resources:/data

where covidBevisApiSchema.json is defined as:

{
  "openapi": "3.0.0",
  "info": {
    "description": "This is the REST API description for the Swedish test proof solution.",
    "version": "0.1",
    "title": "Swedish Test proof REST API",
    "termsOfService": "Terms of service",
    "contact": {
      "name": "Myndigheten för Digital förvaltning",
      "url": "http://www.digg.se",
      "email": "info@digg.se"
    },
    "license": {
      "name": "MIT License",
      "url": "API license URL"
    }
  },
  "tags": [
    {
      "name": "test-submission-controller",
      "description": "Test Submission Controller"
    }
  ],
  "paths": {
    "/observation": {
      "post": {
        "tags": [
            "test-submission-controller"
        ],
        "summary": "Operation for submitting a test observation",
        "operationId": "submitObservationUsingPOST",
        "requestBody": {
          "content": {
            "application/json": {
              "schema": {
                "type": "object"
              }
            }
          },
          "description": "request body",
          "required": true
        },
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/TestSubmissionResponse"
                }
              }
            }
          },
          "401": {
            "description": "Unauthorized"
          },
          "403": {
            "description": "Forbidden"
          },
          "404": {
            "description": "Not Found"
          }
        }
      }
    }
  },
  "servers": [
    {
      "url": "//localhost:8453/"
    }
  ],
  "components": {
    "schemas": {
      "Coding": {
        "type": "object",
        "required": [
            "code",
            "display"
        ],
        "properties": {
          "code": {
            "type": "string"
          },
          "display": {
            "type": "string"
          }
        },
        "title": "Coding"
      },
      "Delivery": {
        "type": "object",
        "required": [
            "serviceSupplier"
        ],
        "properties": {
          "delivered": {
            "type": "boolean"
          },
          "message": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          },
          "serviceSupplier": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          }
        },
        "title": "Delivery"
      },
      "Proof": {
        "type": "object",
        "required": [
            "content",
            "mimetype"
        ],
        "properties": {
          "content": {
            "type": "string"
          },
          "delivery": {
            "$ref": "#/components/schemas/Delivery"
          },
          "mimetype": {
            "type": "string",
            "minLength": 3,
            "maxLength": 2147483647
          }
        },
        "title": "Proof"
      },
      "ProofQRCode": {
        "type": "object",
        "required": [
            "height",
            "image",
            "mimetype",
            "width"
        ],
        "properties": {
          "height": {
            "type": "integer",
            "format": "int32",
            "example": 400
          },
          "image": {
            "type": "string",
            "example": ""
          },
          "mimetype": {
            "type": "string",
            "minLength": 3,
            "maxLength": 2147483647,
            "example": "image/png"
          },
          "width": {
            "type": "integer",
            "format": "int32",
            "example": 400
          }
        },
        "title": "ProofQRCode"
      },
      "Test": {
        "type": "object",
        "required": [
            "id",
            "targetDisease",
            "testResult",
            "typeOfTest"
        ],
        "properties": {
          "id": {
            "type": "string"
          },
          "sampleCollectionDateTime": {
            "type": "string",
            "format": "date-time"
          },
          "targetDisease": {
            "$ref": "#/components/schemas/Coding"
          },
          "testManufacturer": {
            "$ref": "#/components/schemas/Coding"
          },
          "testName": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          },
          "testResult": {
            "$ref": "#/components/schemas/Coding"
          },
          "typeOfTest": {
            "$ref": "#/components/schemas/Coding"
          }
        },
        "title": "Test"
      },
      "TestPersonData": {
        "type": "object",
        "properties": {
          "birthDate": {
            "type": "string",
            "format": "date"
          },
          "familyName": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          },
          "givenName": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          },
          "identity": {
            "type": "string",
            "minLength": 12,
            "maxLength": 12,
            "pattern": "^((18|19|20)[0-9]{2}(0[1-9]|1[0-2])(0[1-9]|1[0-9]|2[0-9]|3[0-1])[0-9]{4})$"
          }
        },
        "title": "TestPersonData"
      },
      "TestProof": {
        "type": "object",
        "required": [
            "metadata",
            "qrCode",
            "subject",
            "test"
        ],
        "properties": {
          "metadata": {
            "$ref": "#/components/schemas/TestProofMetadata"
          },
          "qrCode": {
            "$ref": "#/components/schemas/ProofQRCode"
          },
          "subject": {
            "$ref": "#/components/schemas/TestPersonData"
          },
          "test": {
            "$ref": "#/components/schemas/Test"
          }
        },
        "title": "TestProof"
      },
      "TestProofMetadata": {
        "type": "object",
        "required": [
            "country",
            "issuanceDate",
            "issuer",
            "uvci",
            "validThrough"
        ],
        "properties": {
          "country": {
            "type": "string",
            "minLength": 2,
            "maxLength": 2147483647
          },
          "issuanceDate": {
            "type": "string",
            "format": "date"
          },
          "issuer": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          },
          "uvci": {
            "type": "string",
            "minLength": 1,
            "maxLength": 2147483647
          },
          "validThrough": {
            "type": "string",
            "format": "date-time",
            "example": "2017-07-21T17:32:28Z"
          }
        },
        "title": "TestProofMetadata"
      },
      "TestSubmissionResponse": {
        "type": "object",
        "required": [
            "proofTypes",
            "testProof"
        ],
        "properties": {
          "proofTypes": {
            "type": "array",
            "items": {
              "$ref": "#/components/schemas/Proof"
            }
          },
          "testProof": {
            "$ref": "#/components/schemas/TestProof"
          }
        },
        "title": "TestSubmissionResponse"
      }
    }
  }
}

The following request:

Zrzut ekranu 2021-08-4 o 11 29 56

Results in the mock taking all the available time to respond (=30 sec), then responding with 503 Error

Container logs:

time="2021-08-04T09:28:05Z" level=info msg="OpenAPI specification was successfully loaded from '/data/covidBevisApiSchema.json'"
time="2021-08-04T09:28:05Z" level=info msg="OpenAPI mock server was created" CORSEnabled=false Debug=true DefaultMaxFloat=1.073741823e+09 DefaultMaxInt=2147483647 DefaultMinFloat=-1.073741823e+09 DefaultMinInt=0 LogFormat=tty LogLevel=trace NullProbability=0.5 Port=8453 ResponseTimeout=30s SpecificationURL=/data/covidBevisApiSchema.json SuppressErrors=false UseExamples=if_present
time="2021-08-04T09:28:05Z" level=info msg="[HTTP]: 2021/08/04 09:28:05 3628537b5fbc - Starting server on port :8453"
time="2021-08-04T09:32:28Z" level=info msg="[contentTypeNegotiator] best media type 'application/json' was negotiated for accept header '*/*'" requestId=35cdc14c-fcab-4bf7-8b80-b8ff68dd383c