@@ -65,28 +65,44 @@ def test_generate_export_date_missing(self, params_w_no_date, logger, monkeypatc
65
65
expected_num_export_days = (date .today () - FULL_BKFILL_START_DATE .date ()).days + 1
66
66
assert num_export_days == expected_num_export_days
67
67
68
+ def generate_expected_start_end_dates (self , params_ , issue_date ):
69
+ dates_dict = {
70
+ "2024-06-27" : [ '2024-06-02' , '2024-06-03' , '2024-06-04' , '2024-06-05' , '2024-06-06' , '2024-06-07' , '2024-06-08' , '2024-06-09' , '2024-06-10' , '2024-06-11' , '2024-06-12' , '2024-06-13' , '2024-06-14' , '2024-06-15' , '2024-06-16' , '2024-06-17' , '2024-06-18' , '2024-06-19' , '2024-06-20' , '2024-06-21' , '2024-06-22' ],
71
+ "2024-06-28" : ['2024-06-03' , '2024-06-04' , '2024-06-05' , '2024-06-06' , '2024-06-07' , '2024-06-08' , '2024-06-09' , '2024-06-10' , '2024-06-11' , '2024-06-12' , '2024-06-13' , '2024-06-14' , '2024-06-15' , '2024-06-16' , '2024-06-17' , '2024-06-18' , '2024-06-19' , '2024-06-20' , '2024-06-21' , '2024-06-22' , '2024-06-23' ],
72
+ "2024-06-29" : ['2024-06-04' , '2024-06-05' , '2024-06-06' ,'2024-06-07' , '2024-06-08' , '2024-06-09' , '2024-06-10' , '2024-06-11' , '2024-06-12' , '2024-06-13' , '2024-06-14' , '2024-06-15' , '2024-06-16' , '2024-06-17' , '2024-06-18' , '2024-06-19' , '2024-06-20' , '2024-06-21' , '2024-06-22' , '2024-06-23' , '2024-06-24' ],
73
+ }
74
+
75
+ dates_dict = {
76
+ datetime .strptime (key , "%Y-%m-%d" ): [datetime .strptime (lvalue , "%Y-%m-%d" ) for lvalue in value ]
77
+ for key , value in dates_dict .items ()
78
+ }
79
+
80
+ dates = dates_dict [issue_date ]
81
+
82
+ return {
83
+ "export_start_date" : min (dates [6 :21 ]),
84
+ "export_end_date" : max (dates [6 :21 ])
85
+ }
86
+
68
87
def test_generate_patch_dates (self , params_w_patch , logger , monkeypatch ):
69
88
import covidcast
70
89
metadata_df = pd .read_csv (f"{ TEST_DIR } /test_data/covid_metadata_missing.csv" )
71
90
monkeypatch .setattr (covidcast , "metadata" , lambda : metadata_df )
72
- max_expected_lag = lag_converter (params_w_patch ["validation" ]["common" ]. get ( "max_expected_lag" , { "all" : 4 }) )
91
+ max_expected_lag = lag_converter (params_w_patch ["validation" ]["common" ][ "max_expected_lag" ] )
73
92
global_max_expected_lag = max (list (max_expected_lag .values ()))
74
- expected_num_export_days = params_w_patch ["validation" ]["common" ]. get ( "span_length" , 14 ) + global_max_expected_lag
93
+ num_export_days = params_w_patch ["validation" ]["common" ][ "span_length" ]
75
94
76
95
issue_date = datetime .strptime (params_w_patch ["patch" ]["start_issue" ], "%Y-%m-%d" )
77
96
end_issue = datetime .strptime (params_w_patch ["patch" ]["end_issue" ], "%Y-%m-%d" )
78
97
79
98
patch_date_dict = generate_patch_dates (params_w_patch )
80
99
81
100
while issue_date <= end_issue :
82
- expected_daterange = generate_query_dates (
83
- FULL_BKFILL_START_DATE ,
84
- issue_date ,
85
- expected_num_export_days ,
86
- False
87
- )
88
101
# in the patch script the date generated by generate_patch_dates becomes the export_start_date and export_end_date
89
- export_start_date , export_end_date = patch_date_dict [issue_date ]
90
- actual_daterange = generate_query_dates (export_start_date , export_end_date , expected_num_export_days , True )
91
- assert set (actual_daterange ) == set (expected_daterange )
92
- issue_date += timedelta (days = 1 )
102
+ patch_settings = patch_date_dict [issue_date ]
103
+ expected_dict = self .generate_expected_start_end_dates (params_w_patch , issue_date )
104
+ expected_dict ["num_export_days" ] = num_export_days # unmodified
105
+
106
+ assert patch_settings == expected_dict
107
+
108
+ issue_date += timedelta (days = 1 )
0 commit comments