This directory contains WooCommerce legacy code. Ideally, the code in this folder should only get the minimum required changes for bug fixing, and any new code should go in the src
directory instead.
Whenever you need to get an instance of a class from the src
directory, please don't instantiate it directly, but instead use the container. To get an instance of the container itself you can use the wc_get_container
function, for example:
$container = wc_get_container();
$service = $container->get( \Automattic\WooCommerce\TheNamespace\TheService::class );
$service->do_something();
The exception to this rule might be data-only classes that could be created the old way (using a plain new
statement); but in general, all classes in the src
directory are registered in the container and should be resolved using it.
Please take a look at the considerations for creation new hooks in src
code, as they apply for includes
code as well. The short version is that new hooks should be introduced only if they provide a valuable extension point for plugins, and not with the purpose of driving WooCommerce's internal logic.
As it's the case for the src
folder, writing unit tests is generally mandatory if you are a WooCommerce team member or a contributor from another Automattic team, and encouraged if you are an external contributor. Tests should cover any new code (although as mentioned, adding new code in includes
should be rare) and any modifications to existing code.
In order to make it easier to write unit tests, there are a couple of mechanisms in place that you can use:
-
The code hacker. Pros: you don't need to do any special changes to your code to make it testable. Cons: it's a hack, the tested code is being actually modified while being loaded by the PHP engine, so not an ideal solution.
-
The legacy proxy and the related helper methods in WC_Unit_Test_case: although these are intended in principle for writing tests for code in the
src
directory, they can be used forincludes
code as well. Pros: a clean approach, no hacks involved. Cons: you need to modify your code to use the proxy whenever you need to call a function or static method that makes the code difficult to test.
It's up to you as a contributor to decide which mechanism to use in each case. Choose wisely.