mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	Add missing colon in :doc: link.
Fixes: fc3283314539 ("doc: Explain briefly how to write new tests")
Signed-off-by: Alexander Dahl <ada@thorsis.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
		
	
			
		
			
				
	
	
		
			133 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0+
 | |
| 
 | |
| Introduction to testing
 | |
| =======================
 | |
| 
 | |
| U-Boot has a large amount of code. This file describes how this code is
 | |
| tested and what tests you should write when adding a new feature.
 | |
| 
 | |
| 
 | |
| Running tests
 | |
| -------------
 | |
| 
 | |
| To run most tests on sandbox, type this::
 | |
| 
 | |
|     make check
 | |
| 
 | |
| in the U-Boot directory. Note that only the pytest suite is run using this
 | |
| command.
 | |
| 
 | |
| Some tests take ages to run and are marked with @pytest.mark.slow. To run just
 | |
| the quick ones, type this::
 | |
| 
 | |
|     make qcheck
 | |
| 
 | |
| It is also possible to run just the tests for tools (patman, binman, etc.).
 | |
| Such tests are included with those tools, i.e. no actual U-Boot unit tests are
 | |
| run. Type this::
 | |
| 
 | |
|     make tcheck
 | |
| 
 | |
| You can also run a selection tests in parallel with::
 | |
| 
 | |
|     make pcheck
 | |
| 
 | |
| All of the above use the test/run script with a paremeter to select which tests
 | |
| are run. See :doc:`py_testing` for more information.
 | |
| 
 | |
| 
 | |
| Sandbox
 | |
| -------
 | |
| U-Boot can be built as a user-space application (e.g. for Linux). This
 | |
| allows test to be executed without needing target hardware. The 'sandbox'
 | |
| target provides this feature and it is widely used in tests.
 | |
| 
 | |
| See :doc:`tests_sandbox` for more information.
 | |
| 
 | |
| Pytest Suite
 | |
| ------------
 | |
| 
 | |
| Many tests are available using the pytest suite, in test/py. This can run
 | |
| either on sandbox or on real hardware. It relies on the U-Boot console to
 | |
| inject test commands and check the result. It is slower to run than C code,
 | |
| but provides the ability to unify lots of tests and summarise their results.
 | |
| 
 | |
| You can run the tests on sandbox with::
 | |
| 
 | |
|    ./test/py/test.py --bd sandbox --build
 | |
| 
 | |
| This will produce HTML output in build-sandbox/test-log.html
 | |
| 
 | |
| Some tests run with other versions of sandbox. For example sandbox_flattree
 | |
| runs the tests with livetree (the hierachical devicetree) disabled. You can
 | |
| also select particular tests with -k::
 | |
| 
 | |
|    ./test/py/test.py --bd sandbox_flattree --build -k hello
 | |
| 
 | |
| There are some special tests that run in SPL. For this you need the sandbox_spl
 | |
| build::
 | |
| 
 | |
|    ./test/py/test.py --bd sandbox_spl --build -k test_spl
 | |
| 
 | |
| See :doc:`py_testing` for more information about the pytest suite.
 | |
| 
 | |
| See :doc:`tests_sandbox` for how to run tests directly (not through pytest).
 | |
| 
 | |
| 
 | |
| tbot
 | |
| ----
 | |
| 
 | |
| Tbot provides a way to execute tests on target hardware. It is intended for
 | |
| trying out both U-Boot and Linux (and potentially other software) on a
 | |
| number of boards automatically. It can be used to create a continuous test
 | |
| environment. See http://www.tbot.tools for more information.
 | |
| 
 | |
| 
 | |
| Ad-hoc tests
 | |
| ------------
 | |
| 
 | |
| There are several ad-hoc tests which run outside the pytest environment:
 | |
| 
 | |
| test/fs
 | |
|    File system test (shell script)
 | |
| test/image
 | |
|    FIT and legacy image tests (shell script and Python)
 | |
| test/stdint
 | |
|    A test that stdint.h can be used in U-Boot (shell script)
 | |
| trace
 | |
|    Test for the tracing feature (shell script)
 | |
| 
 | |
| TODO: Move these into pytest.
 | |
| 
 | |
| 
 | |
| When to write tests
 | |
| -------------------
 | |
| 
 | |
| If you add code to U-Boot without a test you are taking a risk. Even if you
 | |
| perform thorough manual testing at the time of submission, it may break when
 | |
| future changes are made to U-Boot. It may even break when applied to mainline,
 | |
| if other changes interact with it. A good mindset is that untested code
 | |
| probably doesn't work and should be deleted.
 | |
| 
 | |
| You can assume that the Pytest suite will be run before patches are accepted
 | |
| to mainline, so this provides protection against future breakage.
 | |
| 
 | |
| On the other hand there is quite a bit of code that is not covered with tests,
 | |
| or is covered sparingly. So here are some suggestions:
 | |
| 
 | |
| - If you are adding a new uclass, add a sandbox driver and a test that uses it
 | |
| - If you are modifying code covered by an existing test, add a new test case
 | |
|   to cover your changes
 | |
| - If the code you are modifying has not tests, consider writing one. Even a
 | |
|   very basic test is useful, and may be picked up and enhanced by others. It
 | |
|   is much easier to add onto a test - writing a new large test can seem
 | |
|   daunting to most contributors.
 | |
| 
 | |
| See :doc:`tests_writing` for how to write tests.
 | |
| 
 | |
| 
 | |
| Future work
 | |
| -----------
 | |
| 
 | |
| Converting existing shell scripts into pytest tests.
 |