Apidog

All-in-one Collaborative API Development Platform

API Design

API Documentation

API Debugging

API Mocking

API Automated Testing

How to Use grpc-curl to Test and Debug Your APIs

Learn how to use grpc-curl, a command-line tool that lets you interact with gRPC servers in a simple and intuitive way, and how to use it with apidog, a web-based tool for API documentation and testing.

Ashley Innocent

Ashley Innocent

Updated on November 12, 2024

If you’re a developer who works with APIs, you probably know how important it is to test and debug them before deploying them to production. You want to make sure that your APIs are reliable, secure, and performant, and that they meet the expectations of your clients and users.

But how do you test and debug your APIs, especially if they use gRPC, a modern and efficient protocol for communication between microservices? That’s where grpc-curl comes in. grpc-curl is a command-line tool that lets you interact with gRPC servers simply and intuitively.

In this blog post, I’ll show you how to use grpc-curl to test and debug your APIs, and why you should consider using it for your gRPC projects.

💡
If you want to take your gRPC testing and debugging to the next level, you might want to use grpc-curl with Apidog, a powerful and flexible tool for API documentation and testing. Apidog is a tool that lets you create, manage, and share API documentation and tests, using a simple and intuitive interface. You can use Apidog to document and test any kind of API, including REST, SOAP, GraphQL, and gRPC for free.
button

What is grpc-curl?

grpc-curl is a command-line tool that lets you invoke RPC methods on a gRPC server from the command-line. It supports various RPC methods, including unary, server-streaming, client-streaming, and bi-directional streaming. You can also browse the schema for gRPC services, either by querying a server that supports server reflection or by loading in compiled protoset files.

GitHub - fullstorydev/grpcurl: Like cURL, but for gRPC: Command-line tool for interacting with gRPC servers
Like cURL, but for gRPC: Command-line tool for interacting with gRPC servers - fullstorydev/grpcurl

grpc-curl is written in .NET, and it has some advantages over gRPCurl, such as:

  • It supports both .NET Core and .NET Framework, and it can run on Windows, Linux, and Mac OS.
  • It has a more concise and expressive syntax, and it can infer the service and method names from the URL.
  • It can automatically format the JSON output with colors and indentation, and it can also output XML or plain text.
  • It can handle nested messages and repeated fields better, and it can also accept input from files or standard input.
  • It can use environment variables for common options, such as the server URL, the headers, and the TLS settings.
  • It can generate code snippets for C#, Java, Python, and Go, to help you write your own client code.

grpc-curl is available as a NuGet package, and you can install it with the following command:

dotnet tool install -g grpc-curl

How to Use grpc-curl?

To use grpc-curl, you need to have a gRPC server running, and you need to know its URL and the service and method names that you want to call. You also need to have the schema for the gRPC services, either by using server reflection or by loading protoset files.

For this example, I’ll use a simple gRPC server that implements a calculator service, with four methods: Add, Subtract, Multiply, and Divide. The server is written in C#, and it supports server reflection.

To start the server, run the following command from the project folder:

dotnet run

The server will listen on port 5000 by default. You can change the port number in the appsettings.json file.

To call the Add method on the server, run the following command from another terminal:

grpc-curl http://localhost:5000 Calculator/Add -d '{"x": 3, "y": 5}'

The output should look something like this:

{
  "result": 8
}

As you can see, grpc-curl automatically infers the service and method names from the URL, and it formats the JSON output with colors and indentation. You can also use the -o option to specify a different output format, such as xml or text.

To call the Subtract method, run the following command:

grpc-curl http://localhost:5000 Calculator/Subtract -d '{"x": 10, "y": 4}'

The output should look something like this:

{
  "result": 6
}

To call the Multiply method, run the following command:

grpc-curl http://localhost:5000 Calculator/Multiply -d '{"x": 2, "y": 7}'

The output should look something like this:

{
  "result": 14
}

To call the Divide method, run the following command:

grpc-curl http://localhost:5000 Calculator/Divide -d '{"x": 15, "y": 3}'

The output should look something like this:

{
  "result": 5
}

If you try to divide by zero, you’ll get an error message, like this:

grpc-curl http://localhost:5000 Calculator/Divide -d '{"x": 15, "y": 0}'
{
  "error": "Cannot divide by zero."
}

grpc-curl also supports streaming methods, which can send or receive multiple messages in a single call. For example, let’s say we have a server-streaming method called Fibonacci, which takes a number n as input and returns the first n Fibonacci numbers as a stream of messages. The server code for this method looks something like this:

public override async Task Fibonacci(Number request, IServerStreamWriter<Number> responseStream, ServerCallContext context)
{
    int n = request.Value;
    int a = 0;
    int b = 1;
    for (int i = 0; i < n; i++)
    {
        await responseStream.WriteAsync(new Number { Value = a });
        int temp = a;
        a = b;
        b = temp + b;
    }
}

