зеркало из
				https://github.com/ssciwr/AMMICO.git
				synced 2025-10-30 21:46:04 +02:00 
			
		
		
		
	![dependabot[bot]](/assets/img/avatar_default.png) 42b6732308
			
		
	
	
		42b6732308
		
			
		
	
	
	
	
		
			
			* Update deepface requirement from <=0.0.75 to <=0.0.92 --- updated-dependencies: - dependency-name: deepface dependency-type: direct:production ... Signed-off-by: dependabot[bot] <support@github.com> * more extensive testing for faces, adapt changes from deepface * include gender threshold in display and notebook * update documentation * increase detection threshold for tests * update handling of missing dict keys * update notebook * make sure text was found on image before analysing --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Inga Ulusoy <inga.ulusoy@uni-heidelberg.de>
		
			
				
	
	
		
			153 строки
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			153 строки
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import json
 | |
| import pandas as pd
 | |
| import ammico.utils as ut
 | |
| import pytest
 | |
| import os
 | |
| 
 | |
| 
 | |
| def test_find_files(get_path):
 | |
|     with pytest.raises(FileNotFoundError):
 | |
|         ut.find_files(path=".", pattern="*.png")
 | |
| 
 | |
|     result_jpg = ut.find_files(path=get_path, pattern=".jpg", recursive=True, limit=10)
 | |
|     assert 0 < len(result_jpg) <= 10
 | |
| 
 | |
|     result_png = ut.find_files(path=get_path, pattern=".png", recursive=True, limit=10)
 | |
|     assert 0 < len(result_png) <= 10
 | |
| 
 | |
|     result_png_jpg = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=10
 | |
|     )
 | |
|     assert 0 < len(result_png_jpg) <= 10
 | |
| 
 | |
|     result_png_jpg = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=4
 | |
|     )
 | |
|     assert 0 < len(result_png_jpg) <= 4
 | |
| 
 | |
|     result_png_jpg = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=[2, 4]
 | |
|     )
 | |
|     assert 0 < len(result_png_jpg) <= 2
 | |
| 
 | |
|     one_dir_up_path = os.path.join(get_path, "..")
 | |
|     with pytest.raises(FileNotFoundError):
 | |
|         ut.find_files(
 | |
|             path=one_dir_up_path, pattern=["png", "jpg"], recursive=False, limit=[2, 4]
 | |
|         )
 | |
| 
 | |
|     result_png_jpg = ut.find_files(
 | |
|         path=one_dir_up_path, pattern=["png", "jpg"], recursive=True, limit=[2, 4]
 | |
|     )
 | |
|     assert 0 < len(result_png_jpg) <= 2
 | |
| 
 | |
|     result_png_jpg = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=None
 | |
|     )
 | |
|     assert 0 < len(result_png_jpg)
 | |
|     result_png_jpg = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=-1
 | |
|     )
 | |
|     assert 0 < len(result_png_jpg)
 | |
| 
 | |
|     result_png_jpg_rdm1 = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=2, random_seed=1
 | |
|     )
 | |
|     result_png_jpg_rdm2 = ut.find_files(
 | |
|         path=get_path, pattern=["png", "jpg"], recursive=True, limit=2, random_seed=2
 | |
|     )
 | |
|     assert result_png_jpg_rdm1 != result_png_jpg_rdm2
 | |
|     assert len(result_png_jpg_rdm1) == len(result_png_jpg_rdm2)
 | |
| 
 | |
|     with pytest.raises(ValueError):
 | |
|         ut.find_files(path=get_path, pattern=["png", "jpg"], recursive=True, limit=-2)
 | |
|     with pytest.raises(ValueError):
 | |
|         ut.find_files(
 | |
|             path=get_path, pattern=["png", "jpg"], recursive=True, limit=[2, 4, 5]
 | |
|         )
 | |
|     with pytest.raises(ValueError):
 | |
|         ut.find_files(path=get_path, pattern=["png", "jpg"], recursive=True, limit=[2])
 | |
|     with pytest.raises(ValueError):
 | |
