在进行MicroPython移植的过程中,需要对目标开发板进行全面的测试,MicroPython中的测试位于 tests/ 路径下。下面列出了关键目录和run-tests.py
运行脚本:
.├── basics├── extmod├── float├── micropython├── run-tests.py...
有一些子文件夹用于对测试进行分类。在现有文件夹或新文件夹中创建新文件,即可添加测试。也可以在测试文件夹之外创建自定义测试,建议用于自定义移植。
例如,在 tests/unix/
子目录下的 print.py
文件中添加以下代码:
def print_one():print(1)print_one()
如果运行测试,该测试应出现在测试输出中:
$ cd ports/unix
$ make tests
skip unix/extra_coverage.py
pass unix/ffi_callback.py
pass unix/ffi_float.py
pass unix/ffi_float2.py
pass unix/print.py
pass unix/time.py
pass unix/time2.py
测试是通过比较测试目标的输出和CPython的输出来运行的。因此,任何测试都应使用打印语句来显示测试结果。
对于无法与CPython进行比较的测试(即MicroPython特有的功能),则可以提供一个.py.exp
文件,该文件将被用作比较的真值。
另一种运行测试的方法是:
$ cd tests
$ ./run-tests.py
然后在开发板运行:
$ ./run-tests.py --target minimal --device /dev/ttyACM0
运行特定的测试集(如一个目录):
$ ./run-tests.py -d basics
$ ./run-tests.py float/builtin*.py
总而言之,测试可以根据硬件情况和实际需要来进行定义。