Skip to content

Latest commit

 

History

History
89 lines (59 loc) · 2.43 KB

README.md

File metadata and controls

89 lines (59 loc) · 2.43 KB

Hypersomnia

Hypersomnia is a web tool to debug your micro services RPC endpoints. Created as a user-friendly replacement of micro web.

Install

go get -u github.com/kstkn/hypersomnia

Usage

Default registry is consul on localhost:8500. If you use it, you can simply start with:

hypersomnia

To use mdns registry:

HYPERSOMNIA_REGISTRY=consul hypersomnia

If default port 8083 is used by some other application, or if you don't want to bind on public interface you can use different setting of your choice:

HYPERSOMNIA_ADDR=127.0.0.1:31337 hypersomnia

Reference values from other request's responses

In request you can reference value from other request's response by using Response.Endpoint(<jsonpath>[,int])

{
    "someField": "Response.SomeService.SomeEndpoint($.items[0].id)" 
}

To insert integer instead of string:

{
    "someField": "Response.SomeService.SomeEndpoint($.items[0].id,int)" 
}

Interact with services in the cloud

This is possible if there's available instance of micro web. To configure, pass a map with environment name as a key and micro web url as value:

HYPERSOMNIA_ENVIRONMENTS="dev:https://web-dev.example.com,stage:https://web-stage.example.com" hypersomnia 

You will see configured environments in environment switcher:

Use as micro client

import microWebClient "github.com/kstkn/hypersomnia/micro"

microWebClient.NewWebClient("https://web-dev.example.com")

Quick access to external system to search by correlation id

For each environment you can set up an URL template to open quickly by pressing correlation id badge. Special placeholder _correlationId_ will be replaced and URL will open. It can be log collector, like kibana. To set up URLs, press environment settings button next to environment selector:

Settings popup will open:

Now to quickly open external URL, click correlation id badge on top of response block:

Development

To ship hypersomnia to the target system we have to include HTML template into binary. We use go generate for that, so after any changes to templates/index.html don't forget to run go generate and commit templates/index.go