1
0
Fork 0
mirror of https://we.phorge.it/source/arcanist.git synced 2025-04-05 17:08:24 +02:00
phorge-arcanist/src/workflow
Paul Tarjan 97e050fce7 Use a named remote and branches for staging to help git-lfs
Summary:
I'm working on a fairly large monorepo using phabricator and we are
running into a `git-lfs` issue. Every single `arc diff` we have to wait
many seconds while all our lfs files are walked before the push goes through.

I chatted with the `git-lfs` folks in
https://github.com/git-lfs/git-lfs/issues/4076 and they suggested this workflow
change. I tested it on our repo and it does indeed seem to fix the issue. Three
things were change:

1. The remote url is named
2. Use branches instead of tags
3. Do a `git fetch`

(Also, hello after all this time! Hope you're all doing well over at phacility.)

Test Plan:
Before
```
$ arc diff
Linting...
 LINT OKAY  No lint problems.
Running unit tests...
 UNIT OKAY  No unit test failures.
 PUSH STAGING  Pushing changes to staging area...
Uploading LFS objects: 100% (8211/8211), 1.0 GB | 0 B/s, done.
Enumerating objects: 31, done.
Counting objects: 100% (31/31), done.
Delta compression using up to 12 threads
Compressing objects: 100% (21/21), done.
Writing objects: 100% (24/24), 1.77 KiB | 8.00 KiB/s, done.
Total 24 (delta 19), reused 0 (delta 0)
remote: Resolving deltas: 100% (19/19), completed with 6 local objects.
To github.com:robinhoodmarkets/web-staging.git
 * [new tag]             2581578b59b6341c1023377fd8741814e89fcd0c -> phabricator/base/427095
 * [new tag]             7d9be50fbca590f15742d8cc20edd4f082dfbb3b -> phabricator/diff/427095
Updated an existing Differential revision:
        Revision URI: https://phabricator.robinhood.com/D135442

Included changes:
  M       __shared/tools/arcanist-js/src/workflow/RHArcanistDiffWorkflow.php
```

After
```
$ arc diff
Linting...
 LINT OKAY  No lint problems.
Running unit tests...
 UNIT OKAY  No unit test failures.
 PUSH STAGING  Pushing changes to staging area...
Enumerating objects: 15, done.
Counting objects: 100% (15/15), done.
Delta compression using up to 12 threads
Compressing objects: 100% (7/7), done.
Writing objects: 100% (8/8), 638 bytes | 2.00 KiB/s, done.
Total 8 (delta 6), reused 0 (delta 0)
remote: Resolving deltas: 100% (6/6), completed with 6 local objects.
To github.com:robinhoodmarkets/web-staging.git
 * [new branch]          2581578b59b6341c1023377fd8741814e89fcd0c -> phabricator/base/427105
 * [new branch]          274cc3a25eb7856291c1d4c078b28b76af8a43b2 -> phabricator/diff/427105
Updated an existing Differential revision:
        Revision URI: https://phabricator.robinhood.com/D135442

Included changes:
  M       __shared/tools/arcanist-js/src/workflow/RHArcanistDiffWorkflow.php
```

(notice the lack of `Uploading LFS objects`)

Reviewers: epriestley, #blessed_reviewers

Reviewed By: epriestley, #blessed_reviewers

Subscribers: Korvin

Differential Revision: https://secure.phabricator.com/D21041
2020-03-20 11:57:26 -07:00
..
exception pht all the things 2015-05-13 21:00:53 +10:00
ArcanistAmendWorkflow.php pht all the things 2015-05-13 21:00:53 +10:00
ArcanistAnoidWorkflow.php Port "arc weld" and "arc anoid" to Toolsets workflows, plus minor fixes 2020-02-16 09:16:24 -08:00
ArcanistBackoutWorkflow.php Strip tips out of commit messages from arc backout 2016-04-02 07:26:02 -07:00
ArcanistBookmarkWorkflow.php Minor linter fixes 2015-05-15 07:09:30 +10:00
ArcanistBranchWorkflow.php Minor linter fixes 2015-05-15 07:09:30 +10:00
ArcanistCallConduitWorkflow.php Use phutil_json_decode instead of json_decode 2015-05-04 22:36:14 +10:00
ArcanistCloseRevisionWorkflow.php When "arc close-revision --finalize ..." skips closing a revision, print a message 2019-11-18 20:31:51 -08:00
ArcanistCloseWorkflow.php Fix two "implode()" order issues arising from wilds/experimental collapse 2020-02-23 08:34:30 -08:00
ArcanistCommitWorkflow.php Various translation improvements 2015-11-02 21:31:04 +11:00
ArcanistCoverWorkflow.php Various translation improvements 2015-11-02 21:31:04 +11:00
ArcanistDiffWorkflow.php Use a named remote and branches for staging to help git-lfs 2020-03-20 11:57:26 -07:00
ArcanistDownloadWorkflow.php Fix two minor issues with "arc download" 2017-04-28 07:45:25 -07:00
ArcanistExportWorkflow.php Remove call to "arcanist.projectinfo" from arc export 2015-05-25 18:31:09 +10:00
ArcanistFeatureWorkflow.php Merge the remainder of the "experimental" branch 2020-02-13 06:05:08 -08:00
ArcanistFlagWorkflow.php Linter fixes 2015-12-07 21:35:34 +11:00
ArcanistGetConfigWorkflow.php pht all the things 2015-05-13 21:00:53 +10:00
ArcanistInstallCertificateWorkflow.php Added a warning prompt if the user tries to use an API cert instead of a CLI cert 2016-08-25 11:34:34 -04:00
ArcanistLandWorkflow.php Update "arc help land" to reference Perforce support 2019-10-28 11:25:32 -07:00
ArcanistLiberateWorkflow.php Port "arc weld" and "arc anoid" to Toolsets workflows, plus minor fixes 2020-02-16 09:16:24 -08:00
ArcanistLintersWorkflow.php Fix missing whitespace in arc linters --help message 2017-08-04 13:12:59 -07:00
ArcanistLintWorkflow.php Merge Arcanist lint changes from "experimental" branch 2020-02-13 06:04:47 -08:00
ArcanistListWorkflow.php Improve arc's handling of dirty submodules in Git 2015-09-21 12:40:06 -07:00
ArcanistPasteWorkflow.php pht all the things 2015-05-13 21:00:53 +10:00
ArcanistPatchWorkflow.php Update "arcanist/" for "topological" API changes 2019-06-20 16:05:21 -07:00
ArcanistPhrequentWorkflow.php Improve arc's handling of dirty submodules in Git 2015-09-21 12:40:06 -07:00
ArcanistRevertWorkflow.php pht all the things 2015-05-13 21:00:53 +10:00
ArcanistSetConfigWorkflow.php Add back pht()s and tsprintf()s to arg set-config 2017-02-16 11:08:45 +00:00
ArcanistStartWorkflow.php Fix errors found by PHPStan 2017-02-16 13:54:43 +00:00
ArcanistStopWorkflow.php Fix errors found by PHPStan 2017-02-16 13:54:43 +00:00
ArcanistTasksWorkflow.php Fix errors found by PHPStan 2017-02-16 13:54:43 +00:00
ArcanistTimeWorkflow.php Minor tidying of ArcanistPhrequentWorkflow classes 2015-02-01 21:49:53 +11:00
ArcanistTodoWorkflow.php pht all the things 2015-05-13 21:00:53 +10:00
ArcanistUnitWorkflow.php Clarify what "--everything" means in "arc lint" and "arc unit" 2018-02-05 12:26:41 -08:00
ArcanistUpgradeWorkflow.php Port "arc upgrade" to Toolsets 2020-02-17 11:33:17 -08:00
ArcanistUploadWorkflow.php Update "arc upload" for Toolsets 2020-02-26 08:22:18 -08:00
ArcanistWeldWorkflow.php Require "--" as an argument terminator when running noninteractively 2020-02-16 09:16:51 -08:00
ArcanistWhichWorkflow.php Make callsigns optional in arcanist 2016-03-15 03:58:46 +00:00
ArcanistWorkflow.php Port "arc upgrade" to Toolsets 2020-02-17 11:33:17 -08:00