To call this method with grpc-curl, run the following command:

grpc-curl http://localhost:5000 Calculator/Fibonacci -d '{"value": 10}'

The output should look something like this:

{
  "value": 0
}
{
  "value": 1
}
{
  "value": 1
}
{
  "value": 2
}
{
  "value": 3
}
{
  "value": 5
}
{
  "value": 8
}
{
  "value": 13
}
{
  "value": 21
}
{
  "value": 34
}

As you can see, grpc-curl prints each message as it receives it from the server, and it closes the connection when the stream is complete.

grpc-curl also supports client-streaming methods, which can send multiple messages to the server and receive a single response. For example, let’s say we have a client-streaming method called Sum, which takes a stream of numbers as input and returns their sum as a response. The server code for this method looks something like this:

public override async Task<Number> Sum(IAsyncStreamReader<Number> requestStream, ServerCallContext context)
{
    int sum = 0;
    await foreach (var number in requestStream.ReadAllAsync())
    {
        sum += number.Value;
    }
    return new Number { Value = sum };
}

To call this method with grpc-curl, we need to provide the input messages from a file or from standard input. For example, we can create a file called numbers.json with the following content:

{"value": 1}
{"value": 2}
{"value": 3}
{"value": 4}
{"value": 5}

Then, we can run the following command:

grpc-curl http://localhost:5000 Calculator/Sum -d @numbers.json

The output should look something like this:

{
  "value": 15
}

Alternatively, we can use the - symbol to indicate that the input messages are coming from standard input, and then type or paste the messages in the terminal, followed by Ctrl+D to end the input. For example:

grpc-curl http://localhost:5000 Calculator/Sum -d -
{"value": 1}
{"value": 2}
{"value": 3}
{"value": 4}
{"value": 5}
^D

The output should be the same as before.

grpc-curl also supports bi-directional streaming methods, which can send and receive multiple messages in both directions. For example, let’s say we have a bi-directional streaming method called Chat, which takes a stream of messages as input and returns a stream of messages as output. The server code for this method looks something like this:

public override async Task Chat(IAsyncStreamReader<Message> requestStream, IServerStreamWriter<Message> responseStream, ServerCallContext context)
{
    await foreach (var message in requestStream.ReadAllAsync())
    {
        Console.WriteLine($"Received: {message.Text}");
        var reply = new Message { Text = $"Echo: {message.Text}" };
        await responseStream.WriteAsync(reply);
        Console.WriteLine($"Sent: {reply.Text}");
    }
}

To call this method with grpc-curl, we need to provide the input messages from a file or from standard input, and we need to use the -s option to indicate that we want to receive the output messages as a stream. For example, we can create a file called chat.json with the following content:

{"text": "Hello"}
{"text": "How are you?"}
{"text": "Goodbye"}

Then, we can run the following command:

grpc-curl http://localhost:5000 Calculator/Chat -d @chat.json -s

The output should look something like this:

{
  "text": "Echo: Hello"
}
{
  "text": "Echo: How are you?"
}
{
  "text": "Echo: Goodbye"
}

As you can see, grpc-curl sends each message to the server, and prints each reply from the server, until the input stream is exhausted.

How gRPC and HTTP/2 Can Boost Your API Performance
Learn what gRPC and HTTP/2 are, how they work together, and why they can offer significant benefits for your API performance. Also, discover how to use apidog to test and debug your gRPC APIs with ease.

Why use grpc-curl?

grpc-curl is a handy tool for testing and debugging your gRPC APIs, because it allows you to:

  • Invoke any kind of RPC method, including streaming methods, from the command-line, without writing any client code.
  • Browse the schema for gRPC services, either by querying a server that supports server reflection, or by loading protoset files.
  • Format the output in different ways, such as JSON, XML, or plain text, with colors and indentation.
  • Handle nested messages and repeated fields better than gRPCurl, and accept input from files or standard input.
  • Use environment variables for common options, such as the server URL, the headers, and the TLS settings.
  • Generate code snippets for C#, Java, Python, and Go, to help you write your own client code.

grpc-curl is also easy to install and use, and it works on multiple platforms, such as Windows, Linux, and Mac OS. It’s compatible with both .NET Core and .NET Framework, and it supports both HTTP/1.1 and HTTP/2 protocols.

grpc-curl is not only useful for developers, but also for testers, QA engineers, DevOps engineers, and anyone who needs to interact with gRPC servers. It can help you verify the functionality, performance, security, and reliability of your APIs, and identify and fix any issues or bugs.

How to use grpc-curl with apidog?

