mirror of
https://github.com/facebook/sapling.git
synced 2024-10-10 08:47:12 +03:00
push_redirector: add contexts
Summary: The more contexts the better. Makes debugging errors much more pleasant. Reviewed By: StanislavGlebik Differential Revision: D22890940 fbshipit-source-id: 48f89031b4b5f9b15f69734d784969e2986b926d
This commit is contained in:
parent
0d45afef56
commit
fe487f9e8b
@ -20,7 +20,7 @@ use crate::{
|
|||||||
BundleResolverError, PostResolveAction, PostResolveBookmarkOnlyPushRebase,
|
BundleResolverError, PostResolveAction, PostResolveBookmarkOnlyPushRebase,
|
||||||
PostResolveInfinitePush, PostResolvePush, PostResolvePushRebase, UploadedBonsais,
|
PostResolveInfinitePush, PostResolvePush, PostResolvePushRebase, UploadedBonsais,
|
||||||
};
|
};
|
||||||
use anyhow::{format_err, Error};
|
use anyhow::{format_err, Context, Error};
|
||||||
use backsyncer::{backsync_latest, BacksyncLimit, TargetRepoDbs};
|
use backsyncer::{backsync_latest, BacksyncLimit, TargetRepoDbs};
|
||||||
use blobrepo::BlobRepo;
|
use blobrepo::BlobRepo;
|
||||||
use blobrepo_hg::BlobRepoHg;
|
use blobrepo_hg::BlobRepoHg;
|
||||||
@ -383,7 +383,8 @@ impl PushRedirector {
|
|||||||
let maybe_bookmark_push = match maybe_bookmark_push {
|
let maybe_bookmark_push = match maybe_bookmark_push {
|
||||||
Some(bookmark_push) => Some(
|
Some(bookmark_push) => Some(
|
||||||
self.convert_infinite_bookmark_push_small_to_large(ctx.clone(), bookmark_push)
|
self.convert_infinite_bookmark_push_small_to_large(ctx.clone(), bookmark_push)
|
||||||
.await?,
|
.await
|
||||||
|
.context("while converting infinite bookmark push small-to-large")?,
|
||||||
),
|
),
|
||||||
None => None,
|
None => None,
|
||||||
};
|
};
|
||||||
@ -414,7 +415,8 @@ impl PushRedirector {
|
|||||||
|
|
||||||
let bookmark_push = self
|
let bookmark_push = self
|
||||||
.convert_plain_bookmark_push_small_to_large(ctx.clone(), bookmark_push)
|
.convert_plain_bookmark_push_small_to_large(ctx.clone(), bookmark_push)
|
||||||
.await?;
|
.await
|
||||||
|
.context("while converting converting plain bookmark push small-to-large")?;
|
||||||
|
|
||||||
Ok(PostResolveBookmarkOnlyPushRebase {
|
Ok(PostResolveBookmarkOnlyPushRebase {
|
||||||
bookmark_push,
|
bookmark_push,
|
||||||
@ -433,16 +435,24 @@ impl PushRedirector {
|
|||||||
use UnbundleResponse::*;
|
use UnbundleResponse::*;
|
||||||
match orig {
|
match orig {
|
||||||
PushRebase(resp) => Ok(PushRebase(
|
PushRebase(resp) => Ok(PushRebase(
|
||||||
self.convert_unbundle_pushrebase_response(ctx, resp).await?,
|
self.convert_unbundle_pushrebase_response(ctx, resp)
|
||||||
|
.await
|
||||||
|
.context("while converting unbundle pushrebase response")?,
|
||||||
)),
|
)),
|
||||||
BookmarkOnlyPushRebase(resp) => Ok(BookmarkOnlyPushRebase(
|
BookmarkOnlyPushRebase(resp) => Ok(BookmarkOnlyPushRebase(
|
||||||
self.convert_unbundle_bookmark_only_pushrebase_response(ctx, resp)
|
self.convert_unbundle_bookmark_only_pushrebase_response(ctx, resp)
|
||||||
.await?,
|
.await
|
||||||
|
.context("while converting unbundle bookmark-only pushrebase response")?,
|
||||||
|
)),
|
||||||
|
Push(resp) => Ok(Push(
|
||||||
|
self.convert_unbundle_push_response(ctx, resp)
|
||||||
|
.await
|
||||||
|
.context("while converting unbundle push response")?,
|
||||||
)),
|
)),
|
||||||
Push(resp) => Ok(Push(self.convert_unbundle_push_response(ctx, resp).await?)),
|
|
||||||
InfinitePush(resp) => Ok(InfinitePush(
|
InfinitePush(resp) => Ok(InfinitePush(
|
||||||
self.convert_unbundle_infinite_push_response(ctx, resp)
|
self.convert_unbundle_infinite_push_response(ctx, resp)
|
||||||
.await?,
|
.await
|
||||||
|
.context("while converting unbundle infinitepush response")?,
|
||||||
)),
|
)),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -474,12 +484,20 @@ impl PushRedirector {
|
|||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let (pushrebased_rev, pushrebased_changesets) = try_join!(
|
let (pushrebased_rev, pushrebased_changesets) = try_join!(
|
||||||
|
async {
|
||||||
self.remap_changeset_expect_rewritten_or_preserved(
|
self.remap_changeset_expect_rewritten_or_preserved(
|
||||||
ctx.clone(),
|
ctx.clone(),
|
||||||
&self.large_to_small_commit_syncer,
|
&self.large_to_small_commit_syncer,
|
||||||
pushrebased_rev,
|
pushrebased_rev,
|
||||||
),
|
)
|
||||||
self.convert_pushrebased_changesets(ctx.clone(), pushrebased_changesets),
|
.await
|
||||||
|
.context("while remapping pushrebased rev")
|
||||||
|
},
|
||||||
|
async {
|
||||||
|
self.convert_pushrebased_changesets(ctx.clone(), pushrebased_changesets)
|
||||||
|
.await
|
||||||
|
.context("while converting pushrebased changesets")
|
||||||
|
},
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let onto = self
|
let onto = self
|
||||||
|
Loading…
Reference in New Issue
Block a user