Page MenuHomePhabricator

Add update-manpages to automated-commits
ClosedPublic

Authored by jasonbcox on Feb 25 2020, 23:40.

Details

Summary

This enables us to automatically update manpages immediately prior to cutting a release.

Depends on D5248

Test Plan
COMMIT_TYPE=update-manpages ./automated-commits.sh

Diff Detail

Repository
rABC Bitcoin ABC
Branch
automanpages
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 9574
Build 17052: Default Diff Build & Tests
Build 17051: arc lint + arc unit

Event Timeline

Fabien requested changes to this revision.Feb 26 2020, 15:20
Fabien added a subscriber: Fabien.
Fabien added inline comments.
contrib/source-control-tools/automated-commits.sh
109 ↗(On Diff #16516)

That seems unnecessary.

111 ↗(On Diff #16516)

Dito, already done by build_cmake.sh

128 ↗(On Diff #16516)

That would be a good idea to check against bitcoind -version.

133 ↗(On Diff #16516)

Use a wildcard here, something like *.1. At some point there will be bitcoin-wallet and maybe others, that would limit the amount of maintenance.

This revision now requires changes to proceed.Feb 26 2020, 15:20
contrib/source-control-tools/automated-commits.sh
109 ↗(On Diff #16516)

This is necessary to run ninja in the right place. But it looks like running ninja explicitly isn't needed (see other comment).

111 ↗(On Diff #16516)

build_cmake.sh runs ninja, not ninja all. I'm not sure if it's an illusion on my end, but I was certain at one time that ninja all was necessary to build all of the binaries. However I've double checked in a clean build dir and this doesn't seem to be the case.

128 ↗(On Diff #16516)

This is a good idea.

133 ↗(On Diff #16516)

I thought about this, but was taking a very conservative stance on which files would be added for the other automated commits. I think it's safe-ish to use a wildcard here only because these files are documentation and very unlikely to break the build.

contrib/source-control-tools/automated-commits.sh
111 ↗(On Diff #16516)

Without any argument, ninja runs the default target which is all. Unless these defaults are changed (not sure how to do so), ninja and ninja all are the same.
We use ninja all where there is another target as an argument, like ninja all check to ensure that default targets are built in addition to the ones required by the check target (e.g. bitcoind is not needed to run check and won't be built).
Note that all doesn't mean that all the targets are built ! e.g. test_bitcoin is not part of the all target (but is a dependency for the check target).

contrib/source-control-tools/automated-commits.sh
111 ↗(On Diff #16516)

Got it. Thanks for clearing that up.

Fabien added inline comments.
contrib/source-control-tools/automated-commits.sh
133 ↗(On Diff #16516)

If you're really concerned about this, there is another solution: you can run ninja install to some tmp dir and use the installed man files as a filter. Not sure it's worth it.

This revision is now accepted and ready to land.Feb 27 2020, 07:12
This revision was automatically updated to reflect the committed changes.