# STDOUT: ---v---v---v---v---v--- Using /etc/ansible/ansible.cfg as config file PLAY [Test a creation of configuration file in the user directory] ************* TASK [Gathering Facts] ********************************************************* Thursday 11 August 2022 20:26:17 +0000 (0:00:00.019) 0:00:00.019 ******* ok: [sut] TASK [Backup configuration files] ********************************************** Thursday 11 August 2022 20:26:18 +0000 (0:00:01.102) 0:00:01.121 ******* included: /WORKDIR/dist-git-ssh-cast-value-to-string-in-jinja-DoWXN5/tests/tasks/backup.yml for sut TASK [Setup] ******************************************************************* Thursday 11 August 2022 20:26:18 +0000 (0:00:00.038) 0:00:01.159 ******* included: /WORKDIR/dist-git-ssh-cast-value-to-string-in-jinja-DoWXN5/tests/tasks/setup.yml for sut TASK [Ensure facts used by test] *********************************************** Thursday 11 August 2022 20:26:18 +0000 (0:00:00.036) 0:00:01.196 ******* skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Make sure openssh is installed before creating backup] ******************* Thursday 11 August 2022 20:26:18 +0000 (0:00:00.029) 0:00:01.225 ******* ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [Create a temporary directory for backup files] *************************** Thursday 11 August 2022 20:26:20 +0000 (0:00:01.171) 0:00:02.397 ******* ok: [sut] => { "changed": false, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/tmp/ansible.dkczi6yu", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 6, "state": "directory", "uid": 0 } TASK [Backup files] ************************************************************ Thursday 11 August 2022 20:26:20 +0000 (0:00:00.394) 0:00:02.791 ******* ok: [sut] => (item=/etc/ssh/ssh_config.d/00-ansible.conf) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /etc/ssh/ssh_config.d/00-ansible.conf; then\n mkdir -p /tmp/ansible.dkczi6yu/$(dirname /etc/ssh/ssh_config.d/00-ansible.conf);\n cp /etc/ssh/ssh_config.d/00-ansible.conf /tmp/ansible.dkczi6yu/$(dirname /etc/ssh/ssh_config.d/00-ansible.conf)\nfi\n", "delta": "0:00:00.003857", "end": "2022-08-11 20:26:20.779349", "item": "/etc/ssh/ssh_config.d/00-ansible.conf", "rc": 0, "start": "2022-08-11 20:26:20.775492" } ok: [sut] => (item=/etc/ssh/ssh_config) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /etc/ssh/ssh_config; then\n mkdir -p /tmp/ansible.dkczi6yu/$(dirname /etc/ssh/ssh_config);\n cp /etc/ssh/ssh_config /tmp/ansible.dkczi6yu/$(dirname /etc/ssh/ssh_config)\nfi\n", "delta": "0:00:00.011412", "end": "2022-08-11 20:26:21.016121", "item": "/etc/ssh/ssh_config", "rc": 0, "start": "2022-08-11 20:26:21.004709" } TASK [Create a test group (with the same name as user)] ************************ Thursday 11 August 2022 20:26:21 +0000 (0:00:00.643) 0:00:03.434 ******* changed: [sut] => { "changed": true, "gid": 1001, "name": "tester123", "state": "present", "system": false } TASK [Create a test user] ****************************************************** Thursday 11 August 2022 20:26:21 +0000 (0:00:00.435) 0:00:03.870 ******* changed: [sut] => { "changed": true, "comment": "", "create_home": true, "group": 1001, "home": "/home/tester123", "name": "tester123", "shell": "/bin/bash", "state": "present", "system": false, "uid": 1001 } TASK [Run role] **************************************************************** Thursday 11 August 2022 20:26:22 +0000 (0:00:00.578) 0:00:04.449 ******* TASK [linux-system-roles.ssh : Set platform/version specific variables] ******** Thursday 11 August 2022 20:26:22 +0000 (0:00:00.048) 0:00:04.498 ******* included: /WORKDIR/dist-git-ssh-cast-value-to-string-in-jinja-DoWXN5/tests/roles/linux-system-roles.ssh/tasks/set_vars.yml for sut TASK [linux-system-roles.ssh : Ensure ansible_facts used by role] ************** Thursday 11 August 2022 20:26:22 +0000 (0:00:00.038) 0:00:04.536 ******* ok: [sut] TASK [linux-system-roles.ssh : Set platform/version specific variables] ******** Thursday 11 August 2022 20:26:22 +0000 (0:00:00.448) 0:00:04.985 ******* skipping: [sut] => (item=RedHat.yml) => { "ansible_loop_var": "item", "changed": false, "item": "RedHat.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=RedHat.yml) => { "ansible_loop_var": "item", "changed": false, "item": "RedHat.yml", "skip_reason": "Conditional result was False" } ok: [sut] => (item=RedHat_9.yml) => { "ansible_facts": { "__ssh_defaults": { "Include": "/etc/ssh/ssh_config.d/*.conf" }, "__ssh_drop_in_name": "00-ansible", "__ssh_supports_drop_in": true }, "ansible_included_var_files": [ "/WORKDIR/dist-git-ssh-cast-value-to-string-in-jinja-DoWXN5/tests/roles/linux-system-roles.ssh/vars/RedHat_9.yml" ], "ansible_loop_var": "item", "changed": false, "item": "RedHat_9.yml" } skipping: [sut] => (item=RedHat_9.1.yml) => { "ansible_loop_var": "item", "changed": false, "item": "RedHat_9.1.yml", "skip_reason": "Conditional result was False" } TASK [linux-system-roles.ssh : Ensure required packages are installed] ********* Thursday 11 August 2022 20:26:22 +0000 (0:00:00.076) 0:00:05.061 ******* ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [linux-system-roles.ssh : Gather information about the user for user configuration] *** Thursday 11 August 2022 20:26:23 +0000 (0:00:00.981) 0:00:06.043 ******* ok: [sut] => { "ansible_facts": { "getent_passwd": { "tester123": [ "x", "1001", "1001", "", "/home/tester123", "/bin/bash" ] } }, "changed": false } TASK [linux-system-roles.ssh : Make sure the ~/.ssh/ directory exists and has expected permissions] *** Thursday 11 August 2022 20:26:24 +0000 (0:00:00.413) 0:00:06.457 ******* changed: [sut] => { "changed": true, "gid": 1001, "group": "tester123", "mode": "0700", "owner": "tester123", "path": "/home/tester123/.ssh/", "secontext": "unconfined_u:object_r:ssh_home_t:s0", "size": 6, "state": "directory", "uid": 1001 } TASK [linux-system-roles.ssh : Generate the configuration file] **************** Thursday 11 August 2022 20:26:24 +0000 (0:00:00.439) 0:00:06.897 ******* changed: [sut] => { "changed": true, "checksum": "33e5d453ffc19413f8e74630b334c90d4e22a1dd", "dest": "/home/tester123/.ssh/config", "gid": 1001, "group": "tester123", "md5sum": "df1b5553fea0fc8007bd9d80d983bbbe", "mode": "0600", "owner": "tester123", "secontext": "unconfined_u:object_r:ssh_home_t:s0", "size": 98, "src": "/root/.ansible/tmp/ansible-tmp-1660249584.6085286-11156-248238404582222/source", "state": "file", "uid": 1001 } TASK [Gather information about the user] *************************************** Thursday 11 August 2022 20:26:25 +0000 (0:00:01.338) 0:00:08.235 ******* ok: [sut] => { "ansible_facts": { "getent_passwd": { "tester123": [ "x", "1001", "1001", "", "/home/tester123", "/bin/bash" ] } }, "changed": false } TASK [Download the created configuration file] ********************************* Thursday 11 August 2022 20:26:26 +0000 (0:00:00.256) 0:00:08.492 ******* ok: [sut] => { "changed": false, "content": "IwojIEFuc2libGUgbWFuYWdlZAojCkdTU0FQSUF1dGhlbnRpY2F0aW9uIG5vCkhvc3QgZXhhbXBsZQogIEhvc3RuYW1lIGV4YW1wbGUuY29tCiAgVXNlciBzb21lYm9keQo=", "encoding": "base64", "source": "/home/tester123/.ssh/config" } TASK [Stat the .ssh dir] ******************************************************* Thursday 11 August 2022 20:26:26 +0000 (0:00:00.397) 0:00:08.890 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660249584.4771354, "attr_flags": "", "attributes": [], "block_size": 4096, "blocks": 0, "charset": "binary", "ctime": 1660249585.7700984, "dev": 51716, "device_type": 0, "executable": true, "exists": true, "gid": 1001, "gr_name": "tester123", "inode": 553648448, "isblk": false, "ischr": false, "isdir": true, "isfifo": false, "isgid": false, "islnk": false, "isreg": false, "issock": false, "isuid": false, "mimetype": "inode/directory", "mode": "0700", "mtime": 1660249585.7700984, "nlink": 2, "path": "/home/tester123/.ssh", "pw_name": "tester123", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 20, "uid": 1001, "version": "4256351719", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": true } } TASK [Verify the ~/.ssh has sensible permissions] ****************************** Thursday 11 August 2022 20:26:27 +0000 (0:00:00.592) 0:00:09.482 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Make sure the file is readable by user] ********************************** Thursday 11 August 2022 20:26:27 +0000 (0:00:00.053) 0:00:09.535 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660249586.4730783, "attr_flags": "", "attributes": [], "block_size": 4096, "blocks": 8, "charset": "us-ascii", "checksum": "33e5d453ffc19413f8e74630b334c90d4e22a1dd", "ctime": 1660249585.7710984, "dev": 51716, "device_type": 0, "executable": false, "exists": true, "gid": 1001, "gr_name": "tester123", "inode": 562037253, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mimetype": "text/plain", "mode": "0600", "mtime": 1660249585.2231143, "nlink": 1, "path": "/home/tester123/.ssh/config", "pw_name": "tester123", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 98, "uid": 1001, "version": "2987848095", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Stat the configuration file] ********************************************* Thursday 11 August 2022 20:26:27 +0000 (0:00:00.471) 0:00:10.007 ******* ok: [sut] => { "changed": false, "stat": { "atime": 1660249586.4730783, "attr_flags": "", "attributes": [], "block_size": 4096, "blocks": 8, "charset": "us-ascii", "checksum": "33e5d453ffc19413f8e74630b334c90d4e22a1dd", "ctime": 1660249585.7710984, "dev": 51716, "device_type": 0, "executable": false, "exists": true, "gid": 1001, "gr_name": "tester123", "inode": 562037253, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mimetype": "text/plain", "mode": "0600", "mtime": 1660249585.2231143, "nlink": 1, "path": "/home/tester123/.ssh/config", "pw_name": "tester123", "readable": true, "rgrp": false, "roth": false, "rusr": true, "size": 98, "uid": 1001, "version": "2987848095", "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Verify the options are in the file] ************************************** Thursday 11 August 2022 20:26:27 +0000 (0:00:00.267) 0:00:10.274 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Verify the file has sensible permissions] ******************************** Thursday 11 August 2022 20:26:27 +0000 (0:00:00.073) 0:00:10.348 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Test the effective configuration using ssh] ****************************** Thursday 11 August 2022 20:26:28 +0000 (0:00:00.055) 0:00:10.403 ******* changed: [sut] => { "changed": true, "cmd": [ "ssh", "-vvv", "-G", "example" ], "delta": "0:00:00.010666", "end": "2022-08-11 20:26:28.441352", "rc": 0, "start": "2022-08-11 20:26:28.430686" } STDOUT: user somebody hostname example.com port 22 addressfamily any batchmode no canonicalizefallbacklocal yes canonicalizehostname false checkhostip no compression no controlmaster false enablesshkeysign no clearallforwardings no exitonforwardfailure no fingerprinthash SHA256 forwardx11 no forwardx11trusted yes gatewayports no gssapiauthentication no gssapikeyexchange no gssapidelegatecredentials no gssapitrustdns no gssapirenewalforcesrekey no gssapikexalgorithms gss-curve25519-sha256-,gss-nistp256-sha256-,gss-group14-sha256-,gss-group16-sha512- hashknownhosts no hostbasedauthentication no identitiesonly no kbdinteractiveauthentication yes nohostauthenticationforlocalhost no passwordauthentication yes permitlocalcommand no proxyusefdpass no pubkeyauthentication yes requesttty auto sessiontype default stdinnull no forkafterauthentication no streamlocalbindunlink no stricthostkeychecking ask tcpkeepalive yes tunnel false verifyhostkeydns false visualhostkey no updatehostkeys true canonicalizemaxdots 1 connectionattempts 1 forwardx11timeout 1200 numberofpasswordprompts 3 serveralivecountmax 3 serveraliveinterval 0 rsaminsize 1024 ciphers aes256-gcm@openssh.com,chacha20-poly1305@openssh.com,aes256-ctr,aes128-gcm@openssh.com,aes128-ctr hostkeyalgorithms ssh-ed25519-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521-cert-v01@openssh.com,sk-ssh-ed25519-cert-v01@openssh.com,sk-ecdsa-sha2-nistp256-cert-v01@openssh.com,rsa-sha2-512-cert-v01@openssh.com,rsa-sha2-256-cert-v01@openssh.com,ssh-rsa-cert-v01@openssh.com,ssh-ed25519,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521,sk-ssh-ed25519@openssh.com,sk-ecdsa-sha2-nistp256@openssh.com,rsa-sha2-512,rsa-sha2-256,ssh-rsa hostbasedacceptedalgorithms ssh-ed25519-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521-cert-v01@openssh.com,sk-ssh-ed25519-cert-v01@openssh.com,sk-ecdsa-sha2-nistp256-cert-v01@openssh.com,rsa-sha2-512-cert-v01@openssh.com,rsa-sha2-256-cert-v01@openssh.com,ssh-rsa-cert-v01@openssh.com,ssh-ed25519,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521,sk-ssh-ed25519@openssh.com,sk-ecdsa-sha2-nistp256@openssh.com,rsa-sha2-512,rsa-sha2-256,ssh-rsa kexalgorithms curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512 casignaturealgorithms ecdsa-sha2-nistp256,sk-ecdsa-sha2-nistp256@openssh.com,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521,ssh-ed25519,sk-ssh-ed25519@openssh.com,rsa-sha2-256,rsa-sha2-512 loglevel DEBUG3 macs hmac-sha2-256-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha2-256,hmac-sha1,umac-128@openssh.com,hmac-sha2-512 securitykeyprovider internal pubkeyacceptedalgorithms ecdsa-sha2-nistp256,ecdsa-sha2-nistp256-cert-v01@openssh.com,sk-ecdsa-sha2-nistp256@openssh.com,sk-ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521,ecdsa-sha2-nistp521-cert-v01@openssh.com,ssh-ed25519,ssh-ed25519-cert-v01@openssh.com,sk-ssh-ed25519@openssh.com,sk-ssh-ed25519-cert-v01@openssh.com,rsa-sha2-256,rsa-sha2-256-cert-v01@openssh.com,rsa-sha2-512,rsa-sha2-512-cert-v01@openssh.com xauthlocation /usr/bin/xauth identityfile ~/.ssh/id_rsa identityfile ~/.ssh/id_dsa identityfile ~/.ssh/id_ecdsa identityfile ~/.ssh/id_ecdsa_sk identityfile ~/.ssh/id_ed25519 identityfile ~/.ssh/id_ed25519_sk identityfile ~/.ssh/id_xmss canonicaldomains none globalknownhostsfile /etc/ssh/ssh_known_hosts /etc/ssh/ssh_known_hosts2 userknownhostsfile /home/tester123/.ssh/known_hosts /home/tester123/.ssh/known_hosts2 logverbose none permitremoteopen any addkeystoagent false forwardagent no connecttimeout none tunneldevice any:any controlpersist no escapechar ~ ipqos af21 cs1 rekeylimit 0 0 streamlocalbindmask 0177 syslogfacility USER STDERR: OpenSSH_8.7p1, OpenSSL 3.0.1 14 Dec 2021 debug1: Reading configuration data /home/tester123/.ssh/config debug1: /home/tester123/.ssh/config line 5: Applying options for example debug1: Reading configuration data /etc/ssh/ssh_config debug3: /etc/ssh/ssh_config line 55: Including file /etc/ssh/ssh_config.d/50-redhat.conf depth 0 debug1: Reading configuration data /etc/ssh/ssh_config.d/50-redhat.conf debug2: checking match for 'final all' host example.com originally example debug3: /etc/ssh/ssh_config.d/50-redhat.conf line 3: not matched 'final' debug2: match not found debug3: /etc/ssh/ssh_config.d/50-redhat.conf line 5: Including file /etc/crypto-policies/back-ends/openssh.config depth 1 (parse only) debug1: Reading configuration data /etc/crypto-policies/back-ends/openssh.config debug3: gss kex names ok: [gss-curve25519-sha256-,gss-nistp256-sha256-,gss-group14-sha256-,gss-group16-sha512-] debug3: kex names ok: [curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512] debug1: configuration requests final Match pass debug1: re-parsing configuration debug1: Reading configuration data /home/tester123/.ssh/config debug1: Reading configuration data /etc/ssh/ssh_config debug3: /etc/ssh/ssh_config line 55: Including file /etc/ssh/ssh_config.d/50-redhat.conf depth 0 debug1: Reading configuration data /etc/ssh/ssh_config.d/50-redhat.conf debug2: checking match for 'final all' host example.com originally example debug3: /etc/ssh/ssh_config.d/50-redhat.conf line 3: matched 'final' debug2: match found debug3: /etc/ssh/ssh_config.d/50-redhat.conf line 5: Including file /etc/crypto-policies/back-ends/openssh.config depth 1 debug1: Reading configuration data /etc/crypto-policies/back-ends/openssh.config debug3: gss kex names ok: [gss-curve25519-sha256-,gss-nistp256-sha256-,gss-group14-sha256-,gss-group16-sha512-] debug3: kex names ok: [curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512] debug3: expanded UserKnownHostsFile '~/.ssh/known_hosts' -> '/home/tester123/.ssh/known_hosts' debug3: expanded UserKnownHostsFile '~/.ssh/known_hosts2' -> '/home/tester123/.ssh/known_hosts2' TASK [Make sure the effective configuration is expected] *********************** Thursday 11 August 2022 20:26:28 +0000 (0:00:00.493) 0:00:10.896 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Download the global configuration files too] ***************************** Thursday 11 August 2022 20:26:28 +0000 (0:00:00.072) 0:00:10.969 ******* ok: [sut] => { "changed": false, "content": "IwkkT3BlbkJTRDogc3NoX2NvbmZpZyx2IDEuMzUgMjAyMC8wNy8xNyAwMzo0Mzo0MiBkdHVja2VyIEV4cCAkCgojIFRoaXMgaXMgdGhlIHNzaCBjbGllbnQgc3lzdGVtLXdpZGUgY29uZmlndXJhdGlvbiBmaWxlLiAgU2VlCiMgc3NoX2NvbmZpZyg1KSBmb3IgbW9yZSBpbmZvcm1hdGlvbi4gIFRoaXMgZmlsZSBwcm92aWRlcyBkZWZhdWx0cyBmb3IKIyB1c2VycywgYW5kIHRoZSB2YWx1ZXMgY2FuIGJlIGNoYW5nZWQgaW4gcGVyLXVzZXIgY29uZmlndXJhdGlvbiBmaWxlcwojIG9yIG9uIHRoZSBjb21tYW5kIGxpbmUuCgojIENvbmZpZ3VyYXRpb24gZGF0YSBpcyBwYXJzZWQgYXMgZm9sbG93czoKIyAgMS4gY29tbWFuZCBsaW5lIG9wdGlvbnMKIyAgMi4gdXNlci1zcGVjaWZpYyBmaWxlCiMgIDMuIHN5c3RlbS13aWRlIGZpbGUKIyBBbnkgY29uZmlndXJhdGlvbiB2YWx1ZSBpcyBvbmx5IGNoYW5nZWQgdGhlIGZpcnN0IHRpbWUgaXQgaXMgc2V0LgojIFRodXMsIGhvc3Qtc3BlY2lmaWMgZGVmaW5pdGlvbnMgc2hvdWxkIGJlIGF0IHRoZSBiZWdpbm5pbmcgb2YgdGhlCiMgY29uZmlndXJhdGlvbiBmaWxlLCBhbmQgZGVmYXVsdHMgYXQgdGhlIGVuZC4KCiMgU2l0ZS13aWRlIGRlZmF1bHRzIGZvciBzb21lIGNvbW1vbmx5IHVzZWQgb3B0aW9ucy4gIEZvciBhIGNvbXByZWhlbnNpdmUKIyBsaXN0IG9mIGF2YWlsYWJsZSBvcHRpb25zLCB0aGVpciBtZWFuaW5ncyBhbmQgZGVmYXVsdHMsIHBsZWFzZSBzZWUgdGhlCiMgc3NoX2NvbmZpZyg1KSBtYW4gcGFnZS4KCiMgSG9zdCAqCiMgICBGb3J3YXJkQWdlbnQgbm8KIyAgIEZvcndhcmRYMTEgbm8KIyAgIFBhc3N3b3JkQXV0aGVudGljYXRpb24geWVzCiMgICBIb3N0YmFzZWRBdXRoZW50aWNhdGlvbiBubwojICAgR1NTQVBJQXV0aGVudGljYXRpb24gbm8KIyAgIEdTU0FQSURlbGVnYXRlQ3JlZGVudGlhbHMgbm8KIyAgIEdTU0FQSUtleUV4Y2hhbmdlIG5vCiMgICBHU1NBUElUcnVzdEROUyBubwojICAgQmF0Y2hNb2RlIG5vCiMgICBDaGVja0hvc3RJUCB5ZXMKIyAgIEFkZHJlc3NGYW1pbHkgYW55CiMgICBDb25uZWN0VGltZW91dCAwCiMgICBTdHJpY3RIb3N0S2V5Q2hlY2tpbmcgYXNrCiMgICBJZGVudGl0eUZpbGUgfi8uc3NoL2lkX3JzYQojICAgSWRlbnRpdHlGaWxlIH4vLnNzaC9pZF9kc2EKIyAgIElkZW50aXR5RmlsZSB+Ly5zc2gvaWRfZWNkc2EKIyAgIElkZW50aXR5RmlsZSB+Ly5zc2gvaWRfZWQyNTUxOQojICAgUG9ydCAyMgojICAgQ2lwaGVycyBhZXMxMjgtY3RyLGFlczE5Mi1jdHIsYWVzMjU2LWN0cixhZXMxMjgtY2JjLDNkZXMtY2JjCiMgICBNQUNzIGhtYWMtbWQ1LGhtYWMtc2hhMSx1bWFjLTY0QG9wZW5zc2guY29tCiMgICBFc2NhcGVDaGFyIH4KIyAgIFR1bm5lbCBubwojICAgVHVubmVsRGV2aWNlIGFueTphbnkKIyAgIFBlcm1pdExvY2FsQ29tbWFuZCBubwojICAgVmlzdWFsSG9zdEtleSBubwojICAgUHJveHlDb21tYW5kIHNzaCAtcSAtVyAlaDolcCBnYXRld2F5LmV4YW1wbGUuY29tCiMgICBSZWtleUxpbWl0IDFHIDFoCiMgICBVc2VyS25vd25Ib3N0c0ZpbGUgfi8uc3NoL2tub3duX2hvc3RzLmQvJWsKIwojIFRoaXMgc3lzdGVtIGlzIGZvbGxvd2luZyBzeXN0ZW0td2lkZSBjcnlwdG8gcG9saWN5LgojIFRvIG1vZGlmeSB0aGUgY3J5cHRvIHByb3BlcnRpZXMgKENpcGhlcnMsIE1BQ3MsIC4uLiksIGNyZWF0ZSBhICAqLmNvbmYKIyAgZmlsZSB1bmRlciAgL2V0Yy9zc2gvc3NoX2NvbmZpZy5kLyAgd2hpY2ggd2lsbCBiZSBhdXRvbWF0aWNhbGx5CiMgaW5jbHVkZWQgYmVsb3cuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWUgbWFudWFsIHBhZ2UgZm9yCiMgIHVwZGF0ZS1jcnlwdG8tcG9saWNpZXMoOCkgIGFuZCAgc3NoX2NvbmZpZyg1KS4KSW5jbHVkZSAvZXRjL3NzaC9zc2hfY29uZmlnLmQvKi5jb25mCg==", "encoding": "base64", "source": "/etc/ssh/ssh_config" } TASK [Verify the options are NOT in the global configuration file] ************* Thursday 11 August 2022 20:26:28 +0000 (0:00:00.241) 0:00:11.210 ******* ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Restore configuration files] ********************************************* Thursday 11 August 2022 20:26:28 +0000 (0:00:00.099) 0:00:11.310 ******* included: /WORKDIR/dist-git-ssh-cast-value-to-string-in-jinja-DoWXN5/tests/tasks/restore.yml for sut TASK [Restore backed up files and remove what was not present] ***************** Thursday 11 August 2022 20:26:28 +0000 (0:00:00.037) 0:00:11.347 ******* ok: [sut] => (item=/etc/ssh/ssh_config.d/00-ansible.conf) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /tmp/ansible.dkczi6yu//etc/ssh/ssh_config.d/00-ansible.conf; then\n cp /tmp/ansible.dkczi6yu//etc/ssh/ssh_config.d/00-ansible.conf $(dirname /etc/ssh/ssh_config.d/00-ansible.conf)\nelif test -f /etc/ssh/ssh_config.d/00-ansible.conf; then\n rm /etc/ssh/ssh_config.d/00-ansible.conf\nfi\n", "delta": "0:00:00.003841", "end": "2022-08-11 20:26:29.210201", "item": "/etc/ssh/ssh_config.d/00-ansible.conf", "rc": 0, "start": "2022-08-11 20:26:29.206360" } ok: [sut] => (item=/etc/ssh/ssh_config) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /tmp/ansible.dkczi6yu//etc/ssh/ssh_config; then\n cp /tmp/ansible.dkczi6yu//etc/ssh/ssh_config $(dirname /etc/ssh/ssh_config)\nelif test -f /etc/ssh/ssh_config; then\n rm /etc/ssh/ssh_config\nfi\n", "delta": "0:00:00.006591", "end": "2022-08-11 20:26:29.472663", "item": "/etc/ssh/ssh_config", "rc": 0, "start": "2022-08-11 20:26:29.466072" } TASK [Remove temporary directory for backup files] ***************************** Thursday 11 August 2022 20:26:29 +0000 (0:00:00.544) 0:00:11.892 ******* ok: [sut] => { "changed": false, "path": "/tmp/ansible.dkczi6yu", "state": "absent" } PLAY RECAP ********************************************************************* sut : ok=30 changed=5 unreachable=0 failed=0 skipped=1 rescued=0 ignored=0 Thursday 11 August 2022 20:26:29 +0000 (0:00:00.279) 0:00:12.172 ******* =============================================================================== linux-system-roles.ssh : Generate the configuration file ---------------- 1.34s Make sure openssh is installed before creating backup ------------------- 1.17s Gathering Facts --------------------------------------------------------- 1.10s linux-system-roles.ssh : Ensure required packages are installed --------- 0.98s Backup files ------------------------------------------------------------ 0.64s Stat the .ssh dir ------------------------------------------------------- 0.59s Create a test user ------------------------------------------------------ 0.58s Restore backed up files and remove what was not present ----------------- 0.54s Test the effective configuration using ssh ------------------------------ 0.49s Make sure the file is readable by user ---------------------------------- 0.47s linux-system-roles.ssh : Ensure ansible_facts used by role -------------- 0.45s linux-system-roles.ssh : Make sure the ~/.ssh/ directory exists and has expected permissions --- 0.44s Create a test group (with the same name as user) ------------------------ 0.44s linux-system-roles.ssh : Gather information about the user for user configuration --- 0.41s Download the created configuration file --------------------------------- 0.40s Create a temporary directory for backup files --------------------------- 0.39s Remove temporary directory for backup files ----------------------------- 0.28s Stat the configuration file --------------------------------------------- 0.27s Gather information about the user --------------------------------------- 0.26s Download the global configuration files too ----------------------------- 0.24s ---^---^---^---^---^--- # 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. [WARNING]: Module remote_tmp /home/tester123/.ansible/tmp did not exist and was created with a mode of 0700, this may cause issues when running as another user. To avoid this, create the remote_tmp dir with the correct permissions manually ---^---^---^---^---^---