spikard 0.4.0-arm64-darwin-23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/LICENSE +1 -0
- data/README.md +659 -0
- data/ext/spikard_rb/Cargo.toml +17 -0
- data/ext/spikard_rb/extconf.rb +10 -0
- data/ext/spikard_rb/src/lib.rs +6 -0
- data/lib/spikard/app.rb +405 -0
- data/lib/spikard/background.rb +27 -0
- data/lib/spikard/config.rb +396 -0
- data/lib/spikard/converters.rb +13 -0
- data/lib/spikard/handler_wrapper.rb +113 -0
- data/lib/spikard/provide.rb +214 -0
- data/lib/spikard/response.rb +173 -0
- data/lib/spikard/schema.rb +243 -0
- data/lib/spikard/sse.rb +111 -0
- data/lib/spikard/streaming_response.rb +44 -0
- data/lib/spikard/testing.rb +221 -0
- data/lib/spikard/upload_file.rb +131 -0
- data/lib/spikard/version.rb +5 -0
- data/lib/spikard/websocket.rb +59 -0
- data/lib/spikard.rb +43 -0
- data/sig/spikard.rbs +366 -0
- data/vendor/bundle/ruby/3.4.0/gems/diff-lcs-1.6.2/mise.toml +5 -0
- data/vendor/bundle/ruby/3.4.0/gems/rake-compiler-dock-1.10.0/build/buildkitd.toml +2 -0
- data/vendor/crates/spikard-bindings-shared/Cargo.toml +63 -0
- data/vendor/crates/spikard-bindings-shared/examples/config_extraction.rs +139 -0
- data/vendor/crates/spikard-bindings-shared/src/config_extractor.rs +561 -0
- data/vendor/crates/spikard-bindings-shared/src/conversion_traits.rs +194 -0
- data/vendor/crates/spikard-bindings-shared/src/di_traits.rs +246 -0
- data/vendor/crates/spikard-bindings-shared/src/error_response.rs +403 -0
- data/vendor/crates/spikard-bindings-shared/src/handler_base.rs +274 -0
- data/vendor/crates/spikard-bindings-shared/src/lib.rs +25 -0
- data/vendor/crates/spikard-bindings-shared/src/lifecycle_base.rs +298 -0
- data/vendor/crates/spikard-bindings-shared/src/lifecycle_executor.rs +637 -0
- data/vendor/crates/spikard-bindings-shared/src/response_builder.rs +309 -0
- data/vendor/crates/spikard-bindings-shared/src/test_client_base.rs +248 -0
- data/vendor/crates/spikard-bindings-shared/src/validation_helpers.rs +355 -0
- data/vendor/crates/spikard-bindings-shared/tests/comprehensive_coverage.rs +502 -0
- data/vendor/crates/spikard-bindings-shared/tests/error_response_edge_cases.rs +389 -0
- data/vendor/crates/spikard-bindings-shared/tests/handler_base_integration.rs +413 -0
- data/vendor/crates/spikard-core/Cargo.toml +40 -0
- data/vendor/crates/spikard-core/src/bindings/mod.rs +3 -0
- data/vendor/crates/spikard-core/src/bindings/response.rs +133 -0
- data/vendor/crates/spikard-core/src/debug.rs +63 -0
- data/vendor/crates/spikard-core/src/di/container.rs +726 -0
- data/vendor/crates/spikard-core/src/di/dependency.rs +273 -0
- data/vendor/crates/spikard-core/src/di/error.rs +118 -0
- data/vendor/crates/spikard-core/src/di/factory.rs +538 -0
- data/vendor/crates/spikard-core/src/di/graph.rs +545 -0
- data/vendor/crates/spikard-core/src/di/mod.rs +192 -0
- data/vendor/crates/spikard-core/src/di/resolved.rs +411 -0
- data/vendor/crates/spikard-core/src/di/value.rs +283 -0
- data/vendor/crates/spikard-core/src/errors.rs +39 -0
- data/vendor/crates/spikard-core/src/http.rs +153 -0
- data/vendor/crates/spikard-core/src/lib.rs +29 -0
- data/vendor/crates/spikard-core/src/lifecycle.rs +422 -0
- data/vendor/crates/spikard-core/src/metadata.rs +397 -0
- data/vendor/crates/spikard-core/src/parameters.rs +723 -0
- data/vendor/crates/spikard-core/src/problem.rs +310 -0
- data/vendor/crates/spikard-core/src/request_data.rs +189 -0
- data/vendor/crates/spikard-core/src/router.rs +249 -0
- data/vendor/crates/spikard-core/src/schema_registry.rs +183 -0
- data/vendor/crates/spikard-core/src/type_hints.rs +304 -0
- data/vendor/crates/spikard-core/src/validation/error_mapper.rs +689 -0
- data/vendor/crates/spikard-core/src/validation/mod.rs +459 -0
- data/vendor/crates/spikard-http/Cargo.toml +58 -0
- data/vendor/crates/spikard-http/examples/sse-notifications.rs +147 -0
- data/vendor/crates/spikard-http/examples/websocket-chat.rs +91 -0
- data/vendor/crates/spikard-http/src/auth.rs +247 -0
- data/vendor/crates/spikard-http/src/background.rs +1562 -0
- data/vendor/crates/spikard-http/src/bindings/mod.rs +3 -0
- data/vendor/crates/spikard-http/src/bindings/response.rs +1 -0
- data/vendor/crates/spikard-http/src/body_metadata.rs +8 -0
- data/vendor/crates/spikard-http/src/cors.rs +490 -0
- data/vendor/crates/spikard-http/src/debug.rs +63 -0
- data/vendor/crates/spikard-http/src/di_handler.rs +1878 -0
- data/vendor/crates/spikard-http/src/handler_response.rs +532 -0
- data/vendor/crates/spikard-http/src/handler_trait.rs +861 -0
- data/vendor/crates/spikard-http/src/handler_trait_tests.rs +284 -0
- data/vendor/crates/spikard-http/src/lib.rs +524 -0
- data/vendor/crates/spikard-http/src/lifecycle/adapter.rs +149 -0
- data/vendor/crates/spikard-http/src/lifecycle.rs +428 -0
- data/vendor/crates/spikard-http/src/middleware/mod.rs +285 -0
- data/vendor/crates/spikard-http/src/middleware/multipart.rs +930 -0
- data/vendor/crates/spikard-http/src/middleware/urlencoded.rs +541 -0
- data/vendor/crates/spikard-http/src/middleware/validation.rs +287 -0
- data/vendor/crates/spikard-http/src/openapi/mod.rs +309 -0
- data/vendor/crates/spikard-http/src/openapi/parameter_extraction.rs +535 -0
- data/vendor/crates/spikard-http/src/openapi/schema_conversion.rs +867 -0
- data/vendor/crates/spikard-http/src/openapi/spec_generation.rs +678 -0
- data/vendor/crates/spikard-http/src/query_parser.rs +369 -0
- data/vendor/crates/spikard-http/src/response.rs +399 -0
- data/vendor/crates/spikard-http/src/server/handler.rs +1557 -0
- data/vendor/crates/spikard-http/src/server/lifecycle_execution.rs +98 -0
- data/vendor/crates/spikard-http/src/server/mod.rs +806 -0
- data/vendor/crates/spikard-http/src/server/request_extraction.rs +630 -0
- data/vendor/crates/spikard-http/src/server/routing_factory.rs +497 -0
- data/vendor/crates/spikard-http/src/sse.rs +961 -0
- data/vendor/crates/spikard-http/src/testing/form.rs +14 -0
- data/vendor/crates/spikard-http/src/testing/multipart.rs +60 -0
- data/vendor/crates/spikard-http/src/testing/test_client.rs +285 -0
- data/vendor/crates/spikard-http/src/testing.rs +377 -0
- data/vendor/crates/spikard-http/src/websocket.rs +831 -0
- data/vendor/crates/spikard-http/tests/background_behavior.rs +918 -0
- data/vendor/crates/spikard-http/tests/common/handlers.rs +308 -0
- data/vendor/crates/spikard-http/tests/common/mod.rs +21 -0
- data/vendor/crates/spikard-http/tests/di_integration.rs +202 -0
- data/vendor/crates/spikard-http/tests/doc_snippets.rs +4 -0
- data/vendor/crates/spikard-http/tests/lifecycle_execution.rs +1135 -0
- data/vendor/crates/spikard-http/tests/multipart_behavior.rs +688 -0
- data/vendor/crates/spikard-http/tests/server_config_builder.rs +324 -0
- data/vendor/crates/spikard-http/tests/sse_behavior.rs +728 -0
- data/vendor/crates/spikard-http/tests/websocket_behavior.rs +724 -0
- data/vendor/crates/spikard-rb/Cargo.toml +43 -0
- data/vendor/crates/spikard-rb/build.rs +199 -0
- data/vendor/crates/spikard-rb/src/background.rs +63 -0
- data/vendor/crates/spikard-rb/src/config/mod.rs +5 -0
- data/vendor/crates/spikard-rb/src/config/server_config.rs +283 -0
- data/vendor/crates/spikard-rb/src/conversion.rs +459 -0
- data/vendor/crates/spikard-rb/src/di/builder.rs +105 -0
- data/vendor/crates/spikard-rb/src/di/mod.rs +413 -0
- data/vendor/crates/spikard-rb/src/handler.rs +612 -0
- data/vendor/crates/spikard-rb/src/integration/mod.rs +3 -0
- data/vendor/crates/spikard-rb/src/lib.rs +1857 -0
- data/vendor/crates/spikard-rb/src/lifecycle.rs +275 -0
- data/vendor/crates/spikard-rb/src/metadata/mod.rs +5 -0
- data/vendor/crates/spikard-rb/src/metadata/route_extraction.rs +427 -0
- data/vendor/crates/spikard-rb/src/runtime/mod.rs +5 -0
- data/vendor/crates/spikard-rb/src/runtime/server_runner.rs +326 -0
- data/vendor/crates/spikard-rb/src/server.rs +283 -0
- data/vendor/crates/spikard-rb/src/sse.rs +231 -0
- data/vendor/crates/spikard-rb/src/testing/client.rs +404 -0
- data/vendor/crates/spikard-rb/src/testing/mod.rs +7 -0
- data/vendor/crates/spikard-rb/src/testing/sse.rs +143 -0
- data/vendor/crates/spikard-rb/src/testing/websocket.rs +221 -0
- data/vendor/crates/spikard-rb/src/websocket.rs +233 -0
- data/vendor/crates/spikard-rb/tests/magnus_ffi_tests.rs +14 -0
- metadata +213 -0
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
//! Tests for ServerConfig builder with dependency injection
|
|
2
|
+
|
|
3
|
+
mod common;
|
|
4
|
+
|
|
5
|
+
#[cfg(feature = "di")]
|
|
6
|
+
mod di_builder_tests {
|
|
7
|
+
use spikard_core::di::ValueDependency;
|
|
8
|
+
use spikard_http::ServerConfig;
|
|
9
|
+
use std::sync::Arc;
|
|
10
|
+
|
|
11
|
+
#[test]
|
|
12
|
+
fn test_builder_basic() {
|
|
13
|
+
let config = ServerConfig::builder().port(3000).host("0.0.0.0").build();
|
|
14
|
+
|
|
15
|
+
assert_eq!(config.port, 3000);
|
|
16
|
+
assert_eq!(config.host, "0.0.0.0");
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
#[test]
|
|
20
|
+
fn test_provide_value() {
|
|
21
|
+
let config = ServerConfig::builder()
|
|
22
|
+
.provide_value("test", "value".to_string())
|
|
23
|
+
.build();
|
|
24
|
+
|
|
25
|
+
assert!(config.di_container.is_some());
|
|
26
|
+
let container = config.di_container.unwrap();
|
|
27
|
+
|
|
28
|
+
// Verify the dependency exists (we can't easily resolve it here without a request)
|
|
29
|
+
// but we can check the container exists
|
|
30
|
+
assert!(Arc::strong_count(&container) >= 1);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
#[test]
|
|
34
|
+
fn test_provide_multiple_values() {
|
|
35
|
+
let config = ServerConfig::builder()
|
|
36
|
+
.provide_value("val1", 1)
|
|
37
|
+
.provide_value("val2", 2)
|
|
38
|
+
.provide_value("val3", "three".to_string())
|
|
39
|
+
.build();
|
|
40
|
+
|
|
41
|
+
assert!(config.di_container.is_some());
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
#[test]
|
|
45
|
+
fn test_provide_factory() {
|
|
46
|
+
let config = ServerConfig::builder()
|
|
47
|
+
.provide_factory("counter", |_resolved| async { Ok(42) })
|
|
48
|
+
.build();
|
|
49
|
+
|
|
50
|
+
assert!(config.di_container.is_some());
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
#[test]
|
|
54
|
+
fn test_provide_value_and_factory() {
|
|
55
|
+
let config = ServerConfig::builder()
|
|
56
|
+
.provide_value("base_value", 10)
|
|
57
|
+
.provide_factory("computed", |_resolved| async { Ok(100) })
|
|
58
|
+
.build();
|
|
59
|
+
|
|
60
|
+
assert!(config.di_container.is_some());
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
#[test]
|
|
64
|
+
fn test_provide_custom_dependency() {
|
|
65
|
+
let dep = ValueDependency::new("custom", "value".to_string());
|
|
66
|
+
|
|
67
|
+
let config = ServerConfig::builder().provide(Arc::new(dep)).build();
|
|
68
|
+
|
|
69
|
+
assert!(config.di_container.is_some());
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
#[test]
|
|
73
|
+
fn test_builder_chaining() {
|
|
74
|
+
let config = ServerConfig::builder()
|
|
75
|
+
.port(8080)
|
|
76
|
+
.host("localhost")
|
|
77
|
+
.enable_request_id(false)
|
|
78
|
+
.provide_value("app_name", "TestApp".to_string())
|
|
79
|
+
.provide_value("version", "1.0.0".to_string())
|
|
80
|
+
.build();
|
|
81
|
+
|
|
82
|
+
assert_eq!(config.port, 8080);
|
|
83
|
+
assert_eq!(config.host, "localhost");
|
|
84
|
+
assert!(!config.enable_request_id);
|
|
85
|
+
assert!(config.di_container.is_some());
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
#[test]
|
|
89
|
+
fn test_builder_with_all_options() {
|
|
90
|
+
use spikard_http::{BackgroundTaskConfig, CompressionConfig, RateLimitConfig};
|
|
91
|
+
|
|
92
|
+
let config = ServerConfig::builder()
|
|
93
|
+
.port(9000)
|
|
94
|
+
.host("127.0.0.1")
|
|
95
|
+
.workers(4)
|
|
96
|
+
.enable_request_id(true)
|
|
97
|
+
.max_body_size(Some(5 * 1024 * 1024))
|
|
98
|
+
.request_timeout(Some(60))
|
|
99
|
+
.compression(Some(CompressionConfig::default()))
|
|
100
|
+
.rate_limit(Some(RateLimitConfig::default()))
|
|
101
|
+
.graceful_shutdown(true)
|
|
102
|
+
.shutdown_timeout(30)
|
|
103
|
+
.background_tasks(BackgroundTaskConfig::default())
|
|
104
|
+
.provide_value("config_value", "test".to_string())
|
|
105
|
+
.build();
|
|
106
|
+
|
|
107
|
+
assert_eq!(config.port, 9000);
|
|
108
|
+
assert_eq!(config.host, "127.0.0.1");
|
|
109
|
+
assert_eq!(config.workers, 4);
|
|
110
|
+
assert!(config.enable_request_id);
|
|
111
|
+
assert_eq!(config.max_body_size, Some(5 * 1024 * 1024));
|
|
112
|
+
assert_eq!(config.request_timeout, Some(60));
|
|
113
|
+
assert!(config.compression.is_some());
|
|
114
|
+
assert!(config.rate_limit.is_some());
|
|
115
|
+
assert!(config.graceful_shutdown);
|
|
116
|
+
assert_eq!(config.shutdown_timeout, 30);
|
|
117
|
+
assert!(config.di_container.is_some());
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
#[test]
|
|
121
|
+
fn test_factory_with_dependencies() {
|
|
122
|
+
let config = ServerConfig::builder()
|
|
123
|
+
.provide_value("multiplier", 2)
|
|
124
|
+
.provide_factory("result", |resolved| {
|
|
125
|
+
// Eagerly get the value to avoid lifetime issues
|
|
126
|
+
let multiplier = resolved.get::<i32>("multiplier").map(|v| *v);
|
|
127
|
+
async move {
|
|
128
|
+
let mult = multiplier.ok_or("multiplier not found")?;
|
|
129
|
+
Ok(mult * 21)
|
|
130
|
+
}
|
|
131
|
+
})
|
|
132
|
+
.build();
|
|
133
|
+
|
|
134
|
+
assert!(config.di_container.is_some());
|
|
135
|
+
|
|
136
|
+
// We can't easily test resolution here without creating a full request context,
|
|
137
|
+
// but we verified the factory can be registered
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
#[test]
|
|
141
|
+
fn test_builder_without_di() {
|
|
142
|
+
// Test that builder works fine without any DI configuration
|
|
143
|
+
let config = ServerConfig::builder().port(3000).host("localhost").build();
|
|
144
|
+
|
|
145
|
+
assert_eq!(config.port, 3000);
|
|
146
|
+
assert_eq!(config.host, "localhost");
|
|
147
|
+
assert!(config.di_container.is_none());
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
#[test]
|
|
151
|
+
fn test_multiple_factories() {
|
|
152
|
+
let config = ServerConfig::builder()
|
|
153
|
+
.provide_factory("factory1", |_resolved| async { Ok(1) })
|
|
154
|
+
.provide_factory("factory2", |_resolved| async { Ok(2) })
|
|
155
|
+
.provide_factory("factory3", |_resolved| async { Ok(3) })
|
|
156
|
+
.build();
|
|
157
|
+
|
|
158
|
+
assert!(config.di_container.is_some());
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
#[test]
|
|
162
|
+
fn test_mixed_dependencies() {
|
|
163
|
+
let config = ServerConfig::builder()
|
|
164
|
+
.provide_value("static1", "value1".to_string())
|
|
165
|
+
.provide_factory("dynamic1", |_resolved| async { Ok("computed1".to_string()) })
|
|
166
|
+
.provide_value("static2", 42)
|
|
167
|
+
.provide_factory("dynamic2", |_resolved| async { Ok(100) })
|
|
168
|
+
.build();
|
|
169
|
+
|
|
170
|
+
assert!(config.di_container.is_some());
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
#[test]
|
|
174
|
+
fn test_type_inference() {
|
|
175
|
+
// Test that the builder can infer types correctly
|
|
176
|
+
let config = ServerConfig::builder()
|
|
177
|
+
.provide_value("string", "test")
|
|
178
|
+
.provide_value("number", 42)
|
|
179
|
+
.provide_value("bool", true)
|
|
180
|
+
.provide_value("vec", vec![1, 2, 3])
|
|
181
|
+
.build();
|
|
182
|
+
|
|
183
|
+
assert!(config.di_container.is_some());
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
#[test]
|
|
187
|
+
fn test_builder_default() {
|
|
188
|
+
let builder = ServerConfig::builder();
|
|
189
|
+
let config = builder.build();
|
|
190
|
+
|
|
191
|
+
// Should have default values
|
|
192
|
+
assert_eq!(config.port, 8000);
|
|
193
|
+
assert_eq!(config.host, "127.0.0.1");
|
|
194
|
+
assert_eq!(config.workers, 1);
|
|
195
|
+
assert!(config.enable_request_id);
|
|
196
|
+
assert_eq!(config.max_body_size, Some(10 * 1024 * 1024));
|
|
197
|
+
assert_eq!(config.request_timeout, Some(30));
|
|
198
|
+
assert!(config.graceful_shutdown);
|
|
199
|
+
assert_eq!(config.shutdown_timeout, 30);
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
#[test]
|
|
203
|
+
fn test_builder_override_defaults() {
|
|
204
|
+
let config = ServerConfig::builder()
|
|
205
|
+
.port(9999)
|
|
206
|
+
.enable_request_id(false)
|
|
207
|
+
.max_body_size(None)
|
|
208
|
+
.build();
|
|
209
|
+
|
|
210
|
+
assert_eq!(config.port, 9999);
|
|
211
|
+
assert!(!config.enable_request_id);
|
|
212
|
+
assert_eq!(config.max_body_size, None);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
#[test]
|
|
216
|
+
fn test_provide_with_arc() {
|
|
217
|
+
// Test providing Arc<T> values
|
|
218
|
+
let shared_value = Arc::new("shared".to_string());
|
|
219
|
+
|
|
220
|
+
let config = ServerConfig::builder()
|
|
221
|
+
.provide_value("shared", shared_value.clone())
|
|
222
|
+
.build();
|
|
223
|
+
|
|
224
|
+
assert!(config.di_container.is_some());
|
|
225
|
+
// Original Arc is still valid
|
|
226
|
+
assert_eq!(*shared_value, "shared");
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
#[cfg(not(feature = "di"))]
|
|
231
|
+
mod no_di_tests {
|
|
232
|
+
use spikard_http::ServerConfig;
|
|
233
|
+
|
|
234
|
+
#[test]
|
|
235
|
+
fn test_builder_without_di_feature() {
|
|
236
|
+
// Test that builder works without DI feature enabled
|
|
237
|
+
let config = ServerConfig::builder().port(3000).host("localhost").build();
|
|
238
|
+
|
|
239
|
+
assert_eq!(config.port, 3000);
|
|
240
|
+
assert_eq!(config.host, "localhost");
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
/// Integration tests for common test handlers
|
|
245
|
+
///
|
|
246
|
+
/// These tests verify that the mock handlers in common module work correctly
|
|
247
|
+
/// and can be used for testing HTTP server components.
|
|
248
|
+
mod common_handler_tests {
|
|
249
|
+
use crate::common::handlers::{EchoHandler, ErrorHandler, JsonHandler, SuccessHandler};
|
|
250
|
+
use axum::body::Body;
|
|
251
|
+
use axum::http::Request;
|
|
252
|
+
use serde_json::json;
|
|
253
|
+
use spikard_http::{Handler, RequestData};
|
|
254
|
+
use std::collections::HashMap;
|
|
255
|
+
use std::sync::Arc;
|
|
256
|
+
|
|
257
|
+
fn create_test_request_data() -> RequestData {
|
|
258
|
+
RequestData {
|
|
259
|
+
path_params: Arc::new(HashMap::new()),
|
|
260
|
+
query_params: serde_json::Value::Null,
|
|
261
|
+
raw_query_params: Arc::new(HashMap::new()),
|
|
262
|
+
body: json!({"test": "data"}),
|
|
263
|
+
raw_body: None,
|
|
264
|
+
headers: Arc::new(HashMap::new()),
|
|
265
|
+
cookies: Arc::new(HashMap::new()),
|
|
266
|
+
method: "GET".to_string(),
|
|
267
|
+
path: "/test".to_string(),
|
|
268
|
+
#[cfg(feature = "di")]
|
|
269
|
+
dependencies: None,
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
#[tokio::test]
|
|
274
|
+
async fn test_success_handler_integration() {
|
|
275
|
+
let handler = SuccessHandler;
|
|
276
|
+
let request = Request::builder().body(Body::empty()).unwrap();
|
|
277
|
+
let request_data = create_test_request_data();
|
|
278
|
+
|
|
279
|
+
let result = handler.call(request, request_data).await;
|
|
280
|
+
assert!(result.is_ok(), "SuccessHandler should return Ok response");
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
#[tokio::test]
|
|
284
|
+
async fn test_error_handler_integration() {
|
|
285
|
+
let handler = ErrorHandler;
|
|
286
|
+
let request = Request::builder().body(Body::empty()).unwrap();
|
|
287
|
+
let request_data = create_test_request_data();
|
|
288
|
+
|
|
289
|
+
let result = handler.call(request, request_data).await;
|
|
290
|
+
assert!(result.is_err(), "ErrorHandler should return Err response");
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
#[tokio::test]
|
|
294
|
+
async fn test_echo_handler_integration() {
|
|
295
|
+
let handler = EchoHandler;
|
|
296
|
+
let request = Request::builder().body(Body::empty()).unwrap();
|
|
297
|
+
let request_data = create_test_request_data();
|
|
298
|
+
|
|
299
|
+
let result = handler.call(request, request_data).await;
|
|
300
|
+
assert!(result.is_ok(), "EchoHandler should return Ok response");
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
#[tokio::test]
|
|
304
|
+
async fn test_json_handler_ok_integration() {
|
|
305
|
+
let body = json!({"status": "ok", "data": [1, 2, 3]});
|
|
306
|
+
let handler = JsonHandler::ok(body);
|
|
307
|
+
let request = Request::builder().body(Body::empty()).unwrap();
|
|
308
|
+
let request_data = create_test_request_data();
|
|
309
|
+
|
|
310
|
+
let result = handler.call(request, request_data).await;
|
|
311
|
+
assert!(result.is_ok(), "JsonHandler::ok should return Ok response");
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
#[tokio::test]
|
|
315
|
+
async fn test_json_handler_created_integration() {
|
|
316
|
+
let body = json!({"id": 123, "created": true});
|
|
317
|
+
let handler = JsonHandler::created(body);
|
|
318
|
+
let request = Request::builder().body(Body::empty()).unwrap();
|
|
319
|
+
let request_data = create_test_request_data();
|
|
320
|
+
|
|
321
|
+
let result = handler.call(request, request_data).await;
|
|
322
|
+
assert!(result.is_ok(), "JsonHandler::created should return Ok response");
|
|
323
|
+
}
|
|
324
|
+
}
|