Validate AsyncAPI document with Studio

Found an error? Have a suggestion?Edit this page on GitHub

Introduction

This tutorial will teach you how to validate AsyncAPI documents using the AsyncAPI Studio tool.

You will start with a broken AsyncAPI document and troubleshoot via console errors step-by-step until we end up with a valid AsyncAPI document. This process will illustrate how to identify REQUIRED properties in AsyncAPI documents.

Background context

An AsyncAPI document is a file that defines and annotates the different components of a specific Event-Driven API. The format of the file must be JSON or YAML. You can use this document to generate both documentation and code.

The AsyncAPI Studio tool allows you to develop an AsyncAPI document, validate it, preview it, convert it to the latest version, and visualize event flows.

Remember

If you did not follow the previous tutorial and do not have an asyncapi.yaml file ready, then generate one using asyncapi new --example=tutorial.yml --no-tty command.

Now let's experiment with an invalid file to see how errors are displayed and how to make that file valid again.

Copy invalid AsyncAPI document

Let's pretend we have an invalid AsyncAPI document.

  1. Open Studio.
Remember

You can also skip the step below by clicking on New File in Studio and opening the Invalid Example template in the tutorials section.

  1. Copy and paste the below invalid AsyncAPI document:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
asyncapi: '1.0.0'
info:
  title: Streetlights API
  version: '1.0.0'
  license:
    name: Apache 2.0
    url: 'https://www.apache.org/licenses/LICENSE-2.0'
servers:
  mosquitto:
    url: mqtt://test.mosquitto.org
    protocol: mqtt
channels:
  light/measured:
    publish:
      summary: Inform about environmental lighting conditions for a particular streetlight.
      operationId: onLightMeasured
      message:
        name: LightMeasured
        payload:
          type: object
          properties:
            id:
              type: integer
              minimum: true
              description: Id of the streetlight.
            lumens:
              type: integer
              minimum: 0
              description: Light intensity measured in lumens.
            sentAt:
              type: integer
              format: date-time
              description: Date and time when the message was sent.

Troubleshoot Studio errors

Let's fix the errors one by one until we end up with a valid AsyncAPI document.

  1. You can see the error message on the screen: Empty or invalid document. Please fix errors/define AsyncAPI document.

  2. Open diagnostics, you can see more information related to your errors.

  3. Fix the incorrect AsyncAPI specification number to 2.5.0.

1
2
3
4
asyncapi: '2.5.0'
info:
  title: Account Service
  version: 1.0.0
Remember
Notice how description property is missing; that doesn't make the AsyncAPI document invalid, but it's always better to include.
  1. Read the next error: must be number. Fix the minimum by changing it to: 0.
1
2
3
4
          properties:
            id:
              type: integer
              minimum: 0
  1. You see three errors:
  • must be equal to one of the allowed values
  • must be array
  • must match a schema in anyOf

anyOf means it should match any one the above schemas then it is valid.

Now let's fix this error by changing the type to string

1
2
3
4
            sentAt:
              type: string
              format: date-time
              description: Date and time when the message was sent.
  1. Congratulations! You identified and fixed all the errors, and now have a valid AsyncAPI document.

Summary

This tutorial taught us how to validate an AsyncAPI document using the AsyncAPI Studio tool. We also learned to troubleshoot an invalid AsyncAPI document by following the error message directions in diagnostics. In doing so, we learned how to identify REQUIRED properties in all AsyncAPI documents.

Next steps

Now that you have completed this tutorial, go ahead to learn generate AsyncAPI messages (events) which you will be sending to your application.

You may also enjoy reading our AsyncAPI document validation guide.


Was this helpful?
Help us improve the docs by adding your contribution.
OR
Github:AsyncAPICreate Issue on GitHub