tests/run_test
can be run from the root folder to run individual test suites.
tests/run_all_tests [--parallel]
can be run from the root folder to run all test suites (Tested only on Linux)
Most new tests requiring no additional configuration should go in files
.
Tests of error-tolerant PHP AST parser (--use-fallback-parser
)
General tests.
- Note: If 70/71/72 is appended to a file, then the test case chooses that file instead for php 7.0/7.1/7.2 as a source file or expected file.
Contains tests of
- ast:
--simplify-ast
(Simplifying AST into an easier to analyze format) This tests the resulting AST. - fallback_test:
--use-fallback-parser
: Tests of error-tolerant PHP AST parser This tests the emitted issues. The parser has its own unit tests. - rewriting_test:
--simplify-ast
. This tests the resulting issues emitted by Phan on a simplified AST.
As well as these extension-specific tests that are skipped if the extension isn't loaded: (TODO: Can we use Phan's stubs to work around the need for this?)
- intl_files Test cases for issues Phan had analyzing the intl extension.
- soap_files Test cases for issues Phan had analyzing the SOAP extension. (Originally a different folder because SOAP was an optional extension.
Contain tests of expected behavior for multi-file project analysis. This also contains regression tests. Add a test here if the bug can only be reproduced with multiple files.
Contains unit tests and integration tests of Phan and its classes. Some of the other subfolders provide test cases to test classes in the Phan/ folder. (Many of the other tests are integration tests)
Integration tests of all of Phan's plugins' output.
Rasmus's original test cases for Phan. These get updated when Phan's behavior improves or intentionally changes.
There are integration tests of the language server(both with and without pcntl) in tests/Phan/LanguageServer/LanguageServerIntegrationTest.php
PHAN_RUN_INTEGRATION_TEST=1
must be set in your environment variables in order to run this test (Otherwise, these tests are skipped)