如何将多个VUnit run.py文件合并到一个VUnit运行中?

时间:2017-03-23 15:12:11

标签: python vhdl vunit

我有一个像这样的目录和文件结构:

vunit_multi/
    alfa/
        run.py
        ...
    bravo/
        run.py
        ...

VUnit run.py可以单独运行。

有没有很好的方法将这些多个单独的VUnit运行组合成一个带有组合状态报告的单个运行?

1 个答案:

答案 0 :(得分:5)

让我们说你的alfa和bravo运行脚本看起来像这样

from os.path import join, dirname
from vunit import VUnit

prj = VUnit.from_argv()

root = dirname(__file__)
lib = prj.add_library("alfa_lib")
lib.add_source_files(join(root, "*.vhd"))

prj.main()

现在将脚本安排到此

from os.path import join, dirname
from vunit import VUnit

def create_test_suite(prj):
    root = dirname(__file__)
    lib = prj.add_library("alfa_lib")
    lib.add_source_files(join(root, "*.vhd"))

if __name__ == '__main__':
    prj = VUnit.from_argv()
    create_test_suite(prj)
    prj.main()

底部的if语句表示如果文件作为脚本调用,则执行最后三行(因此您仍然可以使用它来测试alfa),但如果文件作为模块导入另一个脚本则不会。

现在将这样的新运行脚本放在顶级目录(vunit_multi

from os.path import join, dirname
from vunit import VUnit
from glob import glob
import imp

def create_test_suites(prj):
    root = dirname(__file__)
    run_scripts = glob(join(root, "*", "run.py"))

    for run_script in run_scripts:
        file_handle, path_name, description = imp.find_module("run", [dirname(run_script)])
        run = imp.load_module("run", file_handle, path_name, description)
        run.create_test_suite(prj)
        file_handle.close()

prj = VUnit.from_argv()
create_test_suites(prj)
prj.main()

create_test_suites将找到所有运行脚本,然后迭代这些脚本。每个脚本文件都将作为模块导入,以访问create_test_suite函数。使用此顶级脚本中创建的prj调用该函数,以添加为模块指定的库和文件。

现在,如果您运行顶级脚本,它将看到所有模块测试平台。

注意:您可以使用比imp更新的模块,但imp也适用于较旧的Python版本。