|         ut.find_files(
 | |
|             path=get_path, pattern=["png", "jpg"], recursive=True, limit="limit"
 | |
|         )
 | |
| 
 | |
| 
 | |
| def test_initialize_dict(get_path):
 | |
|     result = [
 | |
|         "./test/data/image_faces.jpg",
 | |
|         "./test/data/image_objects.jpg",
 | |
|     ]
 | |
|     mydict = ut.initialize_dict(result)
 | |
|     with open(get_path + "example_utils_init_dict.json", "r") as file:
 | |
|         out_dict = json.load(file)
 | |
|     assert mydict == out_dict
 | |
| 
 | |
| 
 | |
| def test_check_for_missing_keys():
 | |
|     mydict = {
 | |
|         "file1": {"faces": "Yes", "text_english": "Something"},
 | |
|         "file2": {"faces": "No", "text_english": "Otherthing"},
 | |
|     }
 | |
|     # check that dict is not changed
 | |
|     mydict2 = ut._check_for_missing_keys(mydict)
 | |
|     assert mydict2 == mydict
 | |
|     # check that dict is updated if key is missing
 | |
|     mydict = {
 | |
|         "file1": {"faces": "Yes", "text_english": "Something"},
 | |
|         "file2": {"faces": "No"},
 | |
|     }
 | |
|     mydict2 = ut._check_for_missing_keys(mydict)
 | |
|     assert mydict2["file2"] == {"faces": "No", "text_english": None}
 | |
|     # check that dict is updated if more than one key is missing
 | |
|     mydict = {"file1": {"faces": "Yes", "text_english": "Something"}, "file2": {}}
 | |
|     mydict2 = ut._check_for_missing_keys(mydict)
 | |
|     assert mydict2["file2"] == {"faces": None, "text_english": None}
 | |
| 
 | |
| 
 | |
| def test_append_data_to_dict(get_path):
 | |
|     with open(get_path + "example_append_data_to_dict_in.json", "r") as file:
 | |
|         mydict = json.load(file)
 | |
|     outdict = ut.append_data_to_dict(mydict)
 | |
|     print(outdict)
 | |
|     with open(get_path + "example_append_data_to_dict_out.json", "r") as file:
 | |
|         example_outdict = json.load(file)
 | |
| 
 | |
|     assert outdict == example_outdict
 | |
| 
 | |
| 
 | |
| def test_dump_df(get_path):
 | |
|     with open(get_path + "example_append_data_to_dict_out.json", "r") as file:
 | |
|         outdict = json.load(file)
 | |
|     df = ut.dump_df(outdict)
 | |
|     out_df = pd.read_csv(get_path + "example_dump_df.csv", index_col=[0])
 | |
|     pd.testing.assert_frame_equal(df, out_df)
 | |
| 
 | |
| 
 | |
| def test_get_dataframe(get_path):
 | |
|     with open(get_path + "example_append_data_to_dict_in.json", "r") as file:
 | |
|         mydict = json.load(file)
 | |
|     out_df = pd.read_csv(get_path + "example_dump_df.csv", index_col=[0])
 | |
|     df = ut.get_dataframe(mydict)
 | |
|     df.to_csv("data_out.csv")
 | |
|     pd.testing.assert_frame_equal(df, out_df)
 | |
| 
 | |
| 
 | |
| def test_is_interactive():
 | |
|     assert ut.is_interactive
 | |
| 
 | |
| 
 | |
| def test_get_color_table():
 | |
|     colors = ut.get_color_table()
 | |
|     assert colors["Pink"] == {
 | |
|         "ColorName": [
 | |
|             "Pink",
 | |
|             "LightPink",
 | |
|             "HotPink",
 | |
|             "DeepPink",
 | |
|             "PaleVioletRed",
 | |
|             "MediumVioletRed",
 | |
|         ],
 | |
|         "HEX": ["#FFC0CB", "#FFB6C1", "#FF69B4", "#FF1493", "#DB7093", "#C71585"],
 | |
|     }
 |