本文整理匯總了Python中chiptools.core.project.Project.run_tests方法的典型用法代碼示例。如果您正苦於以下問題:Python Project.run_tests方法的具體用法?Python Project.run_tests怎麽用?Python Project.run_tests使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類chiptools.core.project.Project
的用法示例。
在下文中一共展示了Project.run_tests方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: cmdloop
# 需要導入模塊: from chiptools.core.project import Project [as 別名]
# 或者: from chiptools.core.project.Project import run_tests [as 別名]
# to 'False', this tells the synthesis tool not to try to synthesise this file.
# If not specified, 'synthesise' will default to 'True'
project.add_file(
'tb_axi_lite_slave_example.v',
library='lib_tb_example',
synthesise=False
)
if __name__ == '__main__':
interactive = True # Set True to load the ChipTools CLI
if interactive:
# ChipTools provides a command line interface to allow you to perform
# actions on the project such as synthesis and simulation interactively.
# It can be launched by importing the CommandLine from chiptools.core.cli
# and executing the cmdloop() method - the project is passed to the
# CommandLine constructor. Launch the ChipTools command line with the
# project we just configured:
from chiptools.core.cli import CommandLine
CommandLine(project).cmdloop()
else:
# Run the automated unit tests on the project:
project.run_tests(tool_name='vivado')
# Synthesise the project:
project.synthesise(
library='lib_example',
entity='axi_lite_slave_example',
tool_name='vivado'
)
示例2: CommandLine
# 需要導入模塊: from chiptools.core.project import Project [as 別名]
# 或者: from chiptools.core.project.Project import run_tests [as 別名]
#.........這裏部分代碼省略.........
)
print(msg)
print(term.darkgray(textwrap.fill(
doc,
width=80,
initial_indent=SEP * 2,
subsequent_indent=SEP * 2,
)))
testUniqueId += 1
def show_test_selection(self):
"""
Show the currently selected tests in the current project.
Add or remove tests using the
add_tests and remove_tests commands respectively.
"""
ids_list = list(self.test_set)
tests = []
for file_object in self.project.get_tests():
file_name = os.path.basename(file_object.path)
print(term.yellow(file_name))
for test_group in file_object.testsuite:
for testId, test in enumerate(test_group):
if testId == 0:
groupName = str(test.__class__.__name__)
testName = test.id().split('.')[-1]
tests.append((file_name, groupName, testName, test))
# Filter out any invalid indices
ids_list = list(filter(lambda x: x < len(tests), ids_list))
for idx, (fileName, groupName, testName, test) in enumerate(
[tests[idx] for idx in ids_list]
):
print(
'{:<5}'.format(str(ids_list[idx]) + ':') +
'[' + term.yellow(fileName) + ']' +
'[' + term.green(groupName) + ']' +
'[' + term.blue(testName) + ']'
)
@wraps_do_commands
def do_add_tests(self, command):
"""
Add the given tests to the test suite. Tests should be supplied as
comma separated numbers or numeric ranges, for example:
add_tests 1-3, 5, 6, 7
Would add tests 1, 2, 3, 5, 6, 7 to the test suite.
You can check which tests are available by issuing the show_tests
command or remove tests that have been added to the suite by issuing
the remove_tests command.
"""
try:
ids = utils.parseRange(command)
except ValueError:
log.error('Invalid test range specified: ' + command)
return
for testId in ids:
self.test_set.add(testId)
self.show_test_selection()
@wraps_do_commands
def do_remove_tests(self, command):
"""
Remove the given tests from the test suite. Tests should be supplied
as comma separated numbers or numeric ranges, for example:
remove_tests 1-3, 5, 6, 7
Would remove tests 1, 2, 3, 5, 6, 7 from the test suite.
You can check which tests are available by issuing the show_tests
command or add tests by issuing the add_tests command.
"""
try:
ids = utils.parseRange(command)
except ValueError:
log.error('Invalid test range specified: ' + command)
return
for testId in ids:
try:
self.test_set.remove(testId)
except KeyError:
pass
self.show_test_selection()
@wraps_do_commands
def do_run_tests(self, command):
"""
Run the tests that were selected via the add_tests command and report
the results.
"""
if len(command) > 0:
tool_name = command
else:
tool_name = None
self.show_test_selection()
self.project.run_tests(self.test_set, tool_name=tool_name)
示例3: cmdloop
# 需要導入模塊: from chiptools.core.project import Project [as 別名]
# 或者: from chiptools.core.project.Project import run_tests [as 別名]
# to 'False', this tells the synthesis tool not to try to synthesise this file.
# If not specified, 'synthesise' will default to 'True'
project.add_file(
'tb_max_hold.vhd',
library='lib_tb_max_hold',
synthesise=False
)
if __name__ == '__main__':
interactive = False # Set True to load the ChipTools CLI
if interactive:
# ChipTools provides a command line interface to allow you to perform
# actions on the project such as synthesis and simulation interactively.
# It can be launched by importing the CommandLine from chiptools.core.cli
# and executing the cmdloop() method - the project is passed to the
# CommandLine constructor. Launch the ChipTools command line with the
# project we just configured:
from chiptools.core.cli import CommandLine
CommandLine(project).cmdloop()
else:
# Run the automated unit tests on the project:
project.run_tests(tool_name='ghdl')
# Synthesise the project:
project.synthesise(
library='lib_max_hold',
entity='max_hold',
tool_name='vivado'
)