|
1 | 1 | import logging |
2 | | - |
3 | 2 | import pytest |
4 | 3 | from pages.HomePage import HomePage |
5 | | - |
| 4 | + |
6 | 5 | logger = logging.getLogger(__name__) |
| 6 | + |
| 7 | +# Define step-wise test actions for Golden Path |
| 8 | +golden_path_steps = [ |
| 9 | + ("Validate home page is loaded", lambda home: home.validate_home_page()), |
| 10 | + ("Select Invoice Schema", lambda home: home.select_schema("Invoice")), |
| 11 | + ("Upload Invoice documents", lambda home: home.upload_files("Invoice")), |
| 12 | + ("Refresh page till status is updated to Completed", lambda home: home.refresh()), |
| 13 | + ("Validate extracted result for Invoice", lambda home: home.validate_invoice_extracted_result()), |
| 14 | + ("Modify Extracted Data JSON & submit comments", lambda home: home.modify_and_submit_extracted_data()), |
| 15 | + ("Validate process steps for Invoice", lambda home: home.validate_process_steps()), |
| 16 | + ("Select Property Loss Damage Claim Form Schema", lambda home: home.select_schema("Property")), |
| 17 | + ("Upload Property Loss Damage Claim Form documents", lambda home: home.upload_files("Property")), |
| 18 | + ("Refresh page till status is updated to Completed", lambda home: home.refresh()), |
| 19 | + ("Validate extracted result for Property Loss Damage Claim Form", lambda home: home.validate_property_extracted_result()), |
| 20 | + ("Validate process steps for Property Loss Damage Claim Form", lambda home: home.validate_process_steps()), |
| 21 | + ("Validate Delete files", lambda home: home.delete_files()) |
| 22 | +] |
| 23 | + |
| 24 | +# Generate readable test step IDs |
| 25 | +golden_path_ids = [f"{i+1:02d}. {desc}" for i, (desc, _) in enumerate(golden_path_steps)] |
| 26 | + |
7 | 27 |
|
| 28 | +@pytest.mark.parametrize("description, action", golden_path_steps, ids=golden_path_ids) |
| 29 | +def test_content_processing_steps(login_logout, description, action, request): |
| 30 | + """ |
| 31 | + Executes Golden Path content processing steps with individual log entries. |
| 32 | + """ |
| 33 | + request.node._nodeid = description |
8 | 34 |
|
9 | | -@pytest.mark.testcase_id("TC001") |
10 | | -def test_ContentProcessing_Golden_path_test(login_logout): |
11 | | - """Validate Golden path test case for Content Processing Accelerator""" |
12 | 35 | page = login_logout |
13 | | - home_page = HomePage(page) |
14 | | - logger.info("Step 1: Validate home page is loaded.") |
15 | | - home_page.validate_home_page() |
16 | | - logger.info("Step 2: Select Invoice Schema.") |
17 | | - home_page.select_schema("Invoice") |
18 | | - logger.info("Step 3: Upload Invoice documents.") |
19 | | - home_page.upload_files("Invoice") |
20 | | - logger.info("Step 4: Refresh page till status is updated to Completed.") |
21 | | - home_page.refresh() |
22 | | - logger.info("Step 5: Validate extracted result for Invoice.") |
23 | | - home_page.validate_invoice_extracted_result() |
24 | | - logger.info("Step 6: Modify Extracted Data JSON & submit comments.") |
25 | | - home_page.modify_and_submit_extracted_data() |
26 | | - logger.info("Step 7: Validate process steps for Invoice") |
27 | | - home_page.validate_process_steps() |
28 | | - logger.info("Step 8: Select Property Loss Damage Claim Form Schema.") |
29 | | - home_page.select_schema("Property") |
30 | | - logger.info("Step 9: Upload Property Loss Damage Claim Form documents.") |
31 | | - home_page.upload_files("Property") |
32 | | - logger.info("Step 10: Refresh page till status is updated to Completed.") |
33 | | - home_page.refresh() |
34 | | - logger.info( |
35 | | - "Step 11: Validate extracted result for Property Loss Damage Claim Form." |
36 | | - ) |
37 | | - home_page.validate_property_extracted_result() |
38 | | - logger.info("Step 12: Validate process steps for Property Loss Damage Claim Form.") |
39 | | - home_page.validate_process_steps() |
40 | | - logger.info("Step 13: Validate Delete files.") |
41 | | - home_page.delete_files() |
| 36 | + home = HomePage(page) |
| 37 | + |
| 38 | + logger.info(f"Running test step: {description}") |
| 39 | + try: |
| 40 | + action(home) |
| 41 | + except Exception as e: |
| 42 | + logger.error(f"Step failed: {description}") |
| 43 | + raise |
| 44 | + |
| 45 | + # Optionally attach to report |
| 46 | + request.node._report_sections.append(("call", "log", f"Step passed: {description}")) |
0 commit comments