Skip to content

Commit

Permalink
Merge pull request #173 from mrc-ide/mrc-5738-no-unbox
Browse files Browse the repository at this point in the history
Don't automatically unbox vectors when making requests.
  • Loading branch information
richfitz authored Sep 5, 2024
2 parents f580aff + cc8c0f6 commit 08a2f60
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 7 deletions.
8 changes: 4 additions & 4 deletions R/location_http.R
Original file line number Diff line number Diff line change
Expand Up @@ -56,16 +56,16 @@ orderly_location_http <- R6::R6Class(

## TODO: we could get the schemas here from outpack_server too
list_unknown_packets = function(ids) {
res <- private$client$request("/packets/missing", function(r) {
httr2::req_body_json(r, list(ids = ids, unpacked = scalar(TRUE)))
})
res <- private$client$request(
"/packets/missing",
function(r) http_body_json(r, list(ids = ids, unpacked = scalar(TRUE))))
list_to_character(res$data)
},

list_unknown_files = function(hashes) {
res <- private$client$request(
"/files/missing",
function(r) httr2::req_body_json(r, list(hashes = hashes)))
function(r) http_body_json(r, list(hashes = hashes)))
list_to_character(res$data)
},

Expand Down
2 changes: 1 addition & 1 deletion R/outpack_hash.R
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ hash_files <- function(paths, algorithm = "sha256", named = FALSE) {
}


hash_data <- function(data, algorithm, call = NULL) {
hash_data <- function(data, algorithm = "sha256", call = NULL) {
assert_scalar_character(algorithm, call = call)
value <- openssl::multihash(data, algorithm)[[algorithm]]
sprintf("%s:%s", algorithm, as.character(value))
Expand Down
6 changes: 5 additions & 1 deletion R/outpack_http_client.R
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,10 @@ outpack_http_client <- R6::R6Class(
}
))

http_body_json <- function(request, body) {
httr2::req_body_json(request, body, auto_unbox = FALSE)
}

http_client_request <- function(url, customize = identity, download = NULL,
parse_json = TRUE) {
req <- httr2::request(url)
Expand Down Expand Up @@ -107,7 +111,7 @@ http_client_login <- function(name, auth) {
cli::cli_alert_info("Logging in to {name}")

res <- http_client_request(auth$url,
function(r) httr2::req_body_json(r, auth$data))
function(r) http_body_json(r, auth$data))

cli::cli_alert_success("Logged in successfully")
auth_cache[[key]] <- list("Authorization" = paste("Bearer", res$token))
Expand Down
37 changes: 36 additions & 1 deletion tests/testthat/test-zzz-location-http.R
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,25 @@ describe("server integration tests", {
msg)
expect_false(file.exists(dest))
})

it("can list missing packets", {
new_id <- outpack_id()
expect_setequal(client_http$list_unknown_packets(new_id), new_id)
expect_setequal(client_http$list_unknown_packets(ids), character(0))
expect_setequal(client_http$list_unknown_packets(c(new_id, ids)), new_id)
})

it("can list missing files", {
existing_hashes <- orderly_metadata(ids[[1]], root = path)$files$hash
new_hash <- hash_data(toString(runif(100)), algorithm = "sha256")

expect_setequal(
client_http$list_unknown_files(new_hash), new_hash)
expect_setequal(
client_http$list_unknown_files(existing_hashes), character(0))
expect_setequal(
client_http$list_unknown_files(c(new_hash, existing_hashes)), new_hash)
})
})


Expand Down Expand Up @@ -93,7 +112,23 @@ describe("http location integration tests", {
expect_false(file.exists(dest))
})

it("can push into server", {
it("can push a single packet", {
root_downstream <- create_temporary_root(use_file_store = TRUE)
ids_downstream <- create_random_packet(root_downstream, n_files = 1)
orderly_location_add("upstream", "http", list(url = url),
root = root_downstream)

plan <- orderly_location_push(ids_downstream, "upstream",
root = root_downstream)
expect_equal(length(plan$packet_id), 1)
expect_equal(length(plan$files), 1)

idx <- root$index$data()
expect_true(all(ids_downstream %in% names(idx$metadata)))
expect_true(all(root_downstream$files$list() %in% root$files$list()))
})

it("can push a packet chain into server", {
root_downstream <- create_temporary_root(use_file_store = TRUE)
ids_downstream <- create_random_packet_chain(root_downstream, 3)
orderly_location_add("upstream", "http", list(url = url),
Expand Down

0 comments on commit 08a2f60

Please sign in to comment.