Skip to content

A sample showing how to create a simulated API implementation for Azure OpenAI (AOAI)

License

Notifications You must be signed in to change notification settings

mluker/aoai-api-simulator

Repository files navigation

Azure OpenAI Simulated API

This repo is an exploration into creating a simulated API implementation for Azure OpenAI (AOAI).

WARNING: This is a work in progress!

Table of Contents

Overview

What is the OpenAI Simulated API?

The OpenAI Simulated API is a tool that allows you to easily deploy endpoints that simulate the OpenAI API. A common use-case for the OpenAI Simulated API is to test the behaviour your application under load. Let's illustrate this with an example...

Let's assume that you have build a chatbot that uses the OpenAI API to generate responses to user queries. Before your chatbot becomes popular, you want to ensure that it can handle a large number of users. One of the factors that will impact whether your chatbot can gracefully handle such load will be the way that your chatbot handles calls to OpenAI. However, when load testing your chatbot there are a number of reasons why you might not want to call the OpenAI API directly:

  • Cost: The OpenAI API is a paid service, and running load tests against it can be expensive.
  • Consistency: The OpenAI API is a live service, and the responses you get back can change over time. This can make it difficult to compare the results of load tests run at different times.
  • Rate Limits: The OpenAI API has rate limits, and running load tests against it can cause you to hit these limits.
  • Latency: The latency of OpenAI API calls might change over time, and this can impact the results of your load tests.

In fact, when considering Rate Limits and Latency, these might be things that you'd like to control. You may also want to inject latency, or inject rate limit issues, so that you can test how your chatbot deals with these issues.

This is where the OpenAI Simulater API plays it's part!

By using the OpenAI Simulated API, you can reduce the cost of running load tests against the OpenAI API and ensure that your application behaves as expected under different conditions.

Simulator Modes

The simulated API has two approaches to simulating API responses: record/replay and generators. If you don't have any requirements around the content of the responses, the generator approach is probably the easiest for you to use. If you need to simulate specific responses, then the record/replay approach is likely the best fit for you.

Record/Replay Mode

With record/replay, the API can be run in record mode to act as a proxy between your application and Azure OpenAI, and it will record requests that are sent to it along with the corresponding response from OpenAI.

Simulator in record mode

Once recorded, the API can be run in replay mode to use the saved responses without forwarding to Azure OpenAI. The recordings are stored in YAML files which can be edited if you want to customise the responses.

Simulator in replay mode

Generator Mode

The simulated API can also be run in generator mode, where responses are generated on the fly. This is useful for load testing scenarios where it would be costly/impractical to record the full set of responses.

Simulator in generator mode

Read More

There are various options for running and deploying the simulator, including running in Docker and deploying to Azure Container Apps.

There are a range of configuration options that can be applied to control the simulator behavior.

The simulated API supports extensions that allow you to customise the behaviour of the API. Extensions can be used to modify the request/response, add latency, or even generate responses.

Changelog

For a list of tagged versions and changes, see the CHANGELOG.md file.

About

A sample showing how to create a simulated API implementation for Azure OpenAI (AOAI)

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 81.6%
  • Shell 8.5%
  • HCL 4.1%
  • Bicep 3.8%
  • Makefile 1.0%
  • HTML 0.6%
  • Dockerfile 0.4%