Skip to content

Commit

Permalink
Fix waiting for publishing to complete when publishing to a sparse re…
Browse files Browse the repository at this point in the history
…gistry
  • Loading branch information
arlosi committed Nov 9, 2022
1 parent 3115dd6 commit 90c6b58
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 6 deletions.
1 change: 1 addition & 0 deletions crates/cargo-test-support/src/registry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -469,6 +469,7 @@ impl Drop for HttpServerHandle {
}

/// Request to the test http server
#[derive(Clone)]
pub struct Request {
pub url: Url,
pub method: String,
Expand Down
1 change: 1 addition & 0 deletions src/cargo/sources/registry/http_remote.rs
Original file line number Diff line number Diff line change
Expand Up @@ -549,6 +549,7 @@ impl<'cfg> RegistryData for HttpRegistry<'cfg> {
// All it does is ensure that a subsequent load will double-check files with the
// server rather than rely on a locally cached copy of the index files.
debug!("invalidated index cache");
self.fresh.clear();
self.requested_update = true;
}

Expand Down
17 changes: 11 additions & 6 deletions tests/testsuite/publish.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2570,20 +2570,25 @@ fn wait_for_subsequent_publish() {
// Counter for number of tries before the package is "published"
let arc: Arc<Mutex<u32>> = Arc::new(Mutex::new(0));
let arc2 = arc.clone();
let publish_req = Arc::new(Mutex::new(None));
let publish_req2 = publish_req.clone();

// Registry returns an invalid response.
let registry = registry::RegistryBuilder::new()
.http_index()
.http_api()
.add_responder("/api/v1/crates/new", move |req, server| {
// Capture the publish request, but defer publishing
*publish_req.lock().unwrap() = Some(req.clone());
server.ok(req)
})
.add_responder("/index/de/la/delay", move |req, server| {
let mut lock = arc.lock().unwrap();
*lock += 1;
// if the package name contains _ or -
if *lock <= 2 {
server.not_found(req)
} else {
server.index(req)
if *lock == 3 {
// Run the publish on the 3rd attempt
server.publish(&publish_req2.lock().unwrap().as_ref().unwrap());
}
server.index(req)
})
.build();

Expand Down

0 comments on commit 90c6b58

Please sign in to comment.