def test_config_priority(tmp_path):
config = tmp_path / 'config1.conf'
+ # config: use pesign and give certdir + certname
config.write_text(textwrap.dedent(
f'''
[UKI]
Stub = some/path4
PCRBanks = sha512,sha1
SigningEngine = engine1
- SignTool = pesign
- SecureBootPrivateKey = some/path5
- SecureBootCertificate = some/path6
- SecureBootCertificateDir = some/path7
+ SecureBootSigningTool = pesign
+ SecureBootCertificateDir = some/path5
SecureBootCertificateName = some/name1
SignKernel = no
Phases = {':'.join(ukify.KNOWN_PHASES)}
'''))
+ # args: use sbsign and give key + cert, should override pesign
opts = ukify.parse_args(
['build',
'--linux=/ARG1',
'--pcr-public-key=PKEY2',
'--pcr-banks=SHA1,SHA256',
'--signing-engine=ENGINE',
- '--signtool=pesign',
+ '--signtool=sbsign',
'--secureboot-private-key=SBKEY',
'--secureboot-certificate=SBCERT',
- '--secureboot-certificate-dir=SBPATH',
- '--secureboot-certificate-name=SBNAME',
'--sign-kernel',
'--no-sign-kernel',
'--tools=TOOLZ///',
pathlib.Path('some/path8')]
assert opts.pcr_banks == ['SHA1', 'SHA256']
assert opts.signing_engine == 'ENGINE'
- assert opts.signtool == 'pesign'
- assert opts.sb_key == 'SBKEY'
- assert opts.sb_cert == 'SBCERT'
- assert opts.sb_certdir == 'SBPATH'
- assert opts.sb_cert_name == 'SBNAME'
+ assert opts.signtool == 'sbsign' # from args
+ assert opts.sb_key == 'SBKEY' # from args
+ assert opts.sb_cert == 'SBCERT' # from args
+ assert opts.sb_certdir == 'some/path5' # from config
+ assert opts.sb_cert_name == 'some/name1' # from config
assert opts.sign_kernel is False
assert opts.tools == [pathlib.Path('TOOLZ/')]
assert opts.output == pathlib.Path('OUTPUT')
if getattr(namespace, dest) is None:
setattr(namespace, dest, value)
+ @staticmethod
+ def config_set(
+ namespace: argparse.Namespace,
+ group: Optional[str],
+ dest: str,
+ value: Any,
+ ) -> None:
+ "Set namespace.<dest> to value only if it was None"
+
+ assert not group
+
+ setattr(namespace, dest, value)
+
@staticmethod
def config_set_group(
namespace: argparse.Namespace,
default = '/etc/pki/pesign',
help = 'required by --signtool=pesign. Path to nss certificate database directory for PE signing. Default is /etc/pki/pesign',
config_key = 'UKI/SecureBootCertificateDir',
+ config_push = ConfigItem.config_set
),
ConfigItem(
'--secureboot-certificate-name',
default = 365 * 10,
help = "period of validity (in days) for a certificate created by 'genkey'",
config_key = 'UKI/SecureBootCertificateValidity',
+ config_push = ConfigItem.config_set
),
ConfigItem(