ts_opts.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. #!/usr/bin/env python3
  2. #
  3. # mmgen = Multi-Mode GENerator, command-line Bitcoin cold storage solution
  4. # Copyright (C)2013-2022 The MMGen Project <mmgen@tuta.io>
  5. #
  6. # Project source code repository: https://github.com/mmgen/mmgen
  7. # Licensed according to the terms of GPL Version 3. See LICENSE for details.
  8. """
  9. ts_opts.py: options processing tests for the MMGen test.py test suite
  10. """
  11. from ..include.common import *
  12. from .ts_base import *
  13. class TestSuiteOpts(TestSuiteBase):
  14. 'options processing'
  15. networks = ('btc',)
  16. tmpdir_nums = [41]
  17. cmd_group = (
  18. ('opt_helpscreen', (41,"helpscreen output", [])),
  19. ('opt_noargs', (41,"invocation with no user options or arguments", [])),
  20. ('opt_good', (41,"good opts", [])),
  21. ('opt_bad_infile', (41,"bad infile parameter", [])),
  22. ('opt_bad_outdir', (41,"bad outdir parameter", [])),
  23. ('opt_bad_incompatible', (41,"incompatible opts", [])),
  24. ('opt_bad_autoset', (41,"invalid autoset value", [])),
  25. ('opt_show_diff', (41,"show_common_opts_diff()", [])),
  26. )
  27. def spawn_prog(self,args):
  28. return self.spawn('test/misc/opts.py',args,cmd_dir='.')
  29. def check_vals(self,args,vals):
  30. t = self.spawn_prog(args)
  31. for k,v in vals:
  32. t.expect(rf'{k}:\s+{v}',regex=True)
  33. return t
  34. def do_run(self,args,expect,exit_val,regex=False):
  35. t = self.spawn_prog(args)
  36. t.expect(expect,regex=regex)
  37. t.req_exit_val = exit_val
  38. return t
  39. def opt_helpscreen(self):
  40. return self.do_run(
  41. ['--help'],
  42. r'OPTS.PY: Opts test.*USAGE:\s+opts.py.*--minconf.*'
  43. + r'NOTES FOR THIS.*a note',
  44. 0,
  45. regex=True )
  46. def opt_noargs(self):
  47. return self.check_vals(
  48. [],
  49. (
  50. ('opt.foo', 'None'), # added opt
  51. ('opt.print_checksum', 'None'), # sets 'quiet'
  52. ('opt.quiet', 'False'), # init_opts, incompatible_opts
  53. ('opt.verbose', 'None'), # init_opts, incompatible_opts
  54. ('opt.fee_estimate_mode', 'conservative'), # autoset_opts
  55. ('opt.passwd_file', 'None'), # infile_opts - check_infile()
  56. ('opt.outdir', 'None'), # check_outdir()
  57. ('opt.cached_balances', 'None'), # opt_sets_global
  58. ('opt.minconf', '1'), # global_sets_opt
  59. ('g.cached_balances', 'None'),
  60. ('g.minconf', '1'),
  61. )
  62. )
  63. def opt_good(self):
  64. pf_base = 'testfile'
  65. pf = os.path.join(self.tmpdir,pf_base)
  66. self.write_to_tmpfile(pf_base,'')
  67. return self.check_vals(
  68. [
  69. '--print-checksum',
  70. '--fee-estimate-mode=E',
  71. '--passwd-file='+pf,
  72. '--outdir='+self.tmpdir,
  73. '--cached-balances',
  74. f'--hidden-incog-input-params={pf},123',
  75. ],
  76. (
  77. ('opt.print_checksum', 'True'),
  78. ('opt.quiet', 'True'), # set by print_checksum
  79. ('opt.fee_estimate_mode', 'economical'),
  80. ('opt.passwd_file', pf),
  81. ('opt.outdir', self.tmpdir),
  82. ('opt.cached_balances', 'True'),
  83. ('opt.hidden_incog_input_params', pf+',123'),
  84. ('g.cached_balances', 'True'),
  85. )
  86. )
  87. def opt_bad_infile(self):
  88. pf = os.path.join(self.tmpdir,'fubar')
  89. return self.do_run(['--passwd-file='+pf],'not found',1)
  90. def opt_bad_outdir(self):
  91. bo = self.tmpdir+'_fubar'
  92. return self.do_run(['--outdir='+bo],'not found',1)
  93. def opt_bad_incompatible(self):
  94. return self.do_run(['--label=Label','--keep-label'],'Conflicting options',1)
  95. def opt_bad_autoset(self):
  96. return self.do_run(['--fee-estimate-mode=Fubar'],'not unique substring',1)
  97. def opt_show_diff(self):
  98. return self.do_run(['show_common_opts_diff'],'common_opts_data',0)