working on export issues

This commit is contained in:
Khalim Conn-Kowlessar 2026-02-26 16:53:23 +00:00
parent 1717e7b4c2
commit 1df4fb7815
4 changed files with 42 additions and 18 deletions

View file

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectTasksOptions">
<TaskOptions isEnabled="true">
<TaskOptions isEnabled="false">
<option name="arguments" value="$FilePath$" />
<option name="checkSyntaxErrors" value="true" />
<option name="description" />

View file

@ -37,6 +37,7 @@ def process_export(payload: ExportRequest, session: Session) -> Dict[Union[str,
logger.info("Retrieved %s plans for export", len(plans_df))
if plans_df.empty:
logger.info("Empty plans dataframe - no plans to export. Returning empty export.")
return export_files
plan_ids: List[int] = plans_df["id"].tolist()
recommendations_df: pd.DataFrame = db_methods.get_recommendations(plan_ids)

View file

@ -27,21 +27,38 @@ def test_default_export_integration(db_session):
t0 = time.perf_counter()
portfolio_df = load_csv("portfolio_569.csv")
properties_df = load_csv("properties_569.csv")
# properties_df = properties_df.head(10)
property_details_epc_df = load_csv("property_details_epc_569.csv")
# property_details_epc_df = property_details_epc_df[property_details_epc_df["property_id"].isin(properties_df[
# "id"])]
plans_df = load_csv("plans_569.csv")
# plans_df = plans_df[plans_df["property_id"].isin(properties_df["id"])]
plan_recs_df = load_csv("plan_recs_569.csv")
# plan_recs_df = plan_recs_df[plan_recs_df["plan_id"].isin(plans_df["id"])]
recommendations_df = load_csv("recommendations_569.csv")
# recommendations_df = recommendations_df[recommendations_df["id"].isin(plan_recs_df["recommendation_id"])]
# Shrink down recommendations_df to speed up the data load. For this test, we only need
# default recommendations so let's focus on those. We filter on where default is true
recommendations_df = recommendations_df[
recommendations_df["default"]
]
valid_rec_ids = recommendations_df["id"].unique()
# recommendations_df = recommendations_df[
# recommendations_df["default"]
# ]
# valid_rec_ids = recommendations_df["id"].unique()
#
# plan_recs_df = plan_recs_df[
# plan_recs_df["recommendation_id"].isin(valid_rec_ids)
# ]
plan_recs_df = plan_recs_df[
plan_recs_df["recommendation_id"].isin(valid_rec_ids)
]
# Save all of this:
# portfolio_df.to_csv("portfolio_569.csv")
# properties_df.to_csv("properties_569.csv")
# property_details_epc_df.to_csv("property_details_epc_569.csv")
# plans_df.to_csv("plans_569.csv")
# plan_recs_df.to_csv("plan_recs_569.csv")
# recommendations_df.to_csv("recommendations_569.csv")
logger.info(
"Loaded CSVs in %.2f seconds | properties=%s plans=%s recs=%s",
@ -131,7 +148,7 @@ def test_default_export_integration(db_session):
# Build only fields that exist on the model
epc_data = {
col.name: row_dict[col.name]
for col in PropertyDetailsEpcModel.__table__.columns
for col in PropertyDetailsEpcModel.__table__.columns.values()
if col.name in row_dict and col.name not in ["id", "property_id", "portfolio_id"]
}
@ -227,6 +244,11 @@ def test_default_export_integration(db_session):
db_session.query(Recommendation).count()
)
logger.info(
"Property count in DB: %s",
db_session.query(PropertyModel).count()
)
logger.info(
"Default + not installed count: %s",
db_session.query(Recommendation)
@ -248,11 +270,11 @@ def test_default_export_integration(db_session):
# 8) Assertions
# ----------------------------------------
assert "default_plans" in result
assert "default_plans" in result, "Expected 'default_plans' in export result, got {}".format(result.keys())
df = result["default_plans"]
assert not df.empty
assert df.shape[0] == 10, "Expected 10 properties in the export, got {}".format(df.shape[0])
# This test was generated on a real portfolio and so we check the things we expect to do

View file

@ -28,15 +28,16 @@ from sqlalchemy import func
# PORTFOLIO_ID = 206
# SCENARIOS = [389]
PORTFOLIO_ID = 568
PORTFOLIO_ID = 581
SCENARIOS = [
1059,
1074, 1075
]
scenario_names = {
1059: "EPC C - 10k budget",
1074: "EPC C",
1075: "EPC C Again",
}
project_name = "manchester"
project_name = "???"
def get_data(portfolio_id, scenario_ids):