Commit Graph

61817 Commits

Author SHA1 Message Date
Lukas Piatkowski
0f54cc3d63 mononoke/blobstore: make Blobstore generic over lifetime
Summary: Remove 'static requirement for async methods of Blobstore, propagate this change and fixup low hanging fruits where the code can become 'static free easily.

Reviewed By: ahornby, farnz

Differential Revision: D24839054

fbshipit-source-id: 5d5daa04c23c4c9ae902b669b0a71fe41ee6dee6
2020-11-20 05:51:52 -08:00
svcscm
a354b73ff5 Updating submodules
Summary:
GitHub commits:

d5f68ec943

Reviewed By: wittgenst

fbshipit-source-id: f42ce70830bb72ef2875d83aaa3aa0ec0f2684cb
2020-11-20 05:51:52 -08:00
svcscm
abcda076bf Updating submodules
Summary:
GitHub commits:

23784f94c3

Reviewed By: wittgenst

fbshipit-source-id: e5962b6adc57b1c98d26feb1caa7bb685c840478
2020-11-19 22:21:41 -08:00
Xavier Deguillard
8260e17f39 inodes: re-order some cache invalidation
Summary:
It feels like invalidating the entry before the directory makes slightly more
sense, so do it in that order.

Reviewed By: chadaustin

Differential Revision: D24800817

fbshipit-source-id: ed053d07bbae6954c276d1ad7a1ff247e5c055d9
2020-11-19 21:59:44 -08:00
svcscm
e7768fe490 Updating submodules
Summary:
GitHub commits:

05e2775fd5
40f5757736

Reviewed By: wittgenst

fbshipit-source-id: 491c2fcb26f9050cdba7a6bcf6ee9cff9b8fd313
2020-11-19 21:59:44 -08:00
svcscm
41b97fae53 Updating submodules
Summary:
GitHub commits:

65cd36c42e
f94973cb28
cac093c33e
8de18cf4c8
c9bee22de1
2f8f61b9fa
f4e3bb7a86

Reviewed By: wittgenst

fbshipit-source-id: 0497fdaf292f0e3c64b6ab1a30c541e8cd9103cd
2020-11-19 19:05:08 -08:00
Durham Goode
132f37fa14 py3: fix hggit tests
Summary:
It turns out the hggit tests weren't passing in Python 3, despite us
having removed them from our py3-broken list. Woops. This fixes them and enables
the tests.

Reviewed By: sfilipco

Differential Revision: D25095189

fbshipit-source-id: acffca34b0d5defa7575ede60621ca2ce0a2afe4
2020-11-19 18:47:02 -08:00
Durham Goode
a0af56bbd4 extras: allow surrogateescaped byte extras
Summary:
Back in March we forced all extras to be strings. It turns out hggit
needs to write binary extras since it stores some binary patches in extras.
To support that, let's encode commit extras using surrogateescaped. That will
allow hggit to put binary data in extras in a later diff.

Reviewed By: sfilipco

Differential Revision: D25095190

fbshipit-source-id: 330bf06b15fc435f70119490557b8c22341b6ed9
2020-11-19 18:47:02 -08:00
svcscm
67c252112d Updating submodules
Summary:
GitHub commits:

96e8cdea2a

Reviewed By: wittgenst

fbshipit-source-id: ece8391384d3fbacaf842328f403f84e8f414020
2020-11-19 18:47:02 -08:00
svcscm
09575cae82 Updating submodules
Summary:
GitHub commits:

d24311872c
1d8a044578
21073611ec
c3baa9b748
a65e905bbb
c313f43877
e552ae42fa
ead050ec08
9d738e8113

Reviewed By: wittgenst

fbshipit-source-id: 6c3d78b9f401a81c3612cf836bdc5a1cfb9e4228
2020-11-19 14:04:57 -08:00
Aida Getoeva
49a5eff46f mononoke/sql: fix connection to the sharded db
Summary:
Apparently shards for some DBs start from 1 (production_filenodes) and for some - from 0 (production_blobstore).
This diff fixed the issue for mysql connections.

Long term we might want to query SMC for the list of shards instead of hardcoding different values in the different places.

Reviewed By: farnz

Differential Revision: D25057136

