mockforge_sdk/
lib.rs

1//! Pillars: [`DevX`]
2//!
3//! # `MockForge` SDK
4//!
5//! Developer SDK for embedding `MockForge` mock servers directly in unit and integration tests.
6//!
7//! ## Features
8//!
9//! - **Start/Stop Mock Servers**: Programmatically control mock server lifecycle
10//! - **Stub Responses**: Define mock responses with a fluent API
11//! - **Offline Mode**: Works without network dependencies
12//! - **Multi-Protocol**: HTTP, WebSocket, gRPC, GraphQL support
13//! - **Ergonomic API**: Builder pattern for easy configuration
14//!
15//! ## Quick Start
16//!
17//! ```rust,no_run
18//! use mockforge_sdk::MockServer;
19//! use serde_json::json;
20//!
21//! #[tokio::test]
22//! async fn test_user_api() {
23//!     // Start a mock server
24//!     let mut server = MockServer::new()
25//!         .port(3000)
26//!         .start()
27//!         .await
28//!         .expect("Failed to start server");
29//!
30//!     // Stub a response
31//!     server
32//!         .stub_response("GET", "/api/users/{id}", json!({
33//!             "id": "{{uuid}}",
34//!             "name": "{{faker.name}}",
35//!             "email": "{{faker.email}}"
36//!         }))
37//!         .await
38//!         .expect("Failed to stub response");
39//!
40//!     // Make requests to the mock server
41//!     let client = reqwest::Client::new();
42//!     let response = client
43//!         .get("http://localhost:3000/api/users/123")
44//!         .send()
45//!         .await
46//!         .expect("Failed to make request");
47//!
48//!     assert_eq!(response.status(), 200);
49//!
50//!     // Stop the server
51//!     server.stop().await.expect("Failed to stop server");
52//! }
53//! ```
54
55pub mod admin;
56pub mod builder;
57pub mod error;
58pub mod ffi;
59pub mod server;
60pub mod stub;
61pub mod verification;
62
63pub use admin::{
64    AdminClient, MockConfig as AdminMockConfig, MockConfigBuilder, MockList,
65    MockResponse as AdminMockResponse, RequestMatchCriteria, ServerConfig as AdminServerConfig,
66    ServerStats,
67};
68pub use builder::MockServerBuilder;
69pub use error::{Error, Result};
70pub use server::MockServer;
71pub use stub::{
72    DynamicResponseFn, DynamicStub, RequestContext, ResourceIdExtractConfig, ResponseStub,
73    StateMachineConfig, StateResponseOverride, StubBuilder, StubFaultInjectionConfig,
74};
75pub use verification::Verification;
76
77// Re-export commonly used types from mockforge-core
78pub use mockforge_core::{
79    Config, FailureConfig, LatencyProfile, OpenApiSpec, ProxyConfig, ServerConfig,
80};