-
Notifications
You must be signed in to change notification settings - Fork 180
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This commit has changes to add sysbench as tool to lisa This is needed for CPU/Memory/Fileio perf test using sysbench tool. Signed-off-by: Smit Gardhariya <[email protected]>
- Loading branch information
1 parent
6d7de37
commit a492d80
Showing
2 changed files
with
219 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,217 @@ | ||
# Copyright (c) Microsoft Corporation. | ||
# Licensed under the MIT license. | ||
|
||
from typing import List, cast | ||
|
||
from lisa.executable import Tool | ||
from lisa.operating_system import Posix | ||
from lisa.util import LisaException | ||
from lisa.util.process import ExecutableResult | ||
|
||
|
||
class Sysbench(Tool): | ||
@property | ||
def command(self) -> str: | ||
return "sysbench" | ||
|
||
@property | ||
def can_install(self) -> bool: | ||
return True | ||
|
||
def install(self) -> bool: | ||
posix_os: Posix = cast(Posix, self.node.os) | ||
posix_os.install_packages("sysbench") | ||
|
||
return self._check_exists() | ||
|
||
def __run_sysbench_test( | ||
self, | ||
test_type: str, | ||
threads: int, | ||
events: int, | ||
verbosity: int, | ||
time_limit: int, | ||
percentile: int, | ||
debug: str, | ||
histogram: str, | ||
validation: str, | ||
extra_args: str = "", | ||
) -> ExecutableResult: | ||
args = ( | ||
f"{test_type} run --threads={threads} --events={events}" | ||
f" --validate={validation} --percentile={percentile}" | ||
f" --verbosity={verbosity} --histogram={histogram}" | ||
f" --time={time_limit} --debug={debug} {extra_args}" | ||
) | ||
|
||
result: ExecutableResult = self.run( | ||
f"{args}", | ||
) | ||
return result | ||
|
||
def run_cpu_perf( | ||
self, | ||
threads: int = 1, | ||
events: int = 0, | ||
cpu_max_prime: int = 10000, | ||
verbosity: int = 5, | ||
time_limit: int = 10, | ||
percentile: int = 95, | ||
debug: str = "on", | ||
histogram: str = "on", | ||
validation: str = "on", | ||
) -> ExecutableResult: | ||
extra_args: str = f" --cpu-max-prime={cpu_max_prime}" | ||
return self.__run_sysbench_test( | ||
test_type="cpu", | ||
threads=threads, | ||
events=events, | ||
verbosity=verbosity, | ||
time_limit=time_limit, | ||
percentile=percentile, | ||
debug=debug, | ||
histogram=histogram, | ||
validation=validation, | ||
extra_args=extra_args, | ||
) | ||
|
||
def run_fileio_perf( | ||
self, | ||
test_mode: str, | ||
threads: int = 1, | ||
events: int = 0, | ||
verbosity: int = 5, | ||
time_limit: int = 10, | ||
percentile: int = 95, | ||
debug: str = "on", | ||
histogram: str = "on", | ||
validation: str = "off", | ||
file_io_mode: str = "sync", | ||
file_fsync_all: str = "off", | ||
file_fsync_end: str = "on", | ||
file_fsync_mode: str = "fsync", | ||
total_file: int = 128, | ||
block_size_in_kb: int = 16, | ||
file_total_size_in_gb: int = 2, | ||
file_async_backlog: int = 128, | ||
file_fsync_freq: int = 100, | ||
file_merged_requests: int = 0, | ||
file_rw_ratio: float = 1.5, | ||
) -> ExecutableResult: | ||
total_size = file_total_size_in_gb * 1024 * 1024 * 1024 | ||
block_size = block_size_in_kb * 1024 | ||
valid_io_mode: List[str] = ["sync", "async", "mmap"] | ||
valid_fsync_mode: List[str] = ["fsync", "fdatasync"] | ||
valid_test_mode: List[str] = [ | ||
"seqwr", | ||
"seqrewr", | ||
"seqrd", | ||
"rndrd", | ||
"rndwr", | ||
"rndrw", | ||
] | ||
|
||
if test_mode not in valid_test_mode: | ||
raise LisaException( | ||
f"Invalid test_mode. Valid test_mode: {valid_test_mode}" | ||
) | ||
elif file_io_mode not in valid_io_mode: | ||
raise LisaException( | ||
f"Invalid file_io_mode. Valid file_io_mode: {valid_io_mode}" | ||
) | ||
elif file_fsync_mode not in valid_fsync_mode: | ||
raise LisaException( | ||
f"Invalid file_fsync_mode. Valid file_fsync_mode: {valid_fsync_mode}" | ||
) | ||
|
||
extra_args: str = ( | ||
f" --file-test-mode={test_mode} --file-num={total_file}" | ||
f" --file-block-size={block_size} --file-total-size={total_size}" | ||
f" --file-io-mode={file_io_mode} --file-async-backlog={file_async_backlog}" | ||
f" --file-fsync-freq={file_fsync_freq} --file-fsync-all={file_fsync_all}" | ||
f" --file-fsync-end={file_fsync_end} --file-fsync-mode={file_fsync_mode}" | ||
f" --file-merged-requests={file_merged_requests}" | ||
f" --file-rw-ratio={file_rw_ratio}" | ||
) | ||
|
||
self.run( | ||
f"fileio prepare --file-total-size={total_size} --file-num={total_file}", | ||
force_run=True, | ||
) | ||
|
||
result = self.__run_sysbench_test( | ||
test_type="fileio", | ||
threads=threads, | ||
events=events, | ||
verbosity=verbosity, | ||
time_limit=time_limit, | ||
percentile=percentile, | ||
debug=debug, | ||
histogram=histogram, | ||
validation=validation, | ||
extra_args=extra_args, | ||
) | ||
|
||
self.run( | ||
f"fileio cleanup --file-total-size={total_size} --file-num={total_file}", | ||
force_run=True, | ||
) | ||
|
||
return result | ||
|
||
def run_memory_perf( | ||
self, | ||
threads: int = 1, | ||
events: int = 0, | ||
verbosity: int = 5, | ||
time_limit: int = 10, | ||
percentile: int = 95, | ||
debug: str = "on", | ||
histogram: str = "on", | ||
validation: str = "on", | ||
memory_block_size_in_kb: int = 1, | ||
memory_total_size_in_gb: int = 100, | ||
memory_scope: str = "global", | ||
memory_hugetlb: str = "off", | ||
memory_oper: str = "write", | ||
memory_access_mode: str = "seq", | ||
) -> ExecutableResult: | ||
block_size = memory_block_size_in_kb * 1024 | ||
total_mem_size = memory_total_size_in_gb * 1024 * 1024 * 1024 | ||
|
||
valid_mem_scope: List[str] = ["global", "local"] | ||
valid_mem_operation: List[str] = ["read", "write", "none"] | ||
valid_mem_access_mode: List[str] = ["seq", "rnd"] | ||
|
||
if memory_scope not in valid_mem_scope: | ||
raise LisaException( | ||
f"Invalid memory_scope. Valid memory_scope: {valid_mem_scope}" | ||
) | ||
elif memory_oper not in valid_mem_operation: | ||
raise LisaException( | ||
f"Invalid memory_oper. Valid memory_oper: {valid_mem_operation}" | ||
) | ||
elif memory_access_mode not in valid_mem_access_mode: | ||
raise LisaException( | ||
"Invalid memory_access_mode." | ||
f"Valid memory_access_mode: {valid_mem_access_mode}" | ||
) | ||
|
||
extra_args: str = ( | ||
f" --memory-block-size={block_size} --memory-total-size={total_mem_size}" | ||
f" --memory-scope={memory_scope} --memory-hugetlb={memory_hugetlb}" | ||
f" --memory-oper={memory_oper} --memory-access-mode={memory_access_mode}" | ||
) | ||
|
||
return self.__run_sysbench_test( | ||
test_type="memory", | ||
threads=threads, | ||
events=events, | ||
verbosity=verbosity, | ||
time_limit=time_limit, | ||
percentile=percentile, | ||
debug=debug, | ||
histogram=histogram, | ||
validation=validation, | ||
extra_args=extra_args, | ||
) |