Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat(Radon): Enhance handling of hex-string, integers and binary buffers #2413

Open
wants to merge 25 commits into
base: 2.0-base
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
5bbea50
feat: implement HttpHead as new RADType
guidiaz Oct 10, 2023
3fdf8f9
chore: cargo fmt --all
guidiaz Oct 10, 2023
721347a
feat: handle repeated headers within http/head response
guidiaz Oct 11, 2023
ef30733
test: run valid http head retrieval
guidiaz Oct 11, 2023
a665397
test: try http-head data request w/ invalid request header
guidiaz Oct 11, 2023
198e5b8
chore: bump package versions
guidiaz Oct 11, 2023
9bae448
chore: cargo fmt --all
guidiaz Oct 11, 2023
af5ff86
chore: solve clippy warnings
guidiaz Oct 11, 2023
ac57ded
fix: use http::Response::headers(&self) to transform response to HTTP…
guidiaz Oct 11, 2023
5e073f9
chore: attend pr review comments
guidiaz Oct 20, 2023
6c4d1ac
feat(rad): add support to binary sources
guidiaz Oct 20, 2023
0cfd81d
chore(rad): refactor existing tests
guidiaz Oct 20, 2023
68c7648
chore: attend pr review comments
guidiaz Oct 26, 2023
184f768
chore: cargo clippy --fix
guidiaz Oct 26, 2023
cd4641c
feat(rad): add new RadonErrors::BufferIsNotValue
guidiaz Oct 26, 2023
f1314a4
fix(rad): http-head response headers can contain 'accept-ranges'
guidiaz Nov 14, 2023
1f2402b
feat(rad): implement StringReplace
guidiaz Nov 14, 2023
533c103
feat(rad): implement StringSlice
guidiaz Nov 14, 2023
b3322b1
feat(rad): implement StringSplit
guidiaz Nov 14, 2023
88c8674
feat(rad): first approach to ArrayJoin
guidiaz Nov 14, 2023
0ab36ce
chore(rad): rename asX <-> toX depending on whether conversion may fail
guidiaz Dec 13, 2023
1c7a4a2
feat(rad): implement RadonOpCodes::BytesAsInteger
guidiaz Dec 13, 2023
ae50ed8
feat(rad): support multiple encoding schemas on RadonOpCodes::BytesSt…
guidiaz Dec 13, 2023
888ef3b
feat(rad): implement RadonOpCodes::IntegerToBytes
guidiaz Dec 13, 2023
179503c
feat(rad): implement RadonOpCodes::StringAsBytes
guidiaz Dec 13, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
test: try http-head data request w/ invalid request header
  • Loading branch information
guidiaz committed Oct 11, 2023
commit a6653977a7d3aa97da4bf1dcc19d07d239050b39
54 changes: 53 additions & 1 deletion rad/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -302,7 +302,7 @@ async fn http_response(
builder.method("POST").uri(&retrieve.url),
WitnetHttpBody::from(retrieve.body.clone()),
)
},
}
RADType::HttpHead => (
builder.method("HEAD").uri(&retrieve.url),
WitnetHttpBody::empty(),
Expand Down Expand Up @@ -1607,6 +1607,58 @@ mod tests {
}
}

#[test]
fn test_try_data_request_http_get_non_ascii_header_key() {
let script_r = Value::Array(vec![]);
let packed_script_r = serde_cbor::to_vec(&script_r).unwrap();
let body = Vec::from(String::from(""));
let headers = vec![("ñ", "value")];
let headers = headers
.into_iter()
.map(|(a, b)| (a.to_string(), b.to_string()))
.collect();
let request = RADRequest {
time_lock: 0,
retrieve: vec![RADRetrieve {
kind: RADType::HttpGet,
url: String::from("http://127.0.0.1"),
script: packed_script_r,
body,
headers,
}],
aggregate: RADAggregate {
filters: vec![],
reducer: RadonReducers::Mode as u32,
},
tally: RADTally {
filters: vec![],
reducer: RadonReducers::Mode as u32,
},
};
let report = try_data_request(
&request,
RadonScriptExecutionSettings::enable_all(),
None,
None,
);
let tally_result = report.tally.into_inner();

assert_eq!(
tally_result,
RadonTypes::RadonError(
RadonError::try_from(RadError::UnhandledIntercept {
inner: Some(Box::new(RadError::InvalidHttpHeader {
name: "ñ".to_string(),
value: "value".to_string(),
error: "invalid HTTP header name".to_string()
})),
message: None
})
.unwrap()
)
);
}

#[test]
fn test_try_data_request_http_post_non_ascii_header_key() {
let script_r = Value::Array(vec![]);
Expand Down