If you want to take your gRPC testing and debugging to the next level, you might want to use grpc-curl with apidog, a powerful and flexible tool for API documentation and testing.

Apidog is a tool that lets you create, manage, and share API documentation and tests, using a simple and intuitive interface. You can use apidog to document and test any kind of API, including REST, SOAP, GraphQL, and gRPC.

button

With apidog, you can:

  • Import your API schema from various sources, such as OpenAPI, Swagger, WSDL, GraphQL, or protoset files.
  • Create and organize your API endpoints, methods, parameters, headers, and responses, using a graphical editor or a code editor.
  • Add descriptions, examples, validations, and annotations to your API elements, using Markdown or HTML.
  • Generate interactive and beautiful API documentation, with live examples, code snippets, and diagrams.
  • Create and run API tests, using a built-in test runner or a command-line tool.
  • Monitor and debug your API calls, using a built-in proxy or a browser extension.
  • Collaborate and share your API projects with your team or your clients, using a cloud-based platform or a self-hosted solution.

Server Streaming

Server Streaming, as the name implies, involves sending multiple response data in a single request. For instance, it could involve subscribing to all the transaction price data of stocks within a one-minute timeframe.

Apidog Server Streaming

Client Streaming

In this mode, the client can continuously send multiple request messages to the server without waiting for immediate responses. After processing all the requests, the server sends a single response message back to the client. This approach is well-suited for efficiently transmitting large amounts of data in a streaming manner, which helps reduce latency and optimize data exchange.

Apidog Client Streaming

Bidirectional Streaming

Bidirectional Streaming enables clients and servers to establish persistent bidirectional communication and transmit multiple messages simultaneously. It is commonly employed in online games and real-time video call software, and is well-suited for real-time communication and large-scale data transmission scenarios. After initiating the call, the client and the server maintain a session between them and receive real-time responses after sending different request contents.

Apidog Bidirectional Streaming

Collaborating on gRPC APIs

Apidog can generate human-readable gRPC interface documents from .proto files, facilitating team collaboration on interfaces. Click the menu button on the right side of the interface to obtain the collaboration link and share it with other team members to align the interface debugging approach.

Collaborating on gRPC APIs
  • Create an apidog account, and log in to the apidog web app.
  • Create a new API project, and give it a name and a description.
  • Import your gRPC schema from a protoset file, or create it manually using the graphical editor or the code editor.
  • Add your gRPC endpoints, methods, parameters, headers, and responses, and fill in the details and the examples.
  • Generate your API documentation, and view it in the browser or export it as a PDF or HTML file.
  • Create your API tests, and run them using the built-in test runner or the command-line tool.
  • Monitor and debug your API calls, using the built-in proxy or the browser extension.
  • Share your API project with your team or your clients, using the cloud-based platform or the self-hosted solution.

To learn more about apidog, and how to use it with grpc-curl, you can visit the apidog website, or check out the apidog documentation.

Conclusion

grpc-curl is a command-line tool that lets you interact with gRPC servers in a simple and intuitive way. It’s based on gRPCurl, but it adds some features and improvements that make it more user-friendly and powerful. You can use grpc- curl to test and debug your gRPC APIs, and to generate code snippets for your own client code.

grpc-curl is also compatible with apidog, a web-based tool for API documentation and testing. You can use apidog to create, manage, and share your API projects, and to run and monitor your API tests.

If you’re a developer who works with gRPC, or if you’re interested in learning more about gRPC, you should definitely give grpc-curl and Apidog a try. They can help you improve the quality and the usability of your APIs, and make your development process easier and faster.

button

Integrating Apidog with Google Analytics: Track Key API Documentation MetricsTutorials

Integrating Apidog with Google Analytics: Track Key API Documentation Metrics

Discover how integrating Apidog with Google Analytics can help you track key API documentation metrics. Learn to improve user engagement, boost API adoption, and make data-driven decisions to enhance your API development strategy.

Oliver Kingsley

December 31, 2024

Integrating Azure Key Vault with Apidog: Keeping API Secret SafeTutorials

Integrating Azure Key Vault with Apidog: Keeping API Secret Safe

Discover how to integrate Azure Key Vault with Apidog for secure API secret management. This guide walks you through each step to safeguard your API keys and tokens during testing, ensuring efficient workflows without compromising security.

Oliver Kingsley

December 25, 2024

Integrating AWS Secrets Manager with Apidog: Protecting API Sensitive DataTutorials

Integrating AWS Secrets Manager with Apidog: Protecting API Sensitive Data

Securing API keys and sensitive data is essential in API development. This guide walks you through integrating AWS Secrets Manager with Apidog, ensuring encrypted and efficient management of API secrets for improved security and smoother testing workflows.

Oliver Kingsley

December 24, 2024