api-testing

SKILL.md

API Testing

Comprehensive API testing: functional, contract, mock, and GraphQL.

Functional API Testing with curl

REST endpoints

# GET with response validation
response=$(curl -s -w "\n%{http_code}" https://api.example.com/users/1)
body=$(echo "$response" | head -n -1)
status=$(echo "$response" | tail -1)
echo "Status: $status"
echo "$body" | jq .

# POST with payload
curl -s -X POST https://api.example.com/users \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer $API_TOKEN" \
  -d '{"name": "Test User", "email": "test@example.com"}' | jq .

# PUT update
curl -s -X PUT https://api.example.com/users/1 \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer $API_TOKEN" \
  -d '{"name": "Updated User"}' | jq .

# DELETE
curl -s -X DELETE https://api.example.com/users/1 \
  -H "Authorization: Bearer $API_TOKEN" -w "\nHTTP %{http_code}\n"

# PATCH
curl -s -X PATCH https://api.example.com/users/1 \
  -H "Content-Type: application/json" \
  -d '{"status": "active"}' | jq .

Validate response schema

# Check required fields exist
curl -s https://api.example.com/users/1 | jq 'has("id", "name", "email")'

# Check array response length
curl -s https://api.example.com/users | jq 'length'

# Check field types
curl -s https://api.example.com/users/1 | jq '{id_is_number: (.id | type == "number"), name_is_string: (.name | type == "string")}'

Newman (Postman CLI)

# Run a Postman collection
newman run collection.json

# With environment variables
newman run collection.json -e environment.json

# Generate HTML report
newman run collection.json --reporters cli,htmlextra --reporter-htmlextra-export report.html

# Run specific folder in collection
newman run collection.json --folder "User CRUD"

# With iteration data (CSV/JSON)
newman run collection.json -d test-data.csv -n 10

# Bail on first failure
newman run collection.json --bail

Contract Testing (Pact)

Consumer side (JavaScript example)

# Install
npm install --save-dev @pact-foundation/pact

# Run consumer tests that generate pact files
npx jest --testPathPattern=pact

# Pact files output to pacts/ directory
ls pacts/

Provider verification

# Verify provider against pact
npx jest --testPathPattern=pact-verification

# Or using Pact CLI
pact-provider-verifier --provider-base-url http://localhost:3000 \
  --pact-url pacts/consumer-provider.json

Mock Servers

Prism (OpenAPI mock)

# Mock from OpenAPI spec
npx @stoplight/prism-cli mock openapi.yaml

# Mock with dynamic responses
npx @stoplight/prism-cli mock openapi.yaml --dynamic

# Validate requests against spec
npx @stoplight/prism-cli proxy openapi.yaml http://localhost:3000

Simple mock with Node

# Quick JSON server for REST mocking
npx json-server --watch db.json --port 3001

# db.json format:
# {"users": [{"id": 1, "name": "Test"}], "posts": [{"id": 1, "title": "Hello"}]}

GraphQL Testing

# Query
curl -s -X POST https://api.example.com/graphql \
  -H "Content-Type: application/json" \
  -d '{"query": "{ users { id name email } }"}' | jq .

# Mutation
curl -s -X POST https://api.example.com/graphql \
  -H "Content-Type: application/json" \
  -H "Authorization: Bearer $TOKEN" \
  -d '{"query": "mutation { createUser(name: \"Test\", email: \"t@t.com\") { id } }"}' | jq .

# Introspection (check if disabled in prod)
curl -s -X POST https://api.example.com/graphql \
  -H "Content-Type: application/json" \
  -d '{"query": "{ __schema { types { name } } }"}' | jq '.data.__schema.types | length'

# With variables
curl -s -X POST https://api.example.com/graphql \
  -H "Content-Type: application/json" \
  -d '{"query": "query GetUser($id: ID!) { user(id: $id) { name } }", "variables": {"id": "1"}}' | jq .

Notes

  • Test error responses too — send bad data and verify proper 400/422 responses.
  • Contract tests prevent integration breakage between services. Run them in CI.
  • Mock servers unblock frontend development when backend isn't ready.
  • GraphQL introspection should be disabled in production — test for it.
  • Always test with authentication. Unauthenticated endpoints are a security risk.
Weekly Installs
2
First Seen
14 days ago
Installed on
opencode2
gemini-cli2
claude-code2
github-copilot2
codex2
kimi-cli2