mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-10 08:52:39 +01:00
Very basic unit test documentation
Summary: This needs work but is better than nothing. Test Plan: Generated and read documentation, clicked links. Reviewed By: edward Reviewers: edward CC: aran, edward Differential Revision: 765
This commit is contained in:
parent
6ee6fcf36f
commit
054ac65a9d
1 changed files with 34 additions and 0 deletions
34
src/docs/developer/unit_tests.diviner
Normal file
34
src/docs/developer/unit_tests.diviner
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
@title Writing Unit Tests
|
||||||
|
@group developer
|
||||||
|
|
||||||
|
Simple guide to libphutil, Arcanist and Phabricator unit tests.
|
||||||
|
|
||||||
|
= Overview =
|
||||||
|
|
||||||
|
libphutil, Arcanist and Phabricator provide and use a simple unit test
|
||||||
|
framework. This document is aimed at project contributors and describes how to
|
||||||
|
use it to add and run tests in these projects or other libphutil libraries.
|
||||||
|
|
||||||
|
In the general case, you can integrate ##arc## with a custom unit test engine
|
||||||
|
(like PHPUnit or any other unit testing library) to run tests in other projects.
|
||||||
|
See @{article:Arcanist User Guide: Customizing Lint, Unit Tests and Workflows}
|
||||||
|
for information on customizing engines.
|
||||||
|
|
||||||
|
= Adding Tests =
|
||||||
|
|
||||||
|
To add new tests to a libphutil, Arcanist or Phabricator module:
|
||||||
|
|
||||||
|
- Create a ##__tests__/## directory in the module if it doesn't exist yet.
|
||||||
|
- Add classes to the ##__tests__/## directory which extend from
|
||||||
|
@{class:PhabricatorTestCase} (in Phabricator) or
|
||||||
|
@{class@arcanist:ArcanistPhutilTestCase} (elsewhere).
|
||||||
|
- Run ##arc liberate## on the library root so your classes are loadable.
|
||||||
|
|
||||||
|
= Running Tests =
|
||||||
|
|
||||||
|
Once you've added test classes, you can run them with:
|
||||||
|
|
||||||
|
- ##arc unit path/to/module/##, to explicitly run module tests.
|
||||||
|
- ##arc unit##, to run tests for all modules affected by changes in the
|
||||||
|
working copy.
|
||||||
|
- ##arc diff## will also run ##arc unit## for you.
|
Loading…
Reference in a new issue