diff --git a/awx/main/tests/unit/test_tasks.py b/awx/main/tests/unit/test_tasks.py index d003569c82a2..696f663c2e61 100644 --- a/awx/main/tests/unit/test_tasks.py +++ b/awx/main/tests/unit/test_tasks.py @@ -374,8 +374,8 @@ def test_vars_unsafe_by_default(self, job, private_data_dir, mock_me): task = jobs.RunJob() task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) # ensure that strings are marked as unsafe for name in JOB_VARIABLE_PREFIXES: @@ -393,8 +393,8 @@ def test_launchtime_vars_unsafe(self, job, private_data_dir, mock_me): task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) assert extra_vars['msg'] == self.UNSAFE assert hasattr(extra_vars['msg'], '__UNSAFE__') @@ -404,8 +404,8 @@ def test_nested_launchtime_vars_unsafe(self, job, private_data_dir, mock_me): task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) assert extra_vars['msg'] == {'a': [self.UNSAFE]} assert hasattr(extra_vars['msg']['a'][0], '__UNSAFE__') @@ -415,8 +415,8 @@ def test_allowed_jt_extra_vars(self, job, private_data_dir, mock_me): task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) assert extra_vars['msg'] == self.UNSAFE assert not hasattr(extra_vars['msg'], '__UNSAFE__') @@ -427,8 +427,8 @@ def test_nested_allowed_vars(self, job, private_data_dir, mock_me): task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) assert extra_vars['msg'] == {'a': {'b': [self.UNSAFE]}} assert not hasattr(extra_vars['msg']['a']['b'][0], '__UNSAFE__') @@ -441,8 +441,8 @@ def test_sensitive_values_dont_leak(self, job, private_data_dir, mock_me): task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) assert extra_vars['msg'] == 'other-value' assert hasattr(extra_vars['msg'], '__UNSAFE__') @@ -456,8 +456,8 @@ def test_overwritten_jt_extra_vars(self, job, private_data_dir, mock_me): task.build_extra_vars_file(job, private_data_dir) - fd = open(os.path.join(private_data_dir, 'env', 'extravars')) - extra_vars = yaml.load(fd, Loader=SafeLoader) + with open(os.path.join(private_data_dir, 'env', 'extravars')) as fd: + extra_vars = yaml.load(fd, Loader=SafeLoader) assert extra_vars['msg'] == self.UNSAFE assert hasattr(extra_vars['msg'], '__UNSAFE__') @@ -885,7 +885,8 @@ def test_k8s_credential(self, job, private_data_dir, verify, mock_me): if verify: assert env['K8S_AUTH_VERIFY_SSL'] == 'True' local_path = to_host_path(env['K8S_AUTH_SSL_CA_CERT'], private_data_dir) - cert = open(local_path, 'r').read() + with open(local_path, 'r') as f: + cert = f.read() assert cert == 'CERTDATA' else: assert env['K8S_AUTH_VERIFY_SSL'] == 'False' @@ -936,7 +937,8 @@ def test_gce_credentials(self, cred_env_var, private_data_dir, job, mock_me): credential.credential_type.inject_credential(credential, env, safe_env, [], private_data_dir) runner_path = env[cred_env_var] local_path = to_host_path(runner_path, private_data_dir) - json_data = json.load(open(local_path, 'rb')) + with open(local_path, 'rb') as f_host: + json_data = json.load(f_host) assert json_data['type'] == 'service_account' assert json_data['private_key'] == self.EXAMPLE_PRIVATE_KEY assert json_data['client_email'] == 'bob' @@ -1008,7 +1010,8 @@ def test_openstack_credentials(self, private_data_dir, job, mock_me): credential.credential_type.inject_credential(credential, env, {}, [], private_data_dir) config_loc = to_host_path(env['OS_CLIENT_CONFIG_FILE'], private_data_dir) - shade_config = open(config_loc, 'r').read() + with open(config_loc, 'r') as f: + shade_config = f.read() assert shade_config == '\n'.join( [ 'clouds:', @@ -1083,7 +1086,8 @@ def test_net_credentials(self, authorize, expected_authorize, job, private_data_ assert env['ANSIBLE_NET_AUTHORIZE'] == expected_authorize if authorize: assert env['ANSIBLE_NET_AUTH_PASS'] == 'authorizeme' - assert open(env['ANSIBLE_NET_SSH_KEYFILE'], 'r').read() == self.EXAMPLE_PRIVATE_KEY + with open(env['ANSIBLE_NET_SSH_KEYFILE'], 'r') as f: + assert f.read() == self.EXAMPLE_PRIVATE_KEY assert safe_env['ANSIBLE_NET_PASSWORD'] == HIDDEN_PASSWORD def test_terraform_cloud_credentials(self, job, private_data_dir, mock_me): @@ -1104,7 +1108,8 @@ def test_terraform_cloud_credentials(self, job, private_data_dir, mock_me): credential.credential_type.inject_credential(credential, env, safe_env, [], private_data_dir) local_path = to_host_path(env['TF_BACKEND_CONFIG_FILE'], private_data_dir) - config = open(local_path, 'r').read() + with open(local_path, 'r') as f: + config = f.read() assert config == hcl_config def test_terraform_gcs_backend_credentials(self, job, private_data_dir, mock_me): @@ -1138,11 +1143,13 @@ def test_terraform_gcs_backend_credentials(self, job, private_data_dir, mock_me) credential.credential_type.inject_credential(credential, env, safe_env, [], private_data_dir) local_path = to_host_path(env['TF_BACKEND_CONFIG_FILE'], private_data_dir) - config = open(local_path, 'r').read() + with open(local_path, 'r') as f: + config = f.read() assert config == hcl_config credentials_path = to_host_path(env['GOOGLE_BACKEND_CREDENTIALS'], private_data_dir) - credentials = open(credentials_path, 'r').read() + with open(credentials_path, 'r') as f: + credentials = f.read() assert credentials == gce_backend_credentials def test_custom_environment_injectors_with_jinja_syntax_error(self, private_data_dir, mock_me): @@ -1351,7 +1358,8 @@ def test_custom_environment_injectors_with_file(self, private_data_dir, mock_me) credential.credential_type.inject_credential(credential, env, {}, [], private_data_dir) path = to_host_path(env['MY_CLOUD_INI_FILE'], private_data_dir) - assert open(path, 'r').read() == '[mycloud]\nABC123' + with open(path, 'r') as f: + assert f.read() == '[mycloud]\nABC123' def test_custom_environment_injectors_with_unicode_content(self, private_data_dir, mock_me): value = 'Iñtërnâtiônàlizætiøn' @@ -1371,7 +1379,8 @@ def test_custom_environment_injectors_with_unicode_content(self, private_data_di credential.credential_type.inject_credential(credential, env, {}, [], private_data_dir) path = to_host_path(env['MY_CLOUD_INI_FILE'], private_data_dir) - assert open(path, 'r').read() == value + with open(path, 'r') as f: + assert f.read() == value def test_custom_environment_injectors_with_files(self, private_data_dir, mock_me): some_cloud = CredentialType( @@ -1391,8 +1400,10 @@ def test_custom_environment_injectors_with_files(self, private_data_dir, mock_me cert_path = to_host_path(env['MY_CERT_INI_FILE'], private_data_dir) key_path = to_host_path(env['MY_KEY_INI_FILE'], private_data_dir) - assert open(cert_path, 'r').read() == '[mycert]\nCERT123' - assert open(key_path, 'r').read() == '[mykey]\nKEY123' + with open(cert_path, 'r') as f: + assert f.read() == '[mycert]\nCERT123' + with open(key_path, 'r') as f: + assert f.read() == '[mykey]\nKEY123' def test_multi_cloud(self, private_data_dir, mock_me): gce = CredentialType.defaults['gce']() @@ -1415,7 +1426,8 @@ def test_multi_cloud(self, private_data_dir, mock_me): # Because this is testing a mix of multiple cloud creds, we are not going to test the GOOGLE_APPLICATION_CREDENTIALS here path = to_host_path(env['GCE_CREDENTIALS_FILE_PATH'], private_data_dir) - json_data = json.load(open(path, 'rb')) + with open(path, 'rb') as f: + json_data = json.load(f) assert json_data['type'] == 'service_account' assert json_data['private_key'] == self.EXAMPLE_PRIVATE_KEY assert json_data['client_email'] == 'bob' @@ -1768,7 +1780,8 @@ def run(expected_gce_zone): credential.credential_type.inject_credential(credential, env, safe_env, [], private_data_dir) assert env['GCE_ZONE'] == expected_gce_zone - json_data = json.load(open(env[cred_env_var], 'rb')) + with open(env[cred_env_var], 'rb') as f: + json_data = json.load(f) assert json_data['type'] == 'service_account' assert json_data['private_key'] == self.EXAMPLE_PRIVATE_KEY assert json_data['client_email'] == 'bob' @@ -1797,7 +1810,8 @@ def get_cred(): env = task.build_env(inventory_update, private_data_dir, private_data_files) path = to_host_path(env['OS_CLIENT_CONFIG_FILE'], private_data_dir) - shade_config = open(path, 'r').read() + with open(path, 'r') as f: + shade_config = f.read() assert ( '\n'.join( [ diff --git a/awx/main/utils/common.py b/awx/main/utils/common.py index f283b8ec90ac..066a365f0f0d 100644 --- a/awx/main/utils/common.py +++ b/awx/main/utils/common.py @@ -1096,7 +1096,11 @@ def create_temporary_fifo(data): path = os.path.join(tempfile.mkdtemp(), next(tempfile._get_candidate_names())) os.mkfifo(path, stat.S_IRUSR | stat.S_IWUSR) - threading.Thread(target=lambda p, d: open(p, 'wb').write(d), args=(path, data)).start() + def tmp_write(path, data): + with open(path, 'wb') as f: + f.write(data) + + threading.Thread(target=tmp_write, args=(path, data)).start() return path diff --git a/pytest.ini b/pytest.ini index a8d237c88d2e..223145085de7 100644 --- a/pytest.ini +++ b/pytest.ini @@ -84,21 +84,6 @@ filterwarnings = # FIXME: descriptors and then delete the entry. once:unclosed file <_io.TextIOWrapper name='[^']+' mode='r' encoding='UTF-8'>:ResourceWarning:awx.main.tests.unit.test_tasks - # FIXME: Use `open()` via a context manager - # FIXME: in `awx/main/tests/unit/test_tasks.py` to close hanging file - # FIXME: descriptors and then delete the entry. - once:unclosed file <_io.BufferedReader name='[^']+'>:ResourceWarning:awx.main.tests.unit.test_tasks - - # FIXME: Use `open()` via a context manager - # FIXME: in `awx/main/tests/unit/test_tasks.py` to close hanging file - # FIXME: descriptors and then delete the entry. - once:unclosed file <_io.TextIOWrapper name='[^']+' mode='r' encoding='UTF-8'>:ResourceWarning:_pytest.python - - # FIXME: Use `open()` via a context manager - # FIXME: in `awx/main/utils/common.py` to close hanging file descriptors - # FIXME: and then delete the entry. - once:unclosed file <_io.BufferedWriter name='[^']+'>:ResourceWarning:awx.main.utils.common - # https://docs.pytest.org/en/stable/usage.html#creating-junitxml-format-files junit_duration_report = call # xunit1 contains more metadata than xunit2 so it's better for CI UIs: