Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
bytecodealliance
GitHub Repository: bytecodealliance/wasmtime
Path: blob/main/crates/wasi-http/tests/all/p2/sync.rs
3092 views
1
use super::*;
2
use test_programs_artifacts::*;
3
use wasmtime_wasi::p2::bindings::sync::Command;
4
5
foreach_p2_http!(assert_test_exists);
6
7
fn run(path: &str, server: &Server) -> Result<()> {
8
let engine = test_programs_artifacts::engine(|config| {
9
config.wasm_backtrace_details(wasmtime::WasmBacktraceDetails::Enable);
10
});
11
let component = Component::from_file(&engine, path)?;
12
let mut store = store(&engine, server);
13
let mut linker = Linker::new(&engine);
14
wasmtime_wasi::p2::add_to_linker_sync(&mut linker)?;
15
wasmtime_wasi_http::add_only_http_to_linker_sync(&mut linker)?;
16
let command = Command::instantiate(&mut store, &component, &linker)?;
17
let result = command.wasi_cli_run().call_run(&mut store)?;
18
result.map_err(|()| wasmtime::format_err!("run returned an error"))
19
}
20
21
#[test_log::test]
22
fn p2_http_outbound_request_get() -> Result<()> {
23
let server = Server::http1(1)?;
24
run(P2_HTTP_OUTBOUND_REQUEST_GET_COMPONENT, &server)
25
}
26
27
#[test_log::test]
28
fn p2_http_outbound_request_timeout() -> Result<()> {
29
let server = Server::http1(1)?;
30
run(P2_HTTP_OUTBOUND_REQUEST_TIMEOUT_COMPONENT, &server)
31
}
32
33
#[test_log::test]
34
fn p2_http_outbound_request_post() -> Result<()> {
35
let server = Server::http1(1)?;
36
run(P2_HTTP_OUTBOUND_REQUEST_POST_COMPONENT, &server)
37
}
38
39
#[test_log::test]
40
fn p2_http_outbound_request_large_post() -> Result<()> {
41
let server = Server::http1(1)?;
42
run(P2_HTTP_OUTBOUND_REQUEST_LARGE_POST_COMPONENT, &server)
43
}
44
45
#[test_log::test]
46
fn p2_http_outbound_request_put() -> Result<()> {
47
let server = Server::http1(1)?;
48
run(P2_HTTP_OUTBOUND_REQUEST_PUT_COMPONENT, &server)
49
}
50
51
#[test_log::test]
52
fn p2_http_outbound_request_invalid_version() -> Result<()> {
53
let server = Server::http2(1)?;
54
run(P2_HTTP_OUTBOUND_REQUEST_INVALID_VERSION_COMPONENT, &server)
55
}
56
57
#[test_log::test]
58
fn p2_http_outbound_request_invalid_header() -> Result<()> {
59
let server = Server::http2(1)?;
60
run(P2_HTTP_OUTBOUND_REQUEST_INVALID_HEADER_COMPONENT, &server)
61
}
62
63
#[test_log::test]
64
fn p2_http_outbound_request_unknown_method() -> Result<()> {
65
let server = Server::http1(1)?;
66
run(P2_HTTP_OUTBOUND_REQUEST_UNKNOWN_METHOD_COMPONENT, &server)
67
}
68
69
#[test_log::test]
70
fn p2_http_outbound_request_unsupported_scheme() -> Result<()> {
71
let server = Server::http1(1)?;
72
run(
73
P2_HTTP_OUTBOUND_REQUEST_UNSUPPORTED_SCHEME_COMPONENT,
74
&server,
75
)
76
}
77
78
#[test_log::test]
79
fn p2_http_outbound_request_invalid_port() -> Result<()> {
80
let server = Server::http1(1)?;
81
run(P2_HTTP_OUTBOUND_REQUEST_INVALID_PORT_COMPONENT, &server)
82
}
83
84
#[test_log::test]
85
fn p2_http_outbound_request_invalid_dnsname() -> Result<()> {
86
let server = Server::http1(1)?;
87
run(P2_HTTP_OUTBOUND_REQUEST_INVALID_DNSNAME_COMPONENT, &server)
88
}
89
90
#[test_log::test]
91
fn p2_http_outbound_request_response_build() -> Result<()> {
92
let server = Server::http1(1)?;
93
run(P2_HTTP_OUTBOUND_REQUEST_RESPONSE_BUILD_COMPONENT, &server)
94
}
95
96
#[test_log::test]
97
fn p2_http_outbound_request_content_length() -> Result<()> {
98
let server = Server::http1(1)?;
99
run(P2_HTTP_OUTBOUND_REQUEST_CONTENT_LENGTH_COMPONENT, &server)
100
}
101
102
#[test_log::test]
103
fn p2_http_outbound_request_missing_path_and_query() -> Result<()> {
104
let server = Server::http1(1)?;
105
run(
106
P2_HTTP_OUTBOUND_REQUEST_MISSING_PATH_AND_QUERY_COMPONENT,
107
&server,
108
)
109
}
110
111