# STDOUT: ---v---v---v---v---v--- Using /etc/ansible/ansible.cfg as config file PLAY [Issue simple self-signed certificate] ************************************ TASK [Gathering Facts] ********************************************************* Thursday 18 August 2022 22:39:56 +0000 (0:00:00.021) 0:00:00.021 ******* ok: [sut] TASK [linux-system-roles.certificate : Set version specific variables] ********* Thursday 18 August 2022 22:39:57 +0000 (0:00:01.101) 0:00:01.122 ******* included: /WORKDIR/dist-git-certificate-use_distro_python_cryptography-AzisEh/tests/roles/linux-system-roles.certificate/tasks/set_vars.yml for sut TASK [linux-system-roles.certificate : Ensure ansible_facts used by role] ****** Thursday 18 August 2022 22:39:57 +0000 (0:00:00.039) 0:00:01.161 ******* ok: [sut] TASK [linux-system-roles.certificate : Set platform/version specific variables] *** Thursday 18 August 2022 22:39:58 +0000 (0:00:00.452) 0:00:01.614 ******* skipping: [sut] => (item=RedHat.yml) => { "ansible_loop_var": "item", "changed": false, "item": "RedHat.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=Fedora.yml) => { "ansible_loop_var": "item", "changed": false, "item": "Fedora.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=Fedora_35.yml) => { "ansible_loop_var": "item", "changed": false, "item": "Fedora_35.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=Fedora_35.yml) => { "ansible_loop_var": "item", "changed": false, "item": "Fedora_35.yml", "skip_reason": "Conditional result was False" } TASK [linux-system-roles.certificate : Ensure certificate role dependencies are installed] *** Thursday 18 August 2022 22:39:58 +0000 (0:00:00.057) 0:00:01.671 ******* changed: [sut] => { "changed": true, "rc": 0, "results": [ "Installed: python3-pyasn1-0.4.8-7.fc35.noarch" ] } TASK [linux-system-roles.certificate : Ensure provider packages are installed] *** Thursday 18 August 2022 22:40:02 +0000 (0:00:04.369) 0:00:06.041 ******* changed: [sut] => (item=certmonger) => { "__certificate_provider": "certmonger", "ansible_loop_var": "__certificate_provider", "changed": true, "rc": 0, "results": [ "Installed: certmonger-0.79.15-2.fc35.x86_64", "Installed: dbus-tools-1:1.12.22-1.fc35.x86_64" ] } TASK [linux-system-roles.certificate : Ensure pre-scripts hooks directory exists] *** Thursday 18 August 2022 22:40:07 +0000 (0:00:04.569) 0:00:10.611 ******* changed: [sut] => (item=certmonger) => { "__certificate_provider": "certmonger", "ansible_loop_var": "__certificate_provider", "changed": true, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/etc/certmonger//pre-scripts", "secontext": "unconfined_u:object_r:etc_t:s0", "size": 4096, "state": "directory", "uid": 0 } TASK [linux-system-roles.certificate : Ensure post-scripts hooks directory exists] *** Thursday 18 August 2022 22:40:07 +0000 (0:00:00.460) 0:00:11.072 ******* changed: [sut] => (item=certmonger) => { "__certificate_provider": "certmonger", "ansible_loop_var": "__certificate_provider", "changed": true, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/etc/certmonger//post-scripts", "secontext": "unconfined_u:object_r:etc_t:s0", "size": 4096, "state": "directory", "uid": 0 } TASK [linux-system-roles.certificate : Ensure provider service is running] ***** Thursday 18 August 2022 22:40:07 +0000 (0:00:00.306) 0:00:11.379 ******* changed: [sut] => (item=certmonger) => { "__certificate_provider": "certmonger", "ansible_loop_var": "__certificate_provider", "changed": true, "enabled": true, "name": "certmonger", "state": "started", "status": { "ActiveEnterTimestamp": "n/a", "ActiveEnterTimestampMonotonic": "0", "ActiveExitTimestamp": "n/a", "ActiveExitTimestampMonotonic": "0", "ActiveState": "inactive", "After": "syslog.target sysinit.target dbus.socket network.target dbus-broker.service basic.target system.slice systemd-journald.socket", "AllowIsolate": "no", "AssertResult": "no", "AssertTimestamp": "n/a", "AssertTimestampMonotonic": "0", "Before": "shutdown.target", "BlockIOAccounting": "no", "BlockIOWeight": "[not set]", "BusName": "org.fedorahosted.certmonger", "CPUAccounting": "yes", "CPUAffinityFromNUMA": "no", "CPUQuotaPerSecUSec": "infinity", "CPUQuotaPeriodUSec": "infinity", "CPUSchedulingPolicy": "0", "CPUSchedulingPriority": "0", "CPUSchedulingResetOnFork": "no", "CPUShares": "[not set]", "CPUUsageNSec": "[not set]", "CPUWeight": "[not set]", "CacheDirectoryMode": "0755", "CanFreeze": "yes", "CanIsolate": "no", "CanReload": "no", "CanStart": "yes", "CanStop": "yes", "CapabilityBoundingSet": "cap_chown cap_dac_override cap_dac_read_search cap_fowner cap_fsetid cap_kill cap_setgid cap_setuid cap_setpcap cap_linux_immutable cap_net_bind_service cap_net_broadcast cap_net_admin cap_net_raw cap_ipc_lock cap_ipc_owner cap_sys_module cap_sys_rawio cap_sys_chroot cap_sys_ptrace cap_sys_pacct cap_sys_admin cap_sys_boot cap_sys_nice cap_sys_resource cap_sys_time cap_sys_tty_config cap_mknod cap_lease cap_audit_write cap_audit_control cap_setfcap cap_mac_override cap_mac_admin cap_syslog cap_wake_alarm cap_block_suspend cap_audit_read cap_perfmon cap_bpf cap_checkpoint_restore", "CleanResult": "success", "CollectMode": "inactive", "ConditionResult": "no", "ConditionTimestamp": "n/a", "ConditionTimestampMonotonic": "0", "ConfigurationDirectoryMode": "0755", "Conflicts": "shutdown.target", "ControlPID": "0", "CoredumpFilter": "0x33", "DefaultDependencies": "yes", "DefaultMemoryLow": "0", "DefaultMemoryMin": "0", "Delegate": "no", "Description": "Certificate monitoring and PKI enrollment", "DevicePolicy": "auto", "DynamicUser": "no", "EnvironmentFiles": "/etc/sysconfig/certmonger (ignore_errors=yes)", "ExecMainCode": "0", "ExecMainExitTimestamp": "n/a", "ExecMainExitTimestampMonotonic": "0", "ExecMainPID": "0", "ExecMainStartTimestamp": "n/a", "ExecMainStartTimestampMonotonic": "0", "ExecMainStatus": "0", "ExecStart": "{ path=/usr/sbin/certmonger ; argv[]=/usr/sbin/certmonger -S -p /run/certmonger.pid -n $OPTS ; ignore_errors=no ; start_time=[n/a] ; stop_time=[n/a] ; pid=0 ; code=(null) ; status=0/0 }", "ExecStartEx": "{ path=/usr/sbin/certmonger ; argv[]=/usr/sbin/certmonger -S -p /run/certmonger.pid -n $OPTS ; flags= ; start_time=[n/a] ; stop_time=[n/a] ; pid=0 ; code=(null) ; status=0/0 }", "FailureAction": "none", "FileDescriptorStoreMax": "0", "FinalKillSignal": "9", "FragmentPath": "/usr/lib/systemd/system/certmonger.service", "FreezerState": "running", "GID": "[not set]", "GuessMainPID": "yes", "IOAccounting": "no", "IOReadBytes": "18446744073709551615", "IOReadOperations": "18446744073709551615", "IOSchedulingClass": "2", "IOSchedulingPriority": "4", "IOWeight": "[not set]", "IOWriteBytes": "18446744073709551615", "IOWriteOperations": "18446744073709551615", "IPAccounting": "no", "IPEgressBytes": "[no data]", "IPEgressPackets": "[no data]", "IPIngressBytes": "[no data]", "IPIngressPackets": "[no data]", "Id": "certmonger.service", "IgnoreOnIsolate": "no", "IgnoreSIGPIPE": "yes", "InactiveEnterTimestamp": "n/a", "InactiveEnterTimestampMonotonic": "0", "InactiveExitTimestamp": "n/a", "InactiveExitTimestampMonotonic": "0", "JobRunningTimeoutUSec": "infinity", "JobTimeoutAction": "none", "JobTimeoutUSec": "infinity", "KeyringMode": "private", "KillMode": "control-group", "KillSignal": "15", "LimitAS": "infinity", "LimitASSoft": "infinity", "LimitCORE": "infinity", "LimitCORESoft": "infinity", "LimitCPU": "infinity", "LimitCPUSoft": "infinity", "LimitDATA": "infinity", "LimitDATASoft": "infinity", "LimitFSIZE": "infinity", "LimitFSIZESoft": "infinity", "LimitLOCKS": "infinity", "LimitLOCKSSoft": "infinity", "LimitMEMLOCK": "8388608", "LimitMEMLOCKSoft": "8388608", "LimitMSGQUEUE": "819200", "LimitMSGQUEUESoft": "819200", "LimitNICE": "0", "LimitNICESoft": "0", "LimitNOFILE": "524288", "LimitNOFILESoft": "1024", "LimitNPROC": "14799", "LimitNPROCSoft": "14799", "LimitRSS": "infinity", "LimitRSSSoft": "infinity", "LimitRTPRIO": "0", "LimitRTPRIOSoft": "0", "LimitRTTIME": "infinity", "LimitRTTIMESoft": "infinity", "LimitSIGPENDING": "14799", "LimitSIGPENDINGSoft": "14799", "LimitSTACK": "infinity", "LimitSTACKSoft": "8388608", "LoadState": "loaded", "LockPersonality": "no", "LogLevelMax": "-1", "LogRateLimitBurst": "0", "LogRateLimitIntervalUSec": "0", "LogsDirectoryMode": "0755", "MainPID": "0", "ManagedOOMMemoryPressure": "auto", "ManagedOOMMemoryPressureLimit": "0", "ManagedOOMPreference": "none", "ManagedOOMSwap": "auto", "MemoryAccounting": "yes", "MemoryAvailable": "infinity", "MemoryCurrent": "[not set]", "MemoryDenyWriteExecute": "no", "MemoryHigh": "infinity", "MemoryLimit": "infinity", "MemoryLow": "0", "MemoryMax": "infinity", "MemoryMin": "0", "MemorySwapMax": "infinity", "MountAPIVFS": "no", "NFileDescriptorStore": "0", "NRestarts": "0", "NUMAPolicy": "n/a", "Names": "certmonger.service", "NeedDaemonReload": "no", "Nice": "0", "NoNewPrivileges": "no", "NonBlocking": "no", "NotifyAccess": "none", "OOMPolicy": "stop", "OOMScoreAdjust": "0", "OnFailureJobMode": "replace", "OnSuccessJobMode": "fail", "PIDFile": "/run/certmonger.pid", "PartOf": "dbus-broker.service", "Perpetual": "no", "PrivateDevices": "no", "PrivateIPC": "no", "PrivateMounts": "no", "PrivateNetwork": "no", "PrivateTmp": "no", "PrivateUsers": "no", "ProcSubset": "all", "ProtectClock": "no", "ProtectControlGroups": "no", "ProtectHome": "no", "ProtectHostname": "no", "ProtectKernelLogs": "no", "ProtectKernelModules": "no", "ProtectKernelTunables": "no", "ProtectProc": "default", "ProtectSystem": "no", "RefuseManualStart": "no", "RefuseManualStop": "no", "ReloadResult": "success", "RemainAfterExit": "no", "RemoveIPC": "no", "Requires": "dbus.socket sysinit.target system.slice", "Restart": "no", "RestartKillSignal": "15", "RestartUSec": "100ms", "RestrictNamespaces": "no", "RestrictRealtime": "no", "RestrictSUIDSGID": "no", "Result": "success", "RootDirectoryStartOnly": "no", "RuntimeDirectoryMode": "0755", "RuntimeDirectoryPreserve": "no", "RuntimeMaxUSec": "infinity", "SameProcessGroup": "no", "SecureBits": "0", "SendSIGHUP": "no", "SendSIGKILL": "yes", "Slice": "system.slice", "StandardError": "inherit", "StandardInput": "null", "StandardOutput": "journal", "StartLimitAction": "none", "StartLimitBurst": "5", "StartLimitIntervalUSec": "10s", "StartupBlockIOWeight": "[not set]", "StartupCPUShares": "[not set]", "StartupCPUWeight": "[not set]", "StartupIOWeight": "[not set]", "StateChangeTimestamp": "n/a", "StateChangeTimestampMonotonic": "0", "StateDirectoryMode": "0755", "StatusErrno": "0", "StopWhenUnneeded": "no", "SubState": "dead", "SuccessAction": "none", "SyslogFacility": "3", "SyslogLevel": "6", "SyslogLevelPrefix": "yes", "SyslogPriority": "30", "SystemCallErrorNumber": "2147483646", "TTYReset": "no", "TTYVHangup": "no", "TTYVTDisallocate": "no", "TasksAccounting": "yes", "TasksCurrent": "[not set]", "TasksMax": "4439", "TimeoutAbortUSec": "1min 30s", "TimeoutCleanUSec": "infinity", "TimeoutStartFailureMode": "terminate", "TimeoutStartUSec": "1min 30s", "TimeoutStopFailureMode": "terminate", "TimeoutStopUSec": "1min 30s", "TimerSlackNSec": "50000", "Transient": "no", "Type": "dbus", "UID": "[not set]", "UMask": "0022", "UnitFilePreset": "disabled", "UnitFileState": "disabled", "UtmpMode": "init", "WatchdogSignal": "6", "WatchdogTimestamp": "n/a", "WatchdogTimestampMonotonic": "0", "WatchdogUSec": "infinity" } } TASK [linux-system-roles.certificate : Ensure certificate requests] ************ Thursday 18 August 2022 22:40:09 +0000 (0:00:01.146) 0:00:12.525 ******* changed: [sut] => (item={'name': 'mycert_no_auto_renew', 'dns': 'www.example.com', 'ca': 'self-sign', 'auto_renew': False}) => { "ansible_loop_var": "item", "changed": true, "item": { "auto_renew": false, "ca": "self-sign", "dns": "www.example.com", "name": "mycert_no_auto_renew" } } MSG: Certificate requested (new). changed: [sut] => (item={'name': 'defaultcert', 'dns': 'www.example.com', 'ca': 'self-sign'}) => { "ansible_loop_var": "item", "changed": true, "item": { "ca": "self-sign", "dns": "www.example.com", "name": "defaultcert" } } MSG: Certificate requested (new). PLAY [Verify certificate] ****************************************************** TASK [Gathering Facts] ********************************************************* Thursday 18 August 2022 22:40:10 +0000 (0:00:01.702) 0:00:14.228 ******* ok: [sut] TASK [Verify each certificate] ************************************************* Thursday 18 August 2022 22:40:11 +0000 (0:00:00.693) 0:00:14.921 ******* included: /WORKDIR/dist-git-certificate-use_distro_python_cryptography-AzisEh/tests/tasks/assert_certificate_parameters.yml for sut => (item={'path': '/etc/pki/tls/certs/mycert_no_auto_renew.crt', 'key_path': '/etc/pki/tls/private/mycert_no_auto_renew.key', 'subject': [{'name': 'commonName', 'oid': '2.5.4.3', 'value': 'www.example.com'}], 'subject_alt_name': [{'name': 'DNS', 'value': 'www.example.com'}], 'auto_renew': False}) included: /WORKDIR/dist-git-certificate-use_distro_python_cryptography-AzisEh/tests/tasks/assert_certificate_parameters.yml for sut => (item={'path': '/etc/pki/tls/certs/defaultcert.crt', 'key_path': '/etc/pki/tls/private/defaultcert.key', 'subject': [{'name': 'commonName', 'oid': '2.5.4.3', 'value': 'www.example.com'}], 'subject_alt_name': [{'name': 'DNS', 'value': 'www.example.com'}], 'auto_renew': True}) TASK [Set virtualenv_path] ***************************************************** Thursday 18 August 2022 22:40:11 +0000 (0:00:00.068) 0:00:14.990 ******* ok: [sut] => { "ansible_facts": { "__virtualenv_path": "/tmp/certificate-tests-venv" }, "changed": false } TASK [Ensure python3 is installed] ********************************************* Thursday 18 August 2022 22:40:11 +0000 (0:00:00.040) 0:00:15.031 ******* ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [Install the package, force upgrade] ************************************** Thursday 18 August 2022 22:40:14 +0000 (0:00:02.757) 0:00:17.788 ******* changed: [sut] => { "changed": true, "cmd": [ "/tmp/certificate-tests-venv/bin/pip3", "install", "-U", "pip" ], "name": [ "pip" ], "requirements": null, "state": "latest", "version": null, "virtualenv": "/tmp/certificate-tests-venv" } STDOUT: Requirement already satisfied: pip in ./certificate-tests-venv/lib/python3.10/site-packages (21.2.3) Collecting pip Downloading pip-22.2.2-py3-none-any.whl (2.0 MB) Installing collected packages: pip Attempting uninstall: pip Found existing installation: pip 21.2.3 Uninstalling pip-21.2.3: Successfully uninstalled pip-21.2.3 Successfully installed pip-22.2.2 TASK [Ensure Python's cryptography is installed] ******************************* Thursday 18 August 2022 22:40:20 +0000 (0:00:06.465) 0:00:24.254 ******* ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [Install certreader] ****************************************************** Thursday 18 August 2022 22:40:23 +0000 (0:00:02.816) 0:00:27.070 ******* changed: [sut] => { "changed": true, "cmd": [ "/tmp/certificate-tests-venv/bin/pip3", "install", "certreader>=0.1.1" ], "name": [ "certreader>=0.1.1" ], "requirements": null, "state": "present", "version": null, "virtualenv": "/tmp/certificate-tests-venv" } STDOUT: Collecting certreader>=0.1.1 Downloading certreader-0.1.1.tar.gz (4.4 kB) Preparing metadata (setup.py): started Preparing metadata (setup.py): finished with status 'done' Collecting cryptography Downloading cryptography-37.0.4-cp36-abi3-manylinux_2_24_x86_64.whl (4.1 MB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 4.1/4.1 MB 38.2 MB/s eta 0:00:00 Collecting pyasn1 Downloading pyasn1-0.4.8-py2.py3-none-any.whl (77 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 77.1/77.1 kB 11.7 MB/s eta 0:00:00 Collecting pyyaml Downloading PyYAML-6.0-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl (682 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 682.2/682.2 kB 15.2 MB/s eta 0:00:00 Collecting cffi>=1.12 Downloading cffi-1.15.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (441 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 441.8/441.8 kB 36.0 MB/s eta 0:00:00 Collecting pycparser Downloading pycparser-2.21-py2.py3-none-any.whl (118 kB) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 118.7/118.7 kB 16.7 MB/s eta 0:00:00 Using legacy 'setup.py install' for certreader, since package 'wheel' is not installed. Installing collected packages: pyasn1, pyyaml, pycparser, cffi, cryptography, certreader Running setup.py install for certreader: started Running setup.py install for certreader: finished with status 'done' Successfully installed certreader-0.1.1 cffi-1.15.1 cryptography-37.0.4 pyasn1-0.4.8 pycparser-2.21 pyyaml-6.0 TASK [Retrieve certificate file stats] ***************************************** Thursday 18 August 2022 22:40:26 +0000 (0:00:03.314) 0:00:30.384 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660862409.8476067, "attr_flags": "e", "attributes": [ "extents" ], "block_size": 4096, "blocks": 8, "charset": "us-ascii", "checksum": "8ce13d6b640af140bd066cb06a7a92410a6bf52c", "ctime": 1660862409.8436065, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 156833, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mimetype": "text/plain", "mode": "0600", "mtime": 1660862409.8436065, "nlink": 1, "path": "/etc/pki/tls/certs/mycert_no_auto_renew.crt", "pw_name": "root", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 1294, "uid": 0, "version": "2405355852", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Verify if certificate file exists] *************************************** Thursday 18 August 2022 22:40:27 +0000 (0:00:00.517) 0:00:30.902 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate file owner and group] ********************************* Thursday 18 August 2022 22:40:27 +0000 (0:00:00.080) 0:00:30.983 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate permissions] ****************************************** Thursday 18 August 2022 22:40:27 +0000 (0:00:00.073) 0:00:31.056 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Retrieve key file stats] ************************************************* Thursday 18 August 2022 22:40:27 +0000 (0:00:00.073) 0:00:31.130 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660862409.788606, "attr_flags": "e", "attributes": [ "extents" ], "block_size": 4096, "blocks": 8, "charset": "us-ascii", "checksum": "4ba9a62a20467db66952602f3369e412d2d14430", "ctime": 1660862409.8436065, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 156832, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mimetype": "text/plain", "mode": "0600", "mtime": 1660862409.8436065, "nlink": 1, "path": "/etc/pki/tls/private/mycert_no_auto_renew.key", "pw_name": "root", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 1704, "uid": 0, "version": "1652052923", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Verify if key file exists] *********************************************** Thursday 18 August 2022 22:40:27 +0000 (0:00:00.277) 0:00:31.407 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify key file owner and group] ***************************************** Thursday 18 August 2022 22:40:28 +0000 (0:00:00.084) 0:00:31.492 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Parse certificate] ******************************************************* Thursday 18 August 2022 22:40:28 +0000 (0:00:00.074) 0:00:31.566 ******* ok: [sut] => { "changed": false, "cmd": [ "/tmp/certificate-tests-venv/bin/certreader2json", "/etc/pki/tls/certs/mycert_no_auto_renew.crt" ], "delta": "0:00:00.278198", "end": "2022-08-18 22:40:28.784251", "rc": 0, "start": "2022-08-18 22:40:28.506053" } STDOUT: { "subject": [ { "name": "commonName", "oid": "2.5.4.3", "value": "www.example.com" } ], "extensions": { "keyUsage": { "value": [ "digital_signature", "key_encipherment" ], "critical": false }, "subjectAltName": { "value": [ { "name": "DNS", "value": "www.example.com" } ], "critical": false }, "extendedKeyUsage": { "value": [ { "name": "id-kp-serverAuth", "oid": "1.3.6.1.5.5.7.3.1" }, { "name": "id-kp-clientAuth", "oid": "1.3.6.1.5.5.7.3.2" } ], "critical": false }, "basicConstraints": { "value": { "ca": false }, "critical": true }, "subjectKeyIdentifier": { "value": "50:03:93:CE:80:CC:A5:7F:42:09:A0:2E:3C:08:BB:B7:58:78:17:78", "critical": false }, "authorityKeyIdentifier": { "value": "DF:24:5F:1C:8E:15:DC:DA:95:96:D4:8D:B1:F2:D9:68:7D:24:60:22", "critical": false } }, "signature_algorithm": { "algorithm": "sha256WithRSAEncryption", "signature": "2A:17:32:4E:88:BC:05:05:14:D7:B1:56:DB:A7:C1:AF:C6:EC:C9:61:CE:4F:B1:95:51:01:FF:F0:7E:49:04:AF:14:31:2D:86:01:88:20:F3:53:9F:72:4C:78:F4:86:D4:11:A4:72:11:31:C5:DC:59:D7:F2:D8:1D:45:3F:10:0A:E5:CF:40:1E:6F:FD:D1:B6:F2:25:6F:3B:DE:46:20:39:48:68:78:52:E8:BB:22:71:DE:6C:7D:78:22:6F:F4:4A:E0:31:82:1C:95:FF:A9:7E:17:A0:EC:D5:6B:68:E7:3F:27:19:67:A4:C9:BD:DC:F5:2B:95:47:46:3B:7C:33:B6:AC:EF:E4:A5:CF:BE:B6:FF:E5:B9:5F:D9:3D:68:10:95:77:3E:44:F8:A1:7D:27:93:69:33:58:10:1C:7A:6F:84:C8:47:8D:CC:AD:B0:8A:BA:36:7A:E1:6B:52:AC:3C:4F:E9:E3:7C:A6:AD:22:D2:3E:97:CD:6A:61:D5:82:F2:D0:4C:5E:05:48:B6:5C:67:CF:84:D4:97:2F:69:E6:F5:BD:00:30:62:47:C2:CE:5A:FE:C2:4C:2A:4C:07:CE:B9:25:AE:09:5C:77:DE:97:C1:27:29:AC:B7:A7:30:11:99:F9:DC:9E:61:28:E2:4F:09:6C:BB:F5:EB:F3:35:F3:23:EF" }, "key_size": 2048, "validity": { "not_valid_after": "2023-08-18 22:40:09", "not_valid_before": "2022-08-18 22:40:09" } } TASK [Load certificate YAML to cert_issued variable] *************************** Thursday 18 August 2022 22:40:28 +0000 (0:00:00.706) 0:00:32.273 ******* ok: [sut] => { "ansible_facts": { "cert_issued": { "extensions": { "authorityKeyIdentifier": { "critical": false, "value": "DF:24:5F:1C:8E:15:DC:DA:95:96:D4:8D:B1:F2:D9:68:7D:24:60:22" }, "basicConstraints": { "critical": true, "value": { "ca": false } }, "extendedKeyUsage": { "critical": false, "value": [ { "name": "id-kp-serverAuth", "oid": "1.3.6.1.5.5.7.3.1" }, { "name": "id-kp-clientAuth", "oid": "1.3.6.1.5.5.7.3.2" } ] }, "keyUsage": { "critical": false, "value": [ "digital_signature", "key_encipherment" ] }, "subjectAltName": { "critical": false, "value": [ { "name": "DNS", "value": "www.example.com" } ] }, "subjectKeyIdentifier": { "critical": false, "value": "50:03:93:CE:80:CC:A5:7F:42:09:A0:2E:3C:08:BB:B7:58:78:17:78" } }, "key_size": 2048, "signature_algorithm": { "algorithm": "sha256WithRSAEncryption", "signature": "2A:17:32:4E:88:BC:05:05:14:D7:B1:56:DB:A7:C1:AF:C6:EC:C9:61:CE:4F:B1:95:51:01:FF:F0:7E:49:04:AF:14:31:2D:86:01:88:20:F3:53:9F:72:4C:78:F4:86:D4:11:A4:72:11:31:C5:DC:59:D7:F2:D8:1D:45:3F:10:0A:E5:CF:40:1E:6F:FD:D1:B6:F2:25:6F:3B:DE:46:20:39:48:68:78:52:E8:BB:22:71:DE:6C:7D:78:22:6F:F4:4A:E0:31:82:1C:95:FF:A9:7E:17:A0:EC:D5:6B:68:E7:3F:27:19:67:A4:C9:BD:DC:F5:2B:95:47:46:3B:7C:33:B6:AC:EF:E4:A5:CF:BE:B6:FF:E5:B9:5F:D9:3D:68:10:95:77:3E:44:F8:A1:7D:27:93:69:33:58:10:1C:7A:6F:84:C8:47:8D:CC:AD:B0:8A:BA:36:7A:E1:6B:52:AC:3C:4F:E9:E3:7C:A6:AD:22:D2:3E:97:CD:6A:61:D5:82:F2:D0:4C:5E:05:48:B6:5C:67:CF:84:D4:97:2F:69:E6:F5:BD:00:30:62:47:C2:CE:5A:FE:C2:4C:2A:4C:07:CE:B9:25:AE:09:5C:77:DE:97:C1:27:29:AC:B7:A7:30:11:99:F9:DC:9E:61:28:E2:4F:09:6C:BB:F5:EB:F3:35:F3:23:EF" }, "subject": [ { "name": "commonName", "oid": "2.5.4.3", "value": "www.example.com" } ], "validity": { "not_valid_after": "2023-08-18 22:40:09", "not_valid_before": "2022-08-18 22:40:09" } } }, "changed": false } TASK [Verify certificate subject] ********************************************** Thursday 18 August 2022 22:40:28 +0000 (0:00:00.080) 0:00:32.354 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate SAN] ************************************************** Thursday 18 August 2022 22:40:29 +0000 (0:00:00.107) 0:00:32.461 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify key size] ********************************************************* Thursday 18 August 2022 22:40:29 +0000 (0:00:00.084) 0:00:32.546 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate Key Usage] ******************************************** Thursday 18 August 2022 22:40:29 +0000 (0:00:00.098) 0:00:32.645 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate Extended Key Usage] *********************************** Thursday 18 August 2022 22:40:29 +0000 (0:00:00.097) 0:00:32.742 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Retrieve auto-renew flag] ************************************************ Thursday 18 August 2022 22:40:29 +0000 (0:00:00.083) 0:00:32.826 ******* ok: [sut] => { "changed": false, "cmd": "set -euo pipefail; getcert list -f /etc/pki/tls/certs/mycert_no_auto_renew.crt | grep 'auto-renew' | sed 's/^\\s\\+auto-renew: //g'", "delta": "0:00:00.055957", "end": "2022-08-18 22:40:29.667648", "rc": 0, "start": "2022-08-18 22:40:29.611691" } STDOUT: no TASK [Verify certificate auto-renew flag] ************************************** Thursday 18 August 2022 22:40:29 +0000 (0:00:00.330) 0:00:33.157 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Set virtualenv_path] ***************************************************** Thursday 18 August 2022 22:40:29 +0000 (0:00:00.103) 0:00:33.260 ******* ok: [sut] => { "ansible_facts": { "__virtualenv_path": "/tmp/certificate-tests-venv" }, "changed": false } TASK [Ensure python3 is installed] ********************************************* Thursday 18 August 2022 22:40:29 +0000 (0:00:00.085) 0:00:33.346 ******* ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [Install the package, force upgrade] ************************************** Thursday 18 August 2022 22:40:32 +0000 (0:00:02.774) 0:00:36.120 ******* ok: [sut] => { "changed": false, "cmd": [ "/tmp/certificate-tests-venv/bin/pip3", "install", "-U", "pip" ], "name": [ "pip" ], "requirements": null, "state": "latest", "version": null, "virtualenv": "/tmp/certificate-tests-venv" } STDOUT: Requirement already satisfied: pip in ./certificate-tests-venv/lib/python3.10/site-packages (22.2.2) TASK [Ensure Python's cryptography is installed] ******************************* Thursday 18 August 2022 22:40:33 +0000 (0:00:01.008) 0:00:37.129 ******* ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [Install certreader] ****************************************************** Thursday 18 August 2022 22:40:36 +0000 (0:00:02.736) 0:00:39.865 ******* ok: [sut] => { "changed": false, "cmd": [ "/tmp/certificate-tests-venv/bin/pip3", "install", "certreader>=0.1.1" ], "name": [ "certreader>=0.1.1" ], "requirements": null, "state": "present", "version": null, "virtualenv": "/tmp/certificate-tests-venv" } STDOUT: Requirement already satisfied: certreader>=0.1.1 in ./certificate-tests-venv/lib/python3.10/site-packages (0.1.1) Requirement already satisfied: cryptography in ./certificate-tests-venv/lib/python3.10/site-packages (from certreader>=0.1.1) (37.0.4) Requirement already satisfied: pyasn1 in ./certificate-tests-venv/lib/python3.10/site-packages (from certreader>=0.1.1) (0.4.8) Requirement already satisfied: pyyaml in ./certificate-tests-venv/lib/python3.10/site-packages (from certreader>=0.1.1) (6.0) Requirement already satisfied: cffi>=1.12 in ./certificate-tests-venv/lib/python3.10/site-packages (from cryptography->certreader>=0.1.1) (1.15.1) Requirement already satisfied: pycparser in ./certificate-tests-venv/lib/python3.10/site-packages (from cffi>=1.12->cryptography->certreader>=0.1.1) (2.21) TASK [Retrieve certificate file stats] ***************************************** Thursday 18 August 2022 22:40:37 +0000 (0:00:00.895) 0:00:40.760 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660862410.5716157, "attr_flags": "e", "attributes": [ "extents" ], "block_size": 4096, "blocks": 8, "charset": "us-ascii", "checksum": "974a4e0781f38e22b637398b58050270ce5ff536", "ctime": 1660862410.5676157, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 156835, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mimetype": "text/plain", "mode": "0600", "mtime": 1660862410.5676157, "nlink": 1, "path": "/etc/pki/tls/certs/defaultcert.crt", "pw_name": "root", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 1294, "uid": 0, "version": "3329716892", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Verify if certificate file exists] *************************************** Thursday 18 August 2022 22:40:37 +0000 (0:00:00.273) 0:00:41.034 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate file owner and group] ********************************* Thursday 18 August 2022 22:40:37 +0000 (0:00:00.049) 0:00:41.084 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate permissions] ****************************************** Thursday 18 August 2022 22:40:37 +0000 (0:00:00.074) 0:00:41.158 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Retrieve key file stats] ************************************************* Thursday 18 August 2022 22:40:37 +0000 (0:00:00.069) 0:00:41.228 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660862410.508615, "attr_flags": "e", "attributes": [ "extents" ], "block_size": 4096, "blocks": 8, "charset": "us-ascii", "checksum": "b66e3b4be4a460ef21358305c0cf8943985f929e", "ctime": 1660862410.5676157, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 156834, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mimetype": "text/plain", "mode": "0600", "mtime": 1660862410.5676157, "nlink": 1, "path": "/etc/pki/tls/private/defaultcert.key", "pw_name": "root", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 1704, "uid": 0, "version": "3864795746", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Verify if key file exists] *********************************************** Thursday 18 August 2022 22:40:38 +0000 (0:00:00.275) 0:00:41.503 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify key file owner and group] ***************************************** Thursday 18 August 2022 22:40:38 +0000 (0:00:00.049) 0:00:41.552 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Parse certificate] ******************************************************* Thursday 18 August 2022 22:40:38 +0000 (0:00:00.072) 0:00:41.625 ******* ok: [sut] => { "changed": false, "cmd": [ "/tmp/certificate-tests-venv/bin/certreader2json", "/etc/pki/tls/certs/defaultcert.crt" ], "delta": "0:00:00.283677", "end": "2022-08-18 22:40:38.683302", "rc": 0, "start": "2022-08-18 22:40:38.399625" } STDOUT: { "subject": [ { "name": "commonName", "oid": "2.5.4.3", "value": "www.example.com" } ], "extensions": { "keyUsage": { "value": [ "digital_signature", "key_encipherment" ], "critical": false }, "subjectAltName": { "value": [ { "name": "DNS", "value": "www.example.com" } ], "critical": false }, "extendedKeyUsage": { "value": [ { "name": "id-kp-serverAuth", "oid": "1.3.6.1.5.5.7.3.1" }, { "name": "id-kp-clientAuth", "oid": "1.3.6.1.5.5.7.3.2" } ], "critical": false }, "basicConstraints": { "value": { "ca": false }, "critical": true }, "subjectKeyIdentifier": { "value": "6C:AC:36:DB:79:EE:20:69:C6:3E:89:0C:4A:5D:EA:71:A1:B0:AE:9E", "critical": false }, "authorityKeyIdentifier": { "value": "DF:24:5F:1C:8E:15:DC:DA:95:96:D4:8D:B1:F2:D9:68:7D:24:60:22", "critical": false } }, "signature_algorithm": { "algorithm": "sha256WithRSAEncryption", "signature": "8D:A5:CD:53:4F:80:70:01:48:A2:DA:55:20:82:97:2C:2B:31:46:8F:37:F3:A1:03:26:44:1B:B4:52:03:B1:73:5B:94:E4:6D:DD:44:ED:2D:8B:48:A5:43:A8:D9:9D:22:3A:6A:2D:F5:6E:62:62:35:D6:5D:24:76:78:B1:0E:C0:49:BA:19:8A:56:39:EF:9F:34:D9:49:48:56:94:EF:7D:47:C3:8A:0B:B9:1A:C1:E9:0F:D3:C1:67:E3:26:26:A7:E7:F7:52:7D:36:C1:09:21:10:B4:01:53:1C:76:08:4E:B2:B1:81:2D:F1:FF:C4:33:3F:4C:D6:3F:B1:41:B0:39:50:79:06:D0:27:DB:CA:05:18:25:5C:98:F5:7E:48:A0:B8:98:0A:9F:75:33:08:84:76:76:9D:BE:6C:1D:16:5D:5A:C0:C1:A4:26:44:79:D3:B8:3C:D3:43:8F:8F:99:35:74:9D:66:DC:CB:20:2C:0F:EE:B5:8A:0A:76:B6:51:C3:CF:76:F0:3D:CA:9F:D3:06:12:4D:9B:72:6E:4C:F7:A8:88:71:B4:D4:E2:EB:67:ED:AE:15:DF:74:69:53:07:91:A3:CC:0F:0B:F9:23:4A:CD:F0:7E:4C:2A:BF:DE:D0:3F:24:BA:4A:51:B2:B7:9F:86:4C:39:BD:31:3F:1E:2A:64" }, "key_size": 2048, "validity": { "not_valid_after": "2023-08-18 22:40:09", "not_valid_before": "2022-08-18 22:40:10" } } TASK [Load certificate YAML to cert_issued variable] *************************** Thursday 18 August 2022 22:40:38 +0000 (0:00:00.546) 0:00:42.171 ******* ok: [sut] => { "ansible_facts": { "cert_issued": { "extensions": { "authorityKeyIdentifier": { "critical": false, "value": "DF:24:5F:1C:8E:15:DC:DA:95:96:D4:8D:B1:F2:D9:68:7D:24:60:22" }, "basicConstraints": { "critical": true, "value": { "ca": false } }, "extendedKeyUsage": { "critical": false, "value": [ { "name": "id-kp-serverAuth", "oid": "1.3.6.1.5.5.7.3.1" }, { "name": "id-kp-clientAuth", "oid": "1.3.6.1.5.5.7.3.2" } ] }, "keyUsage": { "critical": false, "value": [ "digital_signature", "key_encipherment" ] }, "subjectAltName": { "critical": false, "value": [ { "name": "DNS", "value": "www.example.com" } ] }, "subjectKeyIdentifier": { "critical": false, "value": "6C:AC:36:DB:79:EE:20:69:C6:3E:89:0C:4A:5D:EA:71:A1:B0:AE:9E" } }, "key_size": 2048, "signature_algorithm": { "algorithm": "sha256WithRSAEncryption", "signature": "8D:A5:CD:53:4F:80:70:01:48:A2:DA:55:20:82:97:2C:2B:31:46:8F:37:F3:A1:03:26:44:1B:B4:52:03:B1:73:5B:94:E4:6D:DD:44:ED:2D:8B:48:A5:43:A8:D9:9D:22:3A:6A:2D:F5:6E:62:62:35:D6:5D:24:76:78:B1:0E:C0:49:BA:19:8A:56:39:EF:9F:34:D9:49:48:56:94:EF:7D:47:C3:8A:0B:B9:1A:C1:E9:0F:D3:C1:67:E3:26:26:A7:E7:F7:52:7D:36:C1:09:21:10:B4:01:53:1C:76:08:4E:B2:B1:81:2D:F1:FF:C4:33:3F:4C:D6:3F:B1:41:B0:39:50:79:06:D0:27:DB:CA:05:18:25:5C:98:F5:7E:48:A0:B8:98:0A:9F:75:33:08:84:76:76:9D:BE:6C:1D:16:5D:5A:C0:C1:A4:26:44:79:D3:B8:3C:D3:43:8F:8F:99:35:74:9D:66:DC:CB:20:2C:0F:EE:B5:8A:0A:76:B6:51:C3:CF:76:F0:3D:CA:9F:D3:06:12:4D:9B:72:6E:4C:F7:A8:88:71:B4:D4:E2:EB:67:ED:AE:15:DF:74:69:53:07:91:A3:CC:0F:0B:F9:23:4A:CD:F0:7E:4C:2A:BF:DE:D0:3F:24:BA:4A:51:B2:B7:9F:86:4C:39:BD:31:3F:1E:2A:64" }, "subject": [ { "name": "commonName", "oid": "2.5.4.3", "value": "www.example.com" } ], "validity": { "not_valid_after": "2023-08-18 22:40:09", "not_valid_before": "2022-08-18 22:40:10" } } }, "changed": false } TASK [Verify certificate subject] ********************************************** Thursday 18 August 2022 22:40:38 +0000 (0:00:00.064) 0:00:42.235 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate SAN] ************************************************** Thursday 18 August 2022 22:40:38 +0000 (0:00:00.071) 0:00:42.307 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify key size] ********************************************************* Thursday 18 August 2022 22:40:38 +0000 (0:00:00.055) 0:00:42.362 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate Key Usage] ******************************************** Thursday 18 August 2022 22:40:38 +0000 (0:00:00.068) 0:00:42.431 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify certificate Extended Key Usage] *********************************** Thursday 18 August 2022 22:40:39 +0000 (0:00:00.067) 0:00:42.499 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Retrieve auto-renew flag] ************************************************ Thursday 18 August 2022 22:40:39 +0000 (0:00:00.068) 0:00:42.567 ******* ok: [sut] => { "changed": false, "cmd": "set -euo pipefail; getcert list -f /etc/pki/tls/certs/defaultcert.crt | grep 'auto-renew' | sed 's/^\\s\\+auto-renew: //g'", "delta": "0:00:00.055566", "end": "2022-08-18 22:40:39.397745", "rc": 0, "start": "2022-08-18 22:40:39.342179" } STDOUT: yes TASK [Verify certificate auto-renew flag] ************************************** Thursday 18 August 2022 22:40:39 +0000 (0:00:00.318) 0:00:42.885 ******* ok: [sut] => { "changed": false } MSG: All assertions passed PLAY RECAP ********************************************************************* sut : ok=54 changed=8 unreachable=0 failed=0 skipped=1 rescued=0 ignored=0 Thursday 18 August 2022 22:40:39 +0000 (0:00:00.080) 0:00:42.966 ******* =============================================================================== Install the package, force upgrade -------------------------------------- 6.47s linux-system-roles.certificate : Ensure provider packages are installed --- 4.57s linux-system-roles.certificate : Ensure certificate role dependencies are installed --- 4.37s Install certreader ------------------------------------------------------ 3.31s Ensure Python's cryptography is installed ------------------------------- 2.82s Ensure python3 is installed --------------------------------------------- 2.77s Ensure python3 is installed --------------------------------------------- 2.76s Ensure Python's cryptography is installed ------------------------------- 2.74s linux-system-roles.certificate : Ensure certificate requests ------------ 1.70s linux-system-roles.certificate : Ensure provider service is running ----- 1.15s Gathering Facts --------------------------------------------------------- 1.10s Install the package, force upgrade -------------------------------------- 1.01s Install certreader ------------------------------------------------------ 0.90s Parse certificate ------------------------------------------------------- 0.71s Gathering Facts --------------------------------------------------------- 0.69s Parse certificate ------------------------------------------------------- 0.55s Retrieve certificate file stats ----------------------------------------- 0.52s linux-system-roles.certificate : Ensure pre-scripts hooks directory exists --- 0.46s linux-system-roles.certificate : Ensure ansible_facts used by role ------ 0.45s Retrieve auto-renew flag ------------------------------------------------ 0.33s ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- [DEPRECATION WARNING]: [defaults]callback_whitelist option, normalizing names to new standard, use callbacks_enabled instead. This feature will be removed from ansible-core in version 2.15. Deprecation warnings can be disabled by setting deprecation_warnings=False in ansible.cfg. ---^---^---^---^---^---