This doc summarize the most common review comments in tp-libvirt open source project.
On one hand it may serve as a check list for reviewers but also for coders to make sure their PR meets expected quality level before submission.
- Provide one place to accumulate knowledge.
- Provide help to coders in expected coding or style format for tp-libvirt.
- Provide a reference for reviewers.
More common issues during reviewing can be categorized as below.
- cfg file
- trailing whitespaces
- indent alignment
- variable reusable
- variable name (upper or lower case letter)
- module import order (better similar module stay together)
- spelling errors
- py file:
- imported module one blank line
- missing doc comments
- doc comments need one empty line between comment and parameter
- doc comments start with #<space>'
- comments include multiple lines, need care ','
- indent issue
- trailing whitespace
- unused variable
- remove comment code (#...)
- comment upper and lower letter issues
- logging.debug("Find snapshots: %s", snap_names)
- spelling errors
- escape sequences, should prepend regex patterns with 'r'
- variable name issue:
- name should be meaningful
- variable declaration:
- should be defined on the very top (avoids local redefinition and undefined names during tear down in case of error)
- deprecated method:
- test.skip (remove raise)
- autotest.client import utils
- result assert
- libvirt_vm.check_exit_status
- comments
- if a test is added or modified and there's a comment - usually for the 'run' function - then we should make sure the comment still is valid
- resource cleanup
- vm_connection_session close(exception gracefully close)
- vm_backup.sync() called before any change
- variable not definition
- extreme situation: variable not definition such as conditional
- parameters in method is not usable
- Use autoflake to remove unused parameters
- list index out of range
- make sure that your list index
- duplicate code avoidance
- when code was called twice, better package them into one function
- depending on how specific the function is to a test case, it should live
- as top-level function in the test script, if it's not needed in other test scripts
- as a helper function in modules below tp-libvirt/provider, if it's a function that needs to be used in several test scripts in tp-libvirt; the module structure should be similar to the structure of the test cases or similar to how avocado-vt organizes its modules
- in avocado-vt, if it's a function that's generally useful for various tests and test providers
- these functions can be moved in time, e.g. from test script, to provider module, to avocado-vt
- when defining a function, raising avocado exceptions directly instead of passing the test instance from the the run method, can make it easier to move the function later to other places
- exception handling
- miss do assert in throwing exception
- libvirt version switches
- instead of hardcoding libvirt version switches in the test scripts, it's preferable to add the version that's minimally supported in the test configuration file, e.g. called func_supported_since_libvirt_ver = (7, 0, 0) in the cfg and use in the script as libvirt_version.is_libvirt_feature_supported(params).
complexity handling
- focus on the problem to be solved now, not speculated one that might need to be solved in the future; the future problem should be solved once it arrives and you can see its actual shape and requirements in the physical universe
copyright and license template when submitting new python file
For newly submitted PR, if there is new python file created from this PR, please add below information at the beginning of python file: # # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # # Copyright xx(company name) # # SPDX-License-Identifier: GPL-2.0
# Author: xx<xx@xx.com> (name + email addres) # # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
conjunction two folders:use os.path.join(xx,xx)
avoid too generic logging message
not recommended to use mutable default value as an argument see <https://docs.quantifiedcode.com/python-anti-patterns/correctness/mutable_default_value_as_argument.html>
without timeout value in infinite loop
use
with
to open fileseither use global constants for timeouts or test
params
to set values for timeouts (e.g.wait_for_loging(..., timeout=LOGIN_TIMEOUT)
); this way it is easier for others to tweak timeouts on slower systemswait don't sleep: try to avoid using time.sleep(...); instead try waiting for a condition to hold (utils_misc.wait_for) - this speeds up testing and enables us to use larger timeout values without necessarily increasing test duration
make sure this is run before sending patch:
inspekt checkall --disable-style E501,E265,W601,E402,E722,E741 --no-license-check <test-script-name>.py