
The available bandit tests change with time (e.g. the Related-Change). We shouldn't try to maintain the list. Related-Change: Ie668d49a56c0a6542d28128656cfd44f7c089ec4 Change-Id: I6eb106abbac28ffbb9a3f64e8aa60218cbe75682
112 lines
6.4 KiB
YAML
112 lines
6.4 KiB
YAML
|
|
### This config may optionally select a subset of tests to run or skip by
|
|
### filling out the 'tests' and 'skips' lists given below. If no tests are
|
|
### specified for inclusion then it is assumed all tests are desired. The skips
|
|
### set will remove specific tests from the include set. This can be controlled
|
|
### using the -t/-s CLI options. Note that the same test ID should not appear
|
|
### in both 'tests' and 'skips', this would be nonsensical and is detected by
|
|
### Bandit at runtime.
|
|
|
|
# See https://bandit.readthedocs.io/en/latest/blacklists/blacklist_calls.html
|
|
# for documentation of the available tests.
|
|
|
|
# (optional) list included test IDs here, eg '[B101, B406]':
|
|
tests:
|
|
|
|
# (optional) list skipped test IDs here, eg '[B101, B406]':
|
|
skips:
|
|
# We default to binding to all interfaces
|
|
- B104
|
|
# Yes, we sometimes catch just to quietly swallow an exception
|
|
- B110
|
|
# We use insecure randomness all over the place, because
|
|
# it's exceedingly rare that we need secure randomness
|
|
- B311
|
|
# We dynamically build SQL all over the place
|
|
- B608
|
|
# We often use subprocesses, and require a lot of trust in our use of them
|
|
- B404
|
|
- B603
|
|
- B607
|
|
# We parse xml
|
|
- B405
|
|
- B603
|
|
|
|
### (optional) plugin settings - some test plugins require configuration data
|
|
### that may be given here, per-plugin. All bandit test plugins have a built in
|
|
### set of sensible defaults and these will be used if no configuration is
|
|
### provided. It is not necessary to provide settings for every (or any) plugin
|
|
### if the defaults are acceptable.
|
|
|
|
#any_other_function_with_shell_equals_true:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#execute_with_run_as_root_equals_true:
|
|
# function_names: [ceilometer.utils.execute, cinder.utils.execute, neutron.agent.linux.utils.execute,
|
|
# nova.utils.execute, nova.utils.trycmd]
|
|
#hardcoded_tmp_directory:
|
|
# tmp_dirs: [/tmp, /var/tmp, /dev/shm]
|
|
#linux_commands_wildcard_injection:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#password_config_option_not_marked_secret:
|
|
# function_names: [oslo.config.cfg.StrOpt, oslo_config.cfg.StrOpt]
|
|
#ssl_with_bad_defaults:
|
|
# bad_protocol_versions: [PROTOCOL_SSLv2, SSLv2_METHOD, SSLv23_METHOD, PROTOCOL_SSLv3,
|
|
# PROTOCOL_TLSv1, SSLv3_METHOD, TLSv1_METHOD]
|
|
#ssl_with_bad_version:
|
|
# bad_protocol_versions: [PROTOCOL_SSLv2, SSLv2_METHOD, SSLv23_METHOD, PROTOCOL_SSLv3,
|
|
# PROTOCOL_TLSv1, SSLv3_METHOD, TLSv1_METHOD]
|
|
#start_process_with_a_shell:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#start_process_with_no_shell:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#start_process_with_partial_path:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#subprocess_popen_with_shell_equals_true:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#subprocess_without_shell_equals_true:
|
|
# no_shell: [os.execl, os.execle, os.execlp, os.execlpe, os.execv, os.execve, os.execvp,
|
|
# os.execvpe, os.spawnl, os.spawnle, os.spawnlp, os.spawnlpe, os.spawnv, os.spawnve,
|
|
# os.spawnvp, os.spawnvpe, os.startfile]
|
|
# shell: [os.system, os.popen, os.popen2, os.popen3, os.popen4, popen2.popen2, popen2.popen3,
|
|
# popen2.popen4, popen2.Popen3, popen2.Popen4, commands.getoutput, commands.getstatusoutput]
|
|
# subprocess: [subprocess.Popen, subprocess.call, subprocess.check_call, subprocess.check_output,
|
|
# utils.execute, utils.execute_with_timeout]
|
|
#try_except_continue: {check_typed_exception: false}
|
|
#try_except_pass: {check_typed_exception: false}
|