fbshipit-source-id: 9201a2ec8afe0b66a246a2ee91cc9389630f5ddf
2020-11-19 13:16:01 -08:00
Chad Austin
3f59c5f443 add eden trace hg command
Summary:
Add a TraceBus to HgQueuedBackingStore and allow tracing import events over Thrift.

This powers a new `eden trace hg` command that allows a live view of
tree and blob imports.

Reviewed By: genevievehelsel

Differential Revision: D24732059

fbshipit-source-id: 525152fe39047160a68c1706217a06a00a6dbef1
2020-11-19 13:02:42 -08:00
Stanislau Hlebik
dec791e015 mononoke: do not report bookmark validation error if we get an infra error
Summary:
We got a few ubns because one bookmark validator in a single region wasn't able
to connect to mysql and was reporting errors.

This diff fixes by separating logical and infra errors

Reviewed By: ikostia

Differential Revision: D25092364

fbshipit-source-id: 93f4be1a7e0467051b7b8d927eef9b4f5cd6a983
2020-11-19 12:57:50 -08:00
Thomas Orozco
d3235ff615 mononoke: remove name from HgBlobEntry
Summary:
This isn't actually being consulted anywhere save for a single test, so let's
just remove it (it's not like the test checks anything important — that field
might not as well exist given we never read it).

Reviewed By: farnz

Differential Revision: D25093494

fbshipit-source-id: 5f4a53f8666fc0e8a89ceade44baa96e71fb813f
2020-11-19 12:55:28 -08:00
Thomas Orozco
dae48357ac mononoke/mercurial_types: remove redundant passing of path in upload
Summary:
This is a bit unnecessary as it stands — we roundtrip the path through
execute() just to return it back. This path was used for trace logging, but
given we literally never look at this log, let's just simplify this logging a
little bit.

Reviewed By: StanislavGlebik

Differential Revision: D25089344

fbshipit-source-id: 15b0f1cce8c9b2938429de19ff063e5677794912
2020-11-19 12:55:28 -08:00
Jun Wu
e91552fefe template: add rev f64 compatibility
Summary:
With segmented changelog, rev can exceed f64 safe range
(Number.MAX_SAFE_INTEGER in Javascript, 9007199254740991, 0x1fffffffffffff).
If rev is used in JSON, then the JSON cannot be parsed with precise rev
information.

This diff adds a compatibility mode so template will map the out-of-range revs
to safe range, and the mapped revs can be detected, and mapped back to be
resolved correctly.

Reviewed By: sfilipco

Differential Revision: D25079001

fbshipit-source-id: 52a5a2c8345a76355b8bf81435034d90c7c31610
2020-11-19 12:15:36 -08:00
Mateusz Kwapich
51b21dd9a7 unit test for dechunker raw bundle2 saving
Summary: Tests the behaviour of collecting the raw bundles.

Reviewed By: krallin

Differential Revision: D25025255

fbshipit-source-id: 114da273a28d131f5dd24047ed28ea23d076f235
2020-11-19 06:41:06 -08:00
svcscm
e83e374cbf Updating submodules
Summary:
GitHub commits:

b0ed2651c5

Reviewed By: wittgenst

fbshipit-source-id: d4bcb67d900a1fd9acb46b6c9b717678f5c3409e
2020-11-19 06:41:05 -08:00
svcscm
214d16f19a Updating submodules
Summary:
GitHub commits:

5c0e734399

Reviewed By: wittgenst

fbshipit-source-id: afb3e7c2e4af14ab1aa6330e9a5c2f32a487b6b1
2020-11-19 01:19:40 -08:00
David Tolnay
448edf7461 Format fbsource with rustfmt-2.0.0-rc.2
Reviewed By: zertosh

Differential Revision: D25075717

fbshipit-source-id: 244182839311f96b69f381c07983276a04ecc5d3
2020-11-18 19:46:38 -08:00
svcscm
8d16795168 Updating submodules
Summary:
GitHub commits:

624ed1d73a
e7ed73b5d7
70f23c02f7
25945ac6b5
e09e652b4b
ab0d3485c0
3ba8a5b46b
98e23fb5ed
20addcb258
d1252735ac
88c62f5c25

Reviewed By: wittgenst

