Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dipjyotimetia/pubsub-emulator
GCP Pubsub Emulator
https://github.com/dipjyotimetia/pubsub-emulator
pubsub pubsub-emulator
Last synced: 3 months ago
JSON representation
GCP Pubsub Emulator
- Host: GitHub
- URL: https://github.com/dipjyotimetia/pubsub-emulator
- Owner: dipjyotimetia
- License: apache-2.0
- Created: 2023-02-17T08:39:04.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-10T08:45:53.000Z (4 months ago)
- Last Synced: 2024-09-10T11:01:50.461Z (4 months ago)
- Topics: pubsub, pubsub-emulator
- Language: Go
- Homepage:
- Size: 173 KB
- Stars: 3
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Google Cloud PubSub Emulator
[![Publish Docker image](https://github.com/dipjyotimetia/pubsub-emulator/actions/workflows/docker-publish.yaml/badge.svg)](https://github.com/dipjyotimetia/pubsub-emulator/actions/workflows/docker-publish.yaml)
[Google Cloud PubSub Emulator](https://cloud.google.com/pubsub/docs/emulator) is a tool that allows you to run a local emulator of Google Cloud Pub/Sub, making it easy to develop and test Pub/Sub applications without incurring costs or interacting with the production environment.
## Usage
This emulator provides the capability to create multiple topics and subscriptions for testing purposes. To get started, follow these steps:
### Prerequisites
- Docker installed on your system.
### 1. Set Environment Variables
Before running the emulator, set the required environment variables in your shell:
- `PUBSUB_PROJECT`: Your Google Cloud project ID.
- `PUBSUB_TOPIC`: Comma-separated list of Pub/Sub topic names.
- `PUBSUB_SUBSCRIPTION`: Comma-separated list of Pub/Sub subscription names.
- `PUBSUB_PORT` (optional): Port to run the emulator on (default is `8085`).### 2. Run the Container
Use the provided Docker image to run the emulator:
```yaml
version: '3.8'
services:
pubsub-emulator:
image: dipjyotimetia/pubsub-emulator:latest
environment:
- PUBSUB_PROJECT=test-project
- PUBSUB_TOPIC=test-topic1,test-topic2,test-topic3
- PUBSUB_SUBSCRIPTION=test-sub1,test-sub2,test-sub3
- PUBSUB_PORT=8085
```Replace the values in the environment variables with your own project, topic, and subscription names.
### 3. Develop and Test
With the emulator running, you can now develop and test your Google Cloud Pub/Sub applications locally. Any messages published to the emulator will be processed as if they were sent to the actual Google Cloud Pub/Sub service.
---
**Note**: The emulator is an excellent tool for local development and testing, but remember that it may not fully replicate all features of the production environment. Be sure to thoroughly test your code in the actual Google Cloud environment before deploying it to production.
---
**Special Thanks**: This project was inspired by [RoryQ/spanner-emulator](https://github.com/RoryQ/spanner-emulator). Thanks for the motivation!