mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-04 16:38:24 +02:00
Update Owners docs a bit
Summary: Fixes T9218. Fixes T8320. Fixes T8661. This isn't exhaustive but documents the stuff that cropped up in this iteration as needing documentation. In particular: - Be explicit about multiple ownership. - Explain value of having one place to update your giant regexp of a trillion paths. Test Plan: Read documentation. Reviewers: chad Reviewed By: chad Maniphest Tasks: T8320, T8661, T9218 Differential Revision: https://secure.phabricator.com/D14023
This commit is contained in:
parent
fe66d52a22
commit
ce7c2097b2
2 changed files with 61 additions and 21 deletions
|
@ -26,7 +26,7 @@ final class PhabricatorOwnersApplication extends PhabricatorApplication {
|
||||||
return array(
|
return array(
|
||||||
array(
|
array(
|
||||||
'name' => pht('Owners User Guide'),
|
'name' => pht('Owners User Guide'),
|
||||||
'href' => PhabricatorEnv::getDoclink('Owners Tool User Guide'),
|
'href' => PhabricatorEnv::getDoclink('Owners User Guide'),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,30 +1,70 @@
|
||||||
@title Owners Tool User Guide
|
@title Owners User Guide
|
||||||
@group userguide
|
@group userguide
|
||||||
|
|
||||||
Use Owners to define and/or monitor code you care about.
|
Group files in a codebase into packages and define ownership.
|
||||||
|
|
||||||
= Packages =
|
Overview
|
||||||
|
========
|
||||||
|
|
||||||
Owners tool allows you to define a code package by specifying a group of paths.
|
The Owners application allows you to group files in a codebase (or across
|
||||||
The package can then be used to monitor the paths. For example, it can be used
|
codebases) into packages. This can make it easier to reference a module or
|
||||||
in Herald rules and in the "Related Commits" feature (see below).
|
subsystem in other applications, like Herald.
|
||||||
|
|
||||||
= Related Commits =
|
|
||||||
|
|
||||||
Once the package is defined, all future commits touching any path defined in
|
Creating a Package
|
||||||
the package will be recorded as "Related Commits" of the package.
|
==================
|
||||||
|
|
||||||
= Commits Needing Attention =
|
To create a package, choose a name and add some files which belong to the
|
||||||
|
package. For example, you might define an "iOS Application" package by
|
||||||
|
including these paths:
|
||||||
|
|
||||||
Owners tool enables the owners of the package to monitor the commits that might
|
/conf/ios/
|
||||||
need attention. If "auditing" is enabled for a package, a related commit will
|
/src/ios/
|
||||||
be marked as "Needing Attention" if
|
/shared/assets/mobile/
|
||||||
|
|
||||||
- it's neither authored nor reviewed by an owner of the package,
|
Any files in those directories are considered to be part of the package, and
|
||||||
- no revision found for the commit,
|
you can now conveniently refer to them (for example, in a Herald rule) by
|
||||||
- the commit author is not recognized, or
|
refering to the package instead of copy/pasting a huge regular expression
|
||||||
- the author or the reviewer specified in the commits don't match the ones in
|
into a bunch of places.
|
||||||
the Differential revision
|
|
||||||
|
|
||||||
The owners of the package can accept or specify concern for such commits by
|
If new source files are later added, or the scope of the package otherwise
|
||||||
clicking the "Audit Status" link.
|
expands or contracts, you can edit the package definition to keep things
|
||||||
|
updated.
|
||||||
|
|
||||||
|
You can use "exclude" paths to ignore subdirectories which would otherwise
|
||||||
|
be considered part of the package. For example, you might exclude a path
|
||||||
|
like this:
|
||||||
|
|
||||||
|
/conf/ios/generated/
|
||||||
|
|
||||||
|
Perhaps that directory contains some generated configuration which frequently
|
||||||
|
changes, and which you aren't concerned about.
|
||||||
|
|
||||||
|
After creating a package, files the package contains will be identified as
|
||||||
|
belonging to the package when you look at them in Diffusion, or look at changes
|
||||||
|
which affect them in Diffusion or Differential.
|
||||||
|
|
||||||
|
|
||||||
|
Files in Multiple Packages
|
||||||
|
==========================
|
||||||
|
|
||||||
|
Multiple packages may own the same file. For example, both the
|
||||||
|
"Android Application" and the "iOS Application" packages might own a path
|
||||||
|
like this, containing resources used by both:
|
||||||
|
|
||||||
|
/shared/assets/mobile/
|
||||||
|
|
||||||
|
If both packages own this directory, files in the directory are considered to
|
||||||
|
be part of both packages.
|
||||||
|
|
||||||
|
Packages do not need to have claims of equal specificity to own files. For
|
||||||
|
example, if you have a "Design Assets" package which owns this path:
|
||||||
|
|
||||||
|
/shared/assets/
|
||||||
|
|
||||||
|
...it will //also// own all of the files in the `mobile/` subdirectory. In this
|
||||||
|
configuration, these files are part of three packages: "iOS Application",
|
||||||
|
"Android Application", and "Design Assets".
|
||||||
|
|
||||||
|
(You can use an "exclude" rule if you want to make a different package with a
|
||||||
|
more specific claim the owner of a file or subdirectory.)
|
||||||
|
|
Loading…
Add table
Reference in a new issue