fbshipit-source-id: dbaa1c390709d25ac21aa8c366ea128e754429b1
2020-11-18 19:46:38 -08:00
svcscm
f0934d350e Updating submodules
Summary:
GitHub commits:

450c59e64f
e6f71ead55
a0347d6ebd
2c41d995ec
bb1f43f913
c23b0145d8
5230e6f940
506e2dec32
42526e8c50
6bd769e2b7
42c1c7f726
51fcbea370

Reviewed By: wittgenst

fbshipit-source-id: 4e775a0f8ae01ef48815cea669c9913de1edd00d
2020-11-18 18:09:10 -08:00
Arun Kulshreshtha
45dd635486 treemanifest: prevent complete tree fetch after HTTP on-demand fetch
Summary:
The `getdesignatednodes` function returns a boolean indicating whether the requested nodes were actually fetched.

In the case of SSH, this is needed because the server may not support the `designatednodes` capability (only supported by Mononoke). If the fetch fails, Mercurial will fall back to an expensive complete tree fetch.

The HTTP version of this function accidentally omitted `return True`, which meant it implicitly returned `None`, which triggered the fallback path.

Reviewed By: sfilipco

Differential Revision: D25074067

fbshipit-source-id: 089d5382dd566db89ee732cdcb82762c8d43e21a
2020-11-18 17:44:12 -08:00
Chad Austin
ac8d6441f9 convert a path to valid glob syntax when prefetching
Summary:
Paths are not necessarily legal glob syntax. In particular, backslash
is used for escaping. This caused problems on Windows, where we tried
to pass a backslash-delimited path into `eden prefetch --no-prefetch`.

Reviewed By: xavierd

Differential Revision: D25072784

fbshipit-source-id: 9ce8e5ccc8f28581512c39d04922889da0bc1bf6
2020-11-18 17:32:30 -08:00
svcscm
dc6b1a368e Updating submodules
Summary:
GitHub commits:

87546af00a
9b8bfed135
d5c5d7ba2c
aa14e3b587

Reviewed By: wittgenst

fbshipit-source-id: e61491d5ba99cce42b6a6013e604524001c487ff
2020-11-18 14:53:37 -08:00
Xavier Deguillard
78fc38e27b store test: do not compile LocalStoreTest on Windows
Summary: The test doesn't compile on Windows, let's just ifdef it.

Reviewed By: genevievehelsel

Differential Revision: D25033804

fbshipit-source-id: 4f312f010f9d0db42cc9ae19df3f668e8e1c4665
2020-11-18 14:39:17 -08:00
Xavier Deguillard
9eca0f83a7 config test: use AbsolutePath instead of folly::fs::path
Summary:
Converting back and forth between folly::fs::path and AbsolutePath appears to
be problematic on Windows as NUL bytes appears in the paths, causing the tests
to fail. Instead of doing this conversion, let's simply use AbsolutePath everywhere.

Reviewed By: chadaustin

Differential Revision: D25033803

fbshipit-source-id: 6c45c2a20fc4bf18cecc838b219faacfeb8386d8
2020-11-18 14:39:17 -08:00
svcscm
c12c8bca0c Updating submodules
Summary:
GitHub commits:

13d95bcf71
d890812798
6bdd6b3f17
767bfd542f

Reviewed By: wittgenst

fbshipit-source-id: 9027bdea6ae41dea4e45b4eddda67ea1345e3003
2020-11-18 13:53:17 -08:00
David Tolnay
b682dd6315 Update to Rust 1.48.0
Summary: Release notes: https://github.com/rust-lang/rust/blob/stable/RELEASES.md#version-1480-2020-11-19

Reviewed By: jsgf

Differential Revision: D25011931

fbshipit-source-id: 04ad2c41d1589c7514b0550b20fd8ae0015dc118
2020-11-18 12:47:46 -08:00
svcscm
a9f0f23b19 Updating submodules
Summary:
GitHub commits:

09d9bdefc1

Reviewed By: wittgenst

fbshipit-source-id: d05eef251881022206c8d14265f5ec48f33150b7
2020-11-18 12:47:46 -08:00
svcscm
57a96dab73 Updating submodules
Summary:
GitHub commits:

26bac13db4
d0e807dd1d
741e53ffa8

Reviewed By: wittgenst

fbshipit-source-id: 40139642d605afadf4a070fe4191d33563f44afc
2020-11-18 10:33:40 -08:00
Thomas Orozco
31b9c58a0f mononoke_api: don't hit all bookmarks in all repos at the same time
Summary:
Querying bookmarks in all repos at the exact same time results in us making a
bunch of concurrent queries to MySQL, which in turn results in MyRouter
allocating a bunch of connections.

This is for reporting the age of bookmarks: that stuff can wait... It doesn't
need to be super fast. Let's make it run on repos one at a time to avoid
allocating dozens of connections every 10 seconds (which is more often than
MyRouter seems to close them).

Reviewed By: ikostia

Differential Revision: D25057432

fbshipit-source-id: 8b65ef65752fc9762a26d835ac80f61573003dd7
2020-11-18 09:48:51 -08:00
Johan Schuijt-Li
0cc4d4f100 introduce ability to talk to mononoke directly
Summary:
Skip the need to go through SSH/Mercurial servers. Directly connect to Mononoke
via TLS with X509 certificates.

Reviewed By: markbt

Differential Revision: D24756947

fbshipit-source-id: a782c894956d6a6be055eaa78287c040ceb57da7
2020-11-18 07:34:38 -08:00
Alex Hornby
7e6a398aa7 mononoke: add test for non-public hg changeset walk
Summary: Add a test case for walking hg data from non-public changeset

Reviewed By: ikostia

Differential Revision: D25023130

fbshipit-source-id: 34295f77926b32c77095f7c10d6daa8ef59d9550
2020-11-18 06:08:45 -08:00
Alex Hornby
3bcfce5803 mononoke: allow excluding filenodes from blobimport
Summary: Add command line option to exclude derived data types from blobimport so we can use it to create non-public commits without filenode data for tests

Differential Revision: D25023116

fbshipit-source-id: d8e5d6955f11cebec0de2075c22981bf6c6f4af3
2020-11-18 06:08:45 -08:00
Alex Hornby
88377d204f mononoke: add DeletedManifest to walker types
Summary: Add DeletedManifest to walker types with edges to linked changeset and its sub-manifests so that they can be scrubbed.

Differential Revision: D25000319

fbshipit-source-id: f146e6132fde0fb13e630d315484cc2c0a964bdc
2020-11-18 06:08:45 -08:00
svcscm
13169be0df Updating submodules
Summary:
GitHub commits:

0eeaf0512f

Reviewed By: wittgenst

fbshipit-source-id: dc26eb91a8bc3defde974f83ab00169ef8f1c3c7
2020-11-18 05:12:34 -08:00
Mark Juggurnauth-Thomas
99bab44a1a scs_server: reset scuba seq for each request
Reviewed By: farnz

Differential Revision: D25022577

fbshipit-source-id: 040dd3a76e4213f03145fe6d3ce73267da1f4d5f
2020-11-18 05:04:44 -08:00
Alex Hornby
bdcc5c2250 mononoke: add DeletedManifestMapping to walker
Summary: Add the mapping from bonsai to deleted manifest to the walker

Reviewed By: ikostia

Differential Revision: D24989424

fbshipit-source-id: 53d622f661629b9b3de91910f4560b641a95a7bf
2020-11-18 04:47:47 -08:00
Alex Hornby
5f5e222c3d mononoke: walker add selectable output format
Summary: Sometimes pretty debug format is too verbose and one per line regular debug format is preferrable.

Reviewed By: ikostia

Differential Revision: D24996432

fbshipit-source-id: 1acda3985658e4c17b57e36734c77b7579e7e28a
2020-11-18 04:47:47 -08:00
Alex Hornby
04c26ffd11 mononoke: add an output option to walker scrub
Summary: add an output option to walker scrub so we can dump out debug representation of any type the walker can walk

Reviewed By: farnz

Differential Revision: D24996433

fbshipit-source-id: a332d89d65e4d928159155a34bd39b0e2e1131de
2020-11-18 04:47:47 -08:00
generatedunixname89002005325676
c22e5de544 Daily arc lint --take CLANGFORMAT
Reviewed By: zertosh

Differential Revision: D25049451

fbshipit-source-id: 6b9d1b95dca0f2454e94918bb78e545e084e5d14
2020-11-18 04:32:26 -08:00
Mark Juggurnauth-Thomas
99c9c39128 mononoke_api: add stats to create changeset parts
Summary: Add gathering of statistics to the three main futures in create_changeset.

Reviewed By: StanislavGlebik

Differential Revision: D25022231

fbshipit-source-id: 26c7cd4a05483e694bdff24229e61a63249f98b5
2020-11-18 02:24:54 -08:00
Mark Juggurnauth-Thomas
dd85945e95 scs_server: add trait for logging thrift response information
Summary:
Add a trait that lets us log data from the response of a thrift request.

Use this to log the commit that was created by `repo_create_commit`.

Reviewed By: StanislavGlebik

Differential Revision: D25022232

fbshipit-source-id: c6526b29b1d2072bf7d4c46d80cb1a5bf522d227
2020-11-18 02:24:54 -08:00
Mark Juggurnauth-Thomas
e0857ba36f scs_server: add parameter logging for RepoCreateCommitParams
Summary:
We don't currently log any information about RepoCreateCommit parameters.

Start logging the parents, date, author and number of changes and deletes.

Reviewed By: farnz

Differential Revision: D25021423

fbshipit-source-id: 2723c208643e074861732a21e149c06ad47879f2
2020-11-18 02:24:54 -08:00
Mark Juggurnauth-Thomas
845167c91e bookmarks_movement: check for case conflicts when landing commits
Summary:
Move the check for commits not having case conflicts from upload time to when
the commit is being landed to a public bookmark.

This allows draft commits in commit cloud to contain erroneously-introduced
case conflicts, whilst still protecting public commits from these case conflicts.

Note that the checks we are moving are the checks for whether this commit
contains case conflicts internally (two files added by this commit conflict in
case), or against the content of ancestor commits (the commit adds a file which
conflicts with an existing file). The check for whether this commit and the
commits it is being pushrebased over conflict still happens during pushrebase.

This behaviour is controlled by a pair of tunable flags:
  * `check_case_conflicts_on_bookmark_movement` enables the new check at land time
  * `skip_case_conflict_check_on_changeset_upload` disables the old check at upload-time

The `check_case_conflicts_on_bookmark_movement` should always be set if the
`skip_case_conflict_check_on_changeset_upload` is set, otherwise users will
be able to land case conflicts.  Setting `check_case_conflicts_on_bookmark_movement`
without setting `skip_case_conflict_check_on_changeset_upload` allows both
checks to be enabled if that is necessary.

To handle bookmark-only moves, the `run_hooks_on_additional_changesets` tunable
flag must also be enabled.

Reviewed By: ahornby

Differential Revision: D24990174

fbshipit-source-id: 34e40e389f2c2139ba24ecee75473c362f365864
2020-11-18 02:10:55 -08:00
Mark Juggurnauth-Thomas
ccfb13ae0c tests: enable skeleton manifests
Summary: Enable skeleton manifest derivation in tests.

Reviewed By: farnz

Differential Revision: D25019342

fbshipit-source-id: a558abafa5a1f0b210c43638d94364b8603ebf4c
2020-11-18 02:10:55 -08:00
Mark Juggurnauth-Thomas
eddc285862 skeleton_manifest: add first_case_conflict method
Summary:
Add a method to `SkeletonManifest` which finds the paths to the first case
conflict, if there is one.

First means lexicographically first within directories, and with the shortest path.

Reviewed By: ahornby, StanislavGlebik

Differential Revision: D24990175

fbshipit-source-id: ec10f66582b81c40740823e32362ca489a6ebb4d
2020-11-18 02:10:55 -08:00
Mark Juggurnauth-Thomas
aea605a82d bookmarks_movement: cache loaded additional changesets
Summary:
Refactor loading of additional changesets so that it is cached.  This will
allow us to access them multiple times but only load them once.

Differential Revision: D24990176

fbshipit-source-id: c21cd1a811ede8fe2c2b03444de0f071ecf5a38c
2020-11-18 02:10:55 -08:00
svcscm
50c4200f7f Updating submodules
Summary:
GitHub commits:

af7efc246c

Reviewed By: wittgenst

fbshipit-source-id: cac8507df5e5bd8a250a5e253f3e9db7cc3aaa5c
2020-11-18 02:10:55 -08:00