MicroPython核心:编写测试

在进行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

总而言之,测试可以根据硬件情况和实际需要来进行定义。

你可能感兴趣的:(硬件,micropython,python,单片机,嵌入式硬件,物联网)