Skip to content

Commit

Permalink
Split upload_rr_trace to allow manual upload fallback. (#145)
Browse files Browse the repository at this point in the history
  • Loading branch information
maleadt authored Nov 15, 2023
1 parent 4235da1 commit 7823619
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 27 deletions.
53 changes: 28 additions & 25 deletions src/BugReporting.jl
Original file line number Diff line number Diff line change
Expand Up @@ -547,16 +547,20 @@ function make_interactive_report(report_arg, ARGS=[])
mktempdir() do trace_dir
proc = rr_record(cmd, ARGS...; trace_dir=trace_dir, timeout=timeout, chaos=chaos, extras=true)
println("Preparing trace for upload (if your trace is large this may take a few minutes)...")
rr_pack(trace_dir)
tarball = pack_rr_trace(trace_dir)
params = get_upload_params()
if params !== nothing
path, creds = params

println("Uploading trace...")
withenv("AWS_REGION" => "us-east-1") do
upload_rr_trace(trace_dir, "s3://$TRACE_BUCKET/$path"; creds...)
upload_rr_tarball(tarball, "s3://$TRACE_BUCKET/$path"; creds...)
end
println("Uploaded to https://$TRACE_BUCKET.s3.amazonaws.com/$path")
rm(tarball)
else
println("""Uploading the trace failed, or was interrupted.
The trace has been saved for manual upload at $tarball""")
end
handle_child_error(proc)
end
Expand Down Expand Up @@ -617,13 +621,12 @@ function get_upload_params()
end
end
bind(c, t)
errormonitor(t)
connectionId = try
take!(c)
catch err
if !(err isa TaskFailedException)
errormonitor(t)
end
rethrow()
# the error should have been reported by `errormonitor`
return
end

println("To upload a trace, please authenticate by visiting:\n")
Expand All @@ -637,11 +640,8 @@ function get_upload_params()
if err isa InterruptException
println()
println("Canceled uploading the trace.")
return
elseif !(err isa TaskFailedException)
errormonitor(t)
end
rethrow()
return
end

println()
Expand All @@ -651,7 +651,7 @@ function get_upload_params()
session_token=s3creds["AWS_SESSION_TOKEN"])
end

function upload_rr_trace(trace_directory, url; access_key_id, secret_access_key, session_token)
function pack_rr_trace(trace_directory)
# Auto-pack this trace directory if it hasn't already been:
sample_directory = joinpath(trace_directory, "latest-trace")
if isdir(sample_directory) && uperm(sample_directory) & 0x2 == 0
Expand All @@ -660,21 +660,24 @@ function upload_rr_trace(trace_directory, url; access_key_id, secret_access_key,
rr_pack(trace_directory)
end

mktempdir() do dir
# Create a compressed tarball
# TODO: stream (peak/s5cmd#182)
tarball = joinpath(dir, "trace.tar")
Tar.create(trace_directory, tarball)
run(`$(zstdmt()) --quiet $tarball`)
dir = mktempdir()

# Upload
# TODO: progress bar (peak/s5cmd#51)
cmd = `$(s5cmd()) --log error cp $(tarball).zst $url`
cmd = addenv(cmd, "AWS_ACCESS_KEY_ID" => access_key_id,
"AWS_SECRET_ACCESS_KEY" => secret_access_key,
"AWS_SESSION_TOKEN" => session_token)
run(cmd)
end
# Create a compressed tarball
tarball = joinpath(dir, "trace.tar")
Tar.create(trace_directory, tarball)
run(`$(zstdmt()) --quiet $tarball`)

return "$(tarball).zst"
end

function upload_rr_tarball(tarball, url; access_key_id, secret_access_key, session_token)
# Upload
# TODO: progress bar (peak/s5cmd#51)
cmd = `$(s5cmd()) --log error cp $(tarball) $url`
cmd = addenv(cmd, "AWS_ACCESS_KEY_ID" => access_key_id,
"AWS_SECRET_ACCESS_KEY" => secret_access_key,
"AWS_SESSION_TOKEN" => session_token)
run(cmd)
end

function __init__()
Expand Down
6 changes: 4 additions & 2 deletions test/rr.jl
Original file line number Diff line number Diff line change
Expand Up @@ -103,18 +103,20 @@ end
end

# Test that we can upload a trace directory, and replay it.
tarball = BugReporting.pack_rr_trace(temp_trace_dir)
Minio.with(; public=true) do conf
creds, bucket = conf
s3_url = "s3://$(bucket.name)/test.tar.zst"
http_url = bucket.baseurl * "test.tar.zst"
endpoint_url = replace(bucket.baseurl, "$(bucket.name)/"=>"")
withenv("S3_ENDPOINT_URL" => endpoint_url) do
BugReporting.upload_rr_trace(temp_trace_dir, s3_url; creds.access_key_id,
creds.secret_access_key, creds.session_token)
BugReporting.upload_rr_tarball(tarball, s3_url; creds.access_key_id,
creds.secret_access_key, creds.session_token)
end

test_replay(http_url)
end
rm(tarball)
end

# Test that the --bug-report mode works
Expand Down

0 comments on commit 7823619

Please sign in to comment.