Console Output
Skipping 137 KB..
Full Log5Py84vycVD1nCI1qPENFAZBu8vY9uhnoPj6QKXogU/TApnQ/mXCmX/k+EwOjFwNrWWJOaSrQXAGEIr/S3KTUorY1U2W5pzzohpoGAls4ABU+jbPyAAAA[0mtests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%]
18:52:44 tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%]
18:52:44 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%]
18:52:44 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%]
18:52:44 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 55%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED [ 56%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 56%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%]
18:52:44 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%]
18:52:44 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%]
18:52:44 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%]
18:52:44 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%]
18:52:44 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%]
18:52:44 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%]
18:52:44 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 58%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED [ 59%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED [ 59%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED [ 59%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 59%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED [ 60%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED [ 60%]
18:52:44 tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED [ 60%]
18:52:44 tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 60%]
18:52:44 tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%]
18:52:44 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%]
18:52:44 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 62%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_platform PASSED [ 63%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%]
18:52:44 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED [ 63%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED [ 64%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED [ 64%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_export PASSED [ 64%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_image PASSED [ 65%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED [ 65%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED [ 65%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED [ 65%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_name PASSED [ 65%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED [ 66%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED [ 66%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED [ 66%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED [ 66%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_short_id PASSED [ 67%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_start PASSED [ 67%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED [ 67%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_status PASSED [ 67%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED [ 67%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_top PASSED [ 67%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 68%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_update PASSED [ 68%]
18:52:44 tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED [ 68%]
18:52:44 tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%]
18:52:44 tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED [ 68%]
18:52:44 tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%]
18:52:44 tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED [ 69%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED [ 69%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED [ 69%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 70%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED [ 70%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%]
18:52:45 tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%]
18:52:45 tests/unit/models_images_test.py::ImageTest::test_history PASSED [ 70%]
18:52:45 tests/unit/models_images_test.py::ImageTest::test_save PASSED [ 71%]
18:52:45 tests/unit/models_images_test.py::ImageTest::test_short_id PASSED [ 71%]
18:52:45 tests/unit/models_images_test.py::ImageTest::test_tag PASSED [ 71%]
18:52:45 tests/unit/models_images_test.py::ImageTest::test_tags PASSED [ 71%]
18:52:45 tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%]
18:52:45 tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%]
18:52:45 tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 72%]
18:52:45 tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED [ 72%]
18:52:45 tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED [ 72%]
18:52:45 tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED [ 72%]
18:52:45 tests/unit/models_resources_test.py::ModelTest::test_hash PASSED [ 72%]
18:52:45 tests/unit/models_resources_test.py::ModelTest::test_reload PASSED [ 72%]
18:52:45 tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%]
18:52:45 tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%]
18:52:45 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%]
18:52:45 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%]
18:52:45 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%]
18:52:45 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 74%]
18:52:45 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%]
18:52:45 tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%]
18:52:45 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%]
18:52:45 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%]
18:52:45 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%]
18:52:45 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 75%]
18:52:45 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%]
18:52:45 tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED [ 75%]
18:52:45 tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%]
18:52:45 tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED [ 75%]
18:52:45 tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED [ 75%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED [ 76%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 77%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 78%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED [ 78%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 79%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 81%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 82%]
18:52:45 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED [ 82%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED [ 82%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED [ 83%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%]
18:52:45 tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%]
18:52:45 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%]
18:52:45 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%]
18:52:45 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%]
18:52:45 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%]
18:52:45 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%]
18:52:45 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%]
18:52:45 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%]
18:52:45 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 85%]
18:52:45 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%]
18:52:45 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%]
18:52:45 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%]
18:52:45 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%]
18:52:45 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%]
18:52:45 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 86%]
18:52:45 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%]
18:52:45 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%]
18:52:45 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%]
18:52:45 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%]
18:52:45 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED [ 86%]
18:52:45 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%]
18:52:45 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED [ 87%]
18:52:45 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED [ 87%]
18:52:45 tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED [ 87%]
18:52:45 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%]
18:52:45 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%]
18:52:45 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%]
18:52:45 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%]
18:52:45 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%]
18:52:45 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 89%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%]
18:52:45 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%]
18:52:45 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%]
18:52:45 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%]
18:52:45 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%]
18:52:45 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%]
18:52:45 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%]
18:52:45 tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED [ 90%]
18:52:45 tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%]
18:52:45 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED [ 91%]
18:52:45 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%]
18:52:45 tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%]
18:52:45 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 93%]
18:52:45 tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED [ 93%]
18:52:45 tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%]
18:52:45 tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED [ 93%]
18:52:45 tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%]
18:52:45 tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%]
18:52:45 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED [ 94%]
18:52:45 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%]
18:52:45 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED [ 94%]
18:52:45 tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED [ 94%]
18:52:45 tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED [ 94%]
18:52:45 tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED [ 96%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED [ 96%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED [ 96%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED [ 97%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED [ 97%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%]
18:52:45 tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED [ 99%]
18:52:45 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%]
18:52:46 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%]
18:52:46
18:52:46 =============================== warnings summary ===============================
18:52:46 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure
18:52:46 /src/tests/unit/ssladapter_test.py:71: DeprecationWarning: ssl.match_hostname() is deprecated
18:52:46 match_hostname(self.cert, 'foobar.co.uk')
18:52:46
18:52:46 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success
18:52:46 /src/tests/unit/ssladapter_test.py:63: DeprecationWarning: ssl.match_hostname() is deprecated
18:52:46 assert match_hostname(self.cert, 'touhou.gensokyo.jp') is None
18:52:46
18:52:46 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure
18:52:46 /src/tests/unit/ssladapter_test.py:67: DeprecationWarning: ssl.match_hostname() is deprecated
18:52:46 match_hostname(self.cert, '192.168.0.25')
18:52:46
18:52:46 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success
18:52:46 /src/tests/unit/ssladapter_test.py:57: DeprecationWarning: ssl.match_hostname() is deprecated
18:52:46 assert match_hostname(self.cert, '127.0.0.1') is None
18:52:46
18:52:46 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success
18:52:46 /src/tests/unit/ssladapter_test.py:60: DeprecationWarning: ssl.match_hostname() is deprecated
18:52:46 assert match_hostname(self.cert, 'localhost') is None
18:52:46
18:52:46 -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html
18:52:46
18:52:46 ---------- coverage: platform linux, python 3.10.5-final-0 -----------
18:52:46 Name Stmts Miss Branch BrPart Cover
18:52:46 -----------------------------------------------------------------------
18:52:46 docker/__init__.py 8 0 0 0 100%
18:52:46 docker/api/__init__.py 1 0 0 0 100%
18:52:46 docker/api/build.py 127 41 98 21 64%
18:52:46 docker/api/client.py 267 65 94 11 76%
18:52:46 docker/api/config.py 31 18 6 0 41%
18:52:46 docker/api/container.py 278 73 110 26 66%
18:52:46 docker/api/daemon.py 40 4 16 4 86%
18:52:46 docker/api/exec_api.py 45 11 24 9 68%
18:52:46 docker/api/image.py 161 43 64 14 70%
18:52:46 docker/api/network.py 91 35 50 11 52%
18:52:46 docker/api/plugin.py 96 68 18 0 26%
18:52:46 docker/api/secret.py 36 22 10 0 35%
18:52:46 docker/api/service.py 202 176 151 0 8%
18:52:46 docker/api/swarm.py 110 67 40 1 31%
18:52:46 docker/api/volume.py 38 9 16 2 72%
18:52:46 docker/auth.py 200 16 80 16 89%
18:52:46 docker/client.py 80 9 4 0 89%
18:52:46 docker/constants.py 21 0 0 0 100%
18:52:46 docker/context/__init__.py 2 0 0 0 100%
18:52:46 docker/context/api.py 81 41 40 8 41%
18:52:46 docker/context/config.py 61 33 22 2 39%
18:52:46 docker/context/context.py 163 96 70 6 32%
18:52:46 docker/credentials/__init__.py 3 0 0 0 100%
18:52:46 docker/credentials/constants.py 4 0 0 0 100%
18:52:46 docker/credentials/errors.py 11 4 8 0 68%
18:52:46 docker/credentials/store.py 44 30 14 0 28%
18:52:46 docker/credentials/utils.py 23 18 12 0 14%
18:52:46 docker/errors.py 113 27 61 4 77%
18:52:46 docker/models/__init__.py 0 0 0 0 100%
18:52:46 docker/models/configs.py 22 8 6 0 64%
18:52:46 docker/models/containers.py 188 11 74 9 91%
18:52:46 docker/models/images.py 141 55 62 4 54%
18:52:46 docker/models/networks.py 39 7 16 3 75%
18:52:46 docker/models/nodes.py 16 5 6 0 68%
18:52:46 docker/models/plugins.py 51 29 12 0 41%
18:52:46 docker/models/resource.py 43 9 10 3 77%
18:52:46 docker/models/secrets.py 23 4 6 0 79%
18:52:46 docker/models/services.py 89 35 40 4 60%
18:52:46 docker/models/swarm.py 40 21 8 0 44%
18:52:46 docker/models/volumes.py 24 10 8 0 56%
18:52:46 docker/tls.py 35 5 14 5 80%
18:52:46 docker/transport/__init__.py 11 3 0 0 73%
18:52:46 docker/transport/basehttpadapter.py 6 0 4 1 90%
18:52:46 docker/transport/npipeconn.py 56 51 17 0 7%
18:52:46 docker/transport/npipesocket.py 140 136 24 0 2%
18:52:46 docker/transport/sshconn.py 161 104 67 3 32%
18:52:46 docker/transport/ssladapter.py 32 8 10 3 69%
18:52:46 docker/transport/unixconn.py 54 3 15 2 93%
18:52:46 docker/types/__init__.py 6 0 0 0 100%
18:52:46 docker/types/base.py 4 0 4 0 100%
18:52:46 docker/types/containers.py 440 79 340 43 82%
18:52:46 docker/types/daemon.py 36 24 16 0 27%
18:52:46 docker/types/healthcheck.py 43 20 6 0 51%
18:52:46 docker/types/networks.py 41 11 36 9 69%
18:52:46 docker/types/services.py 328 146 252 41 53%
18:52:46 docker/types/swarm.py 51 45 44 0 11%
18:52:46 docker/utils/__init__.py 3 0 0 0 100%
18:52:46 docker/utils/build.py 151 24 78 10 83%
18:52:46 docker/utils/config.py 36 1 12 1 96%
18:52:46 docker/utils/decorators.py 33 1 12 1 96%
18:52:46 docker/utils/fnmatch.py 55 18 28 2 61%
18:52:46 docker/utils/json_stream.py 40 8 14 2 78%
18:52:46 docker/utils/ports.py 50 3 32 2 91%
18:52:46 docker/utils/proxy.py 37 1 14 0 98%
18:52:46 docker/utils/socket.py 85 10 42 8 84%
18:52:46 docker/utils/utils.py 279 18 173 13 92%
18:52:46 docker/version.py 2 0 2 0 100%
18:52:46 -----------------------------------------------------------------------
18:52:46 TOTAL 5228 1819 2512 304 62%
18:52:46
18:52:46 =========================== short test summary info ============================
18:52:46 XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows
18:52:46 SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax
18:52:46 SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows
18:52:46 SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows
18:52:46 SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows
18:52:46 SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows
18:52:46 SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check
18:52:46 SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows
18:52:46 SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows
18:52:46 SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows
18:52:46 SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32'
18:52:46 ============ 563 passed, 10 skipped, 1 xfailed, 5 warnings in 6.29s ============