[
  {
    "description": "  As a developer\n  I want to see build and deployment statuses on commits\n  So that I know the state of each commit at a glance",
    "elements": [
      {
        "description": "",
        "id": "commit-status-visibility;build-step-reports-pending-status-to-commit",
        "keyword": "Scenario",
        "line": 15,
        "name": "Build step reports pending status to commit",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 2724863156
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1438397592
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 852451
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 556604
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 16,
            "name": "a build step starts executing",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:41"
            },
            "result": {
              "status": "passed",
              "duration": 69143260
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 17,
            "name": "the commit shows a pending status with a description of the step",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:46"
            },
            "result": {
              "status": "passed",
              "duration": 71113860
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 591592313
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 57448875
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0001",
            "line": 14
          },
          {
            "name": "@mock",
            "line": 14
          },
          {
            "name": "@real",
            "line": 14
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "commit-status-visibility;build-step-reports-successful-completion-with-a-result-link",
        "keyword": "Scenario",
        "line": 20,
        "name": "Build step reports successful completion with a result link",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1351265665
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1390576786
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 412750
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 360231
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 21,
            "name": "a build step completes successfully and reports its results",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:52"
            },
            "result": {
              "status": "passed",
              "duration": 72331620
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 22,
            "name": "the commit shows a success status with a clickable link to the results",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:57"
            },
            "result": {
              "status": "passed",
              "duration": 32279872
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 574356648
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 50254402
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0001",
            "line": 19
          },
          {
            "name": "@mock",
            "line": 19
          },
          {
            "name": "@real",
            "line": 19
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "commit-status-visibility;build-step-reports-failure-when-tests-do-not-pass",
        "keyword": "Scenario",
        "line": 25,
        "name": "Build step reports failure when tests do not pass",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1360005908
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1477070187
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 835368
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 355913
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 26,
            "name": "a build step fails",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:63"
            },
            "result": {
              "status": "passed",
              "duration": 48858212
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 27,
            "name": "the commit shows a failure status with a description of what went wrong",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:68"
            },
            "result": {
              "status": "passed",
              "duration": 32452607
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 578297225
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 52832622
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0001",
            "line": 24
          },
          {
            "name": "@mock",
            "line": 24
          },
          {
            "name": "@real",
            "line": 24
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "commit-status-visibility;multiple-build-steps-report-distinct-statuses-on-the-same-commit",
        "keyword": "Scenario",
        "line": 30,
        "name": "Multiple build steps report distinct statuses on the same commit",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1340348255
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1497845164
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 406137
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 288305
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 31,
            "name": "several build steps each report their own status to the same commit",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:74"
            },
            "result": {
              "status": "passed",
              "duration": 782660393
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 32,
            "name": "each status appears under a unique label on the commit",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:82"
            },
            "result": {
              "status": "passed",
              "duration": 733711998
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 598328155
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 57394623
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0001",
            "line": 29
          },
          {
            "name": "@mock",
            "line": 29
          },
          {
            "name": "@real",
            "line": 29
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "commit-status-visibility;deployment-step-reports-status-back-to-the-source-commit",
        "keyword": "Scenario",
        "line": 35,
        "name": "Deployment step reports status back to the source commit",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1369108018
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1432666607
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 357562
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 195927
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 36,
            "name": "a deployment finishes for a commit that originated from another repository",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:95"
            },
            "result": {
              "status": "passed",
              "duration": 48793147
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 37,
            "name": "the source commit shows the deployment status alongside the build status",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:100"
            },
            "result": {
              "status": "passed",
              "duration": 82172693
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 590511459
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 66485162
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0001",
            "line": 34
          },
          {
            "name": "@mock",
            "line": 34
          },
          {
            "name": "@real",
            "line": 34
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "commit-status-visibility;status-reporting-is-interrupted-when-the-build-system-cannot-be-reached",
        "keyword": "Scenario",
        "line": 40,
        "name": "Status reporting is interrupted when the build system cannot be reached",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1324985697
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1399920002
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 265722
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 244039
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 41,
            "name": "a build step tries to report status but the build system is unavailable",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:110"
            },
            "result": {
              "status": "passed",
              "duration": 1275600822
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 42,
            "name": "the pipeline fails with a clear error message",
            "match": {
              "location": "tests/features/step_definitions/commit-status.steps.js:118"
            },
            "result": {
              "status": "passed",
              "duration": 570941
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 598612704
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 50875208
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0001",
            "line": 39
          },
          {
            "name": "@mock",
            "line": 39
          }
        ],
        "type": "scenario"
      }
    ],
    "id": "commit-status-visibility",
    "line": 1,
    "keyword": "Feature",
    "name": "Commit status visibility",
    "tags": [],
    "uri": "tests/features/commit-status.feature"
  },
  {
    "description": "  As a GitOps repository\n  I want to update version references and report results to the caller\n  So that the deployment chain is traceable from source to GitOps commit",
    "elements": [
      {
        "description": "",
        "id": "gitops-update;not-enough-env-vars-—-script-fails,-no-status-set",
        "keyword": "Scenario",
        "line": 11,
        "name": "Not enough env vars — script fails, no status set",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1385763414
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1483442514
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 337900
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 177508
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 12,
            "name": "insufficient environment variables are provided for the GitOps update",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:96"
            },
            "result": {
              "status": "passed",
              "duration": 655832
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 13,
            "name": "the GitOps update script runs",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:119"
            },
            "result": {
              "status": "passed",
              "duration": 29263313
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 14,
            "name": "the script exits with error",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:123"
            },
            "result": {
              "status": "passed",
              "duration": 426679
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 593085351
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 75789625
            }
          }
        ],
        "tags": [
          {
            "name": "@mock",
            "line": 10
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "gitops-update;gitops-job-fails-—-no-status-set-(sha-not-yet-known)",
        "keyword": "Scenario",
        "line": 17,
        "name": "GitOps job fails — no status set (SHA not yet known)",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1372026203
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1392753777
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 204069
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 217603
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 18,
            "name": "the GitOps repository clone will fail",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:100"
            },
            "result": {
              "status": "passed",
              "duration": 1289010
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 19,
            "name": "the GitOps update script runs",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:119"
            },
            "result": {
              "status": "passed",
              "duration": 55791874
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 20,
            "name": "the script exits with error",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:123"
            },
            "result": {
              "status": "passed",
              "duration": 195827
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 561406533
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 49233809
            }
          }
        ],
        "tags": [
          {
            "name": "@mock",
            "line": 16
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "gitops-update;everything-succeeds-—-gitops-repo-gets-success-status-with-link-to-caller",
        "keyword": "Scenario",
        "line": 23,
        "name": "Everything succeeds — GitOps repo gets success status with link to caller",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1343752470
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1443635936
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 308313
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 293295
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 24,
            "name": "a valid GitOps update dispatch",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:104"
            },
            "result": {
              "status": "passed",
              "duration": 391177
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 25,
            "name": "the GitOps update script runs",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:119"
            },
            "result": {
              "status": "passed",
              "duration": 804885286
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 26,
            "name": "the script exits successfully",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:127"
            },
            "result": {
              "status": "passed",
              "duration": 580819
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 27,
            "name": "the GitOps repo commit shows a success status with a link to the caller commit",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:131"
            },
            "result": {
              "status": "passed",
              "duration": 70733268
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 588878372
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 40616084
            }
          }
        ],
        "tags": [
          {
            "name": "@mock",
            "line": 22
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "gitops-update;gitops-push-fails-—-gitops-repo-gets-failure-status",
        "keyword": "Scenario",
        "line": 30,
        "name": "GitOps push fails — GitOps repo gets failure status",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1386151548
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1400792953
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 202942
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 155743
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 31,
            "name": "the GitOps repo push will fail after the version is committed",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:108"
            },
            "result": {
              "status": "passed",
              "duration": 413198
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 32,
            "name": "the GitOps update script runs",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:119"
            },
            "result": {
              "status": "passed",
              "duration": 186293271
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 33,
            "name": "the script exits with error",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:123"
            },
            "result": {
              "status": "passed",
              "duration": 242733
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 34,
            "name": "the GitOps repo commit shows a failure status linking to the caller commit",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:143"
            },
            "result": {
              "status": "passed",
              "duration": 46469125
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 581367537
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 54484225
            }
          }
        ],
        "tags": [
          {
            "name": "@mock",
            "line": 29
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "gitops-update;no-changes-—-gitops-repo-gets-\"no-change\"-status",
        "keyword": "Scenario",
        "line": 37,
        "name": "No changes — GitOps repo gets \"no change\" status",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1340866548
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1422634872
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a project repository exists in Gitea",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:29"
            },
            "result": {
              "status": "passed",
              "duration": 274950
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "a commit has been pushed to the repository",
            "match": {
              "location": "tests/features/step_definitions/common.steps.js:32"
            },
            "result": {
              "status": "passed",
              "duration": 200910
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 38,
            "name": "the version file already has the target version",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:112"
            },
            "result": {
              "status": "passed",
              "duration": 547082
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 39,
            "name": "the GitOps update script runs",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:119"
            },
            "result": {
              "status": "passed",
              "duration": 943371509
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 40,
            "name": "the script exits successfully",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:127"
            },
            "result": {
              "status": "passed",
              "duration": 207341
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 41,
            "name": "the GitOps repo commit shows a \"no change\" status",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:155"
            },
            "result": {
              "status": "passed",
              "duration": 57511027
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 42,
            "name": "no Git commit or push was performed",
            "match": {
              "location": "tests/features/step_definitions/gitops-update.steps.js:167"
            },
            "result": {
              "status": "passed",
              "duration": 19121233
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 583404903
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 58895746
            }
          }
        ],
        "tags": [
          {
            "name": "@mock",
            "line": 36
          }
        ],
        "type": "scenario"
      }
    ],
    "id": "gitops-update",
    "line": 1,
    "keyword": "Feature",
    "name": "GitOps update",
    "tags": [],
    "uri": "tests/features/gitops-update.feature"
  },
  {
    "description": "  As a test engineer\n  I want integration and end-to-end tests to run automatically after deployment\n  So that I can verify the deployed version works correctly",
    "elements": [
      {
        "description": "",
        "id": "test-execution;dispatch-a-test-workflow-and-wait-for-its-completion",
        "keyword": "Scenario",
        "line": 15,
        "name": "Dispatch a test workflow and wait for its completion",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1334599864
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1406648881
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a deployment has completed in the target environment",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:60"
            },
            "result": {
              "status": "passed",
              "duration": 389782
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "the test project repository exists with test definitions",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:63"
            },
            "result": {
              "status": "passed",
              "duration": 149863
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 16,
            "name": "a test workflow is dispatched to a test project",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:66"
            },
            "result": {
              "status": "passed",
              "duration": 1509363969
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 17,
            "name": "the pipeline waits until the test workflow finishes",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:76"
            },
            "result": {
              "status": "passed",
              "duration": 516777
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 18,
            "name": "the pipeline continues only after receiving a success result",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:80"
            },
            "result": {
              "status": "passed",
              "duration": 375357
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 606744599
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 89177560
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0002",
            "line": 14
          },
          {
            "name": "@mock",
            "line": 14
          },
          {
            "name": "@real",
            "line": 14
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "test-execution;dispatch-fails-when-the-dispatched-test-workflow-fails",
        "keyword": "Scenario",
        "line": 21,
        "name": "Dispatch fails when the dispatched test workflow fails",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1389688945
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1478796385
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a deployment has completed in the target environment",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:60"
            },
            "result": {
              "status": "passed",
              "duration": 168735
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "the test project repository exists with test definitions",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:63"
            },
            "result": {
              "status": "passed",
              "duration": 116158
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 22,
            "name": "a test workflow is dispatched and the tests fail",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:84"
            },
            "result": {
              "status": "passed",
              "duration": 1090633282
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 23,
            "name": "the calling pipeline reports failure",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:94"
            },
            "result": {
              "status": "passed",
              "duration": 1019317
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 590211027
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 82970854
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0002",
            "line": 20
          },
          {
            "name": "@mock",
            "line": 20
          },
          {
            "name": "@real",
            "line": 20
          }
        ],
        "type": "scenario"
      },
      {
        "description": "",
        "id": "test-execution;dispatch-times-out-when-the-test-workflow-takes-too-long",
        "keyword": "Scenario",
        "line": 26,
        "name": "Dispatch times out when the test workflow takes too long",
        "steps": [
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1387993859
            }
          },
          {
            "keyword": "Before",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 1424846456
            }
          },
          {
            "arguments": [],
            "keyword": "Given ",
            "line": 7,
            "name": "a deployment has completed in the target environment",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:60"
            },
            "result": {
              "status": "passed",
              "duration": 244278
            }
          },
          {
            "arguments": [],
            "keyword": "And ",
            "line": 8,
            "name": "the test project repository exists with test definitions",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:63"
            },
            "result": {
              "status": "passed",
              "duration": 152353
            }
          },
          {
            "arguments": [],
            "keyword": "When ",
            "line": 27,
            "name": "a test workflow is dispatched but does not finish within the allowed time",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:98"
            },
            "result": {
              "status": "passed",
              "duration": 3324430725
            }
          },
          {
            "arguments": [],
            "keyword": "Then ",
            "line": 28,
            "name": "the calling pipeline reports a timeout error",
            "match": {
              "location": "tests/features/step_definitions/test-execution.steps.js:112"
            },
            "result": {
              "status": "passed",
              "duration": 607654
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 576099356
            }
          },
          {
            "keyword": "After",
            "hidden": true,
            "result": {
              "status": "passed",
              "duration": 74074296
            }
          }
        ],
        "tags": [
          {
            "name": "@ticket-0002",
            "line": 25
          },
          {
            "name": "@mock",
            "line": 25
          }
        ],
        "type": "scenario"
      }
    ],
    "id": "test-execution",
    "line": 1,
    "keyword": "Feature",
    "name": "Test execution",
    "tags": [],
    "uri": "tests/features/test-execution.feature"
  }
]