Skip to content

Mock rest api using Golang, no dependencies required.

License

Notifications You must be signed in to change notification settings

allegewhd/gmock-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gmock-api

A tool for Rest API test by mock API response. No dependencies are required.

usage

compile

$ git clone ....
$ make
  # this will show make file help 
  
$ make build
  # build main.go
  
$ make dist
  # build main.go for linux arm64
  
$ make run
  # run main.go directly
  
# 

edit config file

apis.json is a sample config file.

{
  "apis": [
    {
      "path":         ["/register", "/new"],
      "method":       ["POST", "PUT"],
      "accept":       ["application/json", "application/x-www-form-urlencoded"],
      "response":     {
        "content_type": "application/json",
        "data": {
          "act_type": 1,
          "status": "success",
          "register_id": "a99f391852caf97496e7a5ad27a7f295ecc194061b490985959472f3da3d00fb"
        },
        "status_code": 200
      }
    },
    ...
  ]
}
  • path API url, multiple support
  • method support method list
  • accept required request methods
  • response mock response
    • content_type response content type
    • data response body
    • status_code response code

test

run with --help to show usage.

$ ./build/bin/mockapi --help
Usage of ./build/bin/mockapi:
  -conf string
    	json config file (default "apis.json")
  -debug
    	debug mode
  -port int
    	agent server port (default 7001)

use your favor rest tool to access http://localhost:700/info

$ curl -s http://localhost:7001/info | jq
  # get sample

$ curl -s -H "Content-Type: application/json; charset=UTF-8" -d '{"agent_id": "tony_test_id_000", "agent_version": "1.0.1"}' http://localhost:7001/register | jq
  # post sample

Happy Hacking!

About

Mock rest api using Golang, no dependencies required.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published