@daghis/teamcity-mcp 0.9.1 → 0.9.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -0
- package/dist/index.js +1707 -16779
- package/dist/index.js.map +4 -4
- package/package.json +1 -1
- package/.commitlintrc.mjs +0 -25
- package/.eslintignore +0 -16
- package/.eslintrc.js +0 -166
- package/.github/dependabot.yml +0 -38
- package/.github/settings.yml +0 -7
- package/.github/workflows/ci.yml +0 -115
- package/.github/workflows/codeql.yml +0 -35
- package/.github/workflows/commitlint.yml +0 -20
- package/.github/workflows/publish.yml +0 -67
- package/.github/workflows/release-please.yml +0 -21
- package/.nvmrc +0 -1
- package/.prettierignore +0 -22
- package/.prettierrc +0 -28
- package/AGENTS.md +0 -129
- package/ARCHITECTURE.md +0 -66
- package/CONTRIBUTING.md +0 -68
- package/dist/src/api-client.d.ts +0 -51
- package/dist/src/api-client.d.ts.map +0 -1
- package/dist/src/config/index.d.ts +0 -41
- package/dist/src/config/index.d.ts.map +0 -1
- package/dist/src/errors/index.d.ts +0 -2
- package/dist/src/errors/index.d.ts.map +0 -1
- package/dist/src/formatters/build-step-formatter.d.ts +0 -5
- package/dist/src/formatters/build-step-formatter.d.ts.map +0 -1
- package/dist/src/formatters/trigger-formatter.d.ts +0 -4
- package/dist/src/formatters/trigger-formatter.d.ts.map +0 -1
- package/dist/src/index.d.ts +0 -2
- package/dist/src/index.d.ts.map +0 -1
- package/dist/src/middleware/error.d.ts +0 -56
- package/dist/src/middleware/error.d.ts.map +0 -1
- package/dist/src/middleware/global-error-handler.d.ts +0 -22
- package/dist/src/middleware/global-error-handler.d.ts.map +0 -1
- package/dist/src/middleware/index.d.ts +0 -2
- package/dist/src/middleware/index.d.ts.map +0 -1
- package/dist/src/server.d.ts +0 -4
- package/dist/src/server.d.ts.map +0 -1
- package/dist/src/swagger/index.d.ts +0 -43
- package/dist/src/swagger/index.d.ts.map +0 -1
- package/dist/src/swagger/swagger-cache.d.ts +0 -23
- package/dist/src/swagger/swagger-cache.d.ts.map +0 -1
- package/dist/src/swagger/swagger-fetcher.d.ts +0 -24
- package/dist/src/swagger/swagger-fetcher.d.ts.map +0 -1
- package/dist/src/swagger/swagger-validator.d.ts +0 -17
- package/dist/src/swagger/swagger-validator.d.ts.map +0 -1
- package/dist/src/teamcity/api-types.d.ts +0 -224
- package/dist/src/teamcity/api-types.d.ts.map +0 -1
- package/dist/src/teamcity/artifact-manager.d.ts +0 -52
- package/dist/src/teamcity/artifact-manager.d.ts.map +0 -1
- package/dist/src/teamcity/auth.d.ts +0 -22
- package/dist/src/teamcity/auth.d.ts.map +0 -1
- package/dist/src/teamcity/branch-discovery-manager.d.ts +0 -39
- package/dist/src/teamcity/branch-discovery-manager.d.ts.map +0 -1
- package/dist/src/teamcity/branch-filtering-service.d.ts +0 -62
- package/dist/src/teamcity/branch-filtering-service.d.ts.map +0 -1
- package/dist/src/teamcity/branch-specification-parser.d.ts +0 -33
- package/dist/src/teamcity/branch-specification-parser.d.ts.map +0 -1
- package/dist/src/teamcity/build-config-manager.d.ts +0 -75
- package/dist/src/teamcity/build-config-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-config-navigator.d.ts +0 -89
- package/dist/src/teamcity/build-config-navigator.d.ts.map +0 -1
- package/dist/src/teamcity/build-configuration-clone-manager.d.ts +0 -49
- package/dist/src/teamcity/build-configuration-clone-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-configuration-manager.d.ts +0 -82
- package/dist/src/teamcity/build-configuration-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-configuration-resolver.d.ts +0 -95
- package/dist/src/teamcity/build-configuration-resolver.d.ts.map +0 -1
- package/dist/src/teamcity/build-configuration-update-manager.d.ts +0 -76
- package/dist/src/teamcity/build-configuration-update-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-list-manager.d.ts +0 -62
- package/dist/src/teamcity/build-list-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-parameters-manager.d.ts +0 -143
- package/dist/src/teamcity/build-parameters-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-progress-tracker.d.ts +0 -49
- package/dist/src/teamcity/build-progress-tracker.d.ts.map +0 -1
- package/dist/src/teamcity/build-query-builder.d.ts +0 -27
- package/dist/src/teamcity/build-query-builder.d.ts.map +0 -1
- package/dist/src/teamcity/build-queue-manager.d.ts +0 -102
- package/dist/src/teamcity/build-queue-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-results-manager.d.ts +0 -87
- package/dist/src/teamcity/build-results-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-status-manager.d.ts +0 -65
- package/dist/src/teamcity/build-status-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-step-manager.d.ts +0 -65
- package/dist/src/teamcity/build-step-manager.d.ts.map +0 -1
- package/dist/src/teamcity/build-trigger-manager.d.ts +0 -108
- package/dist/src/teamcity/build-trigger-manager.d.ts.map +0 -1
- package/dist/src/teamcity/circuit-breaker.d.ts +0 -47
- package/dist/src/teamcity/circuit-breaker.d.ts.map +0 -1
- package/dist/src/teamcity/client-adapter.d.ts +0 -12
- package/dist/src/teamcity/client-adapter.d.ts.map +0 -1
- package/dist/src/teamcity/client.d.ts +0 -49
- package/dist/src/teamcity/client.d.ts.map +0 -1
- package/dist/src/teamcity/config.d.ts +0 -41
- package/dist/src/teamcity/config.d.ts.map +0 -1
- package/dist/src/teamcity/configuration-branch-matcher.d.ts +0 -37
- package/dist/src/teamcity/configuration-branch-matcher.d.ts.map +0 -1
- package/dist/src/teamcity/errors.d.ts +0 -79
- package/dist/src/teamcity/errors.d.ts.map +0 -1
- package/dist/src/teamcity/index.d.ts +0 -48
- package/dist/src/teamcity/index.d.ts.map +0 -1
- package/dist/src/teamcity/pagination.d.ts +0 -32
- package/dist/src/teamcity/pagination.d.ts.map +0 -1
- package/dist/src/teamcity/project-list-manager.d.ts +0 -19
- package/dist/src/teamcity/project-list-manager.d.ts.map +0 -1
- package/dist/src/teamcity/project-manager.d.ts +0 -73
- package/dist/src/teamcity/project-manager.d.ts.map +0 -1
- package/dist/src/teamcity/project-navigator.d.ts +0 -100
- package/dist/src/teamcity/project-navigator.d.ts.map +0 -1
- package/dist/src/teamcity/test-problem-reporter.d.ts +0 -60
- package/dist/src/teamcity/test-problem-reporter.d.ts.map +0 -1
- package/dist/src/teamcity/types/api-responses.d.ts +0 -235
- package/dist/src/teamcity/types/api-responses.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/agent-api.d.ts +0 -97
- package/dist/src/teamcity-client/api/agent-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/agent-pool-api.d.ts +0 -92
- package/dist/src/teamcity-client/api/agent-pool-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/agent-type-api.d.ts +0 -20
- package/dist/src/teamcity-client/api/agent-type-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/audit-api.d.ts +0 -26
- package/dist/src/teamcity-client/api/audit-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/avatar-api.d.ts +0 -34
- package/dist/src/teamcity-client/api/avatar-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/build-api.d.ts +0 -315
- package/dist/src/teamcity-client/api/build-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/build-queue-api.d.ts +0 -90
- package/dist/src/teamcity-client/api/build-queue-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/build-type-api.d.ts +0 -585
- package/dist/src/teamcity-client/api/build-type-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/change-api.d.ts +0 -71
- package/dist/src/teamcity-client/api/change-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/cloud-instance-api.d.ts +0 -70
- package/dist/src/teamcity-client/api/cloud-instance-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/deployment-dashboard-api.d.ts +0 -64
- package/dist/src/teamcity-client/api/deployment-dashboard-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/global-server-settings-api.d.ts +0 -25
- package/dist/src/teamcity-client/api/global-server-settings-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/group-api.d.ts +0 -99
- package/dist/src/teamcity-client/api/group-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/health-api.d.ts +0 -38
- package/dist/src/teamcity-client/api/health-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/investigation-api.d.ts +0 -46
- package/dist/src/teamcity-client/api/investigation-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/mute-api.d.ts +0 -46
- package/dist/src/teamcity-client/api/mute-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/node-api.d.ts +0 -49
- package/dist/src/teamcity-client/api/node-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/problem-api.d.ts +0 -26
- package/dist/src/teamcity-client/api/problem-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/problem-occurrence-api.d.ts +0 -26
- package/dist/src/teamcity-client/api/problem-occurrence-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/project-api.d.ts +0 -271
- package/dist/src/teamcity-client/api/project-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/role-api.d.ts +0 -56
- package/dist/src/teamcity-client/api/role-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/root-api.d.ts +0 -35
- package/dist/src/teamcity-client/api/root-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/server-api.d.ts +0 -112
- package/dist/src/teamcity-client/api/server-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/server-authentication-settings-api.d.ts +0 -25
- package/dist/src/teamcity-client/api/server-authentication-settings-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/test-api.d.ts +0 -26
- package/dist/src/teamcity-client/api/test-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/test-occurrence-api.d.ts +0 -26
- package/dist/src/teamcity-client/api/test-occurrence-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/user-api.d.ts +0 -164
- package/dist/src/teamcity-client/api/user-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/vcs-root-api.d.ts +0 -88
- package/dist/src/teamcity-client/api/vcs-root-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/vcs-root-instance-api.d.ts +0 -104
- package/dist/src/teamcity-client/api/vcs-root-instance-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api/versioned-settings-api.d.ts +0 -94
- package/dist/src/teamcity-client/api/versioned-settings-api.d.ts.map +0 -1
- package/dist/src/teamcity-client/api.d.ts +0 -31
- package/dist/src/teamcity-client/api.d.ts.map +0 -1
- package/dist/src/teamcity-client/base.d.ts +0 -32
- package/dist/src/teamcity-client/base.d.ts.map +0 -1
- package/dist/src/teamcity-client/common.d.ts +0 -14
- package/dist/src/teamcity-client/common.d.ts.map +0 -1
- package/dist/src/teamcity-client/configuration.d.ts +0 -23
- package/dist/src/teamcity-client/configuration.d.ts.map +0 -1
- package/dist/src/teamcity-client/index.d.ts +0 -4
- package/dist/src/teamcity-client/index.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-locator.d.ts +0 -34
- package/dist/src/teamcity-client/models/agent-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-pool-locator.d.ts +0 -10
- package/dist/src/teamcity-client/models/agent-pool-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-pool.d.ts +0 -16
- package/dist/src/teamcity-client/models/agent-pool.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-pools.d.ts +0 -9
- package/dist/src/teamcity-client/models/agent-pools.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-requirement.d.ts +0 -11
- package/dist/src/teamcity-client/models/agent-requirement.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-requirements.d.ts +0 -6
- package/dist/src/teamcity-client/models/agent-requirements.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-type-locator.d.ts +0 -8
- package/dist/src/teamcity-client/models/agent-type-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-type.d.ts +0 -14
- package/dist/src/teamcity-client/models/agent-type.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent-types.d.ts +0 -9
- package/dist/src/teamcity-client/models/agent-types.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agent.d.ts +0 -59
- package/dist/src/teamcity-client/models/agent.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/agents.d.ts +0 -9
- package/dist/src/teamcity-client/models/agents.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/approvable-build.d.ts +0 -6
- package/dist/src/teamcity-client/models/approvable-build.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/approval-info.d.ts +0 -24
- package/dist/src/teamcity-client/models/approval-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/artifact-dependencies.d.ts +0 -7
- package/dist/src/teamcity-client/models/artifact-dependencies.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/artifact-dependency.d.ts +0 -13
- package/dist/src/teamcity-client/models/artifact-dependency.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/artifact-download-info.d.ts +0 -5
- package/dist/src/teamcity-client/models/artifact-download-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/audit-action.d.ts +0 -6
- package/dist/src/teamcity-client/models/audit-action.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/audit-event.d.ts +0 -12
- package/dist/src/teamcity-client/models/audit-event.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/audit-events.d.ts +0 -9
- package/dist/src/teamcity-client/models/audit-events.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/audit-locator.d.ts +0 -245
- package/dist/src/teamcity-client/models/audit-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/auth-module.d.ts +0 -6
- package/dist/src/teamcity-client/models/auth-module.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/auth-modules.d.ts +0 -5
- package/dist/src/teamcity-client/models/auth-modules.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/authorization-tokens-requirements.d.ts +0 -5
- package/dist/src/teamcity-client/models/authorization-tokens-requirements.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/authorized-info.d.ts +0 -6
- package/dist/src/teamcity-client/models/authorized-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/branch-locator.d.ts +0 -40
- package/dist/src/teamcity-client/models/branch-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/branch-version.d.ts +0 -13
- package/dist/src/teamcity-client/models/branch-version.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/branch.d.ts +0 -12
- package/dist/src/teamcity-client/models/branch.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/branches.d.ts +0 -7
- package/dist/src/teamcity-client/models/branches.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-cancel-request.d.ts +0 -5
- package/dist/src/teamcity-client/models/build-cancel-request.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-change.d.ts +0 -6
- package/dist/src/teamcity-client/models/build-change.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-changes.d.ts +0 -6
- package/dist/src/teamcity-client/models/build-changes.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-executor.d.ts +0 -4
- package/dist/src/teamcity-client/models/build-executor.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-locator.d.ts +0 -69
- package/dist/src/teamcity-client/models/build-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-queue-locator.d.ts +0 -14
- package/dist/src/teamcity-client/models/build-queue-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-status-update.d.ts +0 -5
- package/dist/src/teamcity-client/models/build-status-update.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-trigger-customization.d.ts +0 -7
- package/dist/src/teamcity-client/models/build-trigger-customization.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-triggering-options.d.ts +0 -12
- package/dist/src/teamcity-client/models/build-triggering-options.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-type-locator.d.ts +0 -18
- package/dist/src/teamcity-client/models/build-type-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-type.d.ts +0 -64
- package/dist/src/teamcity-client/models/build-type.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build-types.d.ts +0 -9
- package/dist/src/teamcity-client/models/build-types.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/build.d.ts +0 -127
- package/dist/src/teamcity-client/models/build.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/builds-with-reason.d.ts +0 -6
- package/dist/src/teamcity-client/models/builds-with-reason.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/builds.d.ts +0 -9
- package/dist/src/teamcity-client/models/builds.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/change-locator.d.ts +0 -21
- package/dist/src/teamcity-client/models/change-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/change-status.d.ts +0 -19
- package/dist/src/teamcity-client/models/change-status.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/change.d.ts +0 -35
- package/dist/src/teamcity-client/models/change.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/changes.d.ts +0 -9
- package/dist/src/teamcity-client/models/changes.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cleanup.d.ts +0 -9
- package/dist/src/teamcity-client/models/cleanup.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-error.d.ts +0 -5
- package/dist/src/teamcity-client/models/cloud-error.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-image-locator.d.ts +0 -17
- package/dist/src/teamcity-client/models/cloud-image-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-image.d.ts +0 -18
- package/dist/src/teamcity-client/models/cloud-image.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-images.d.ts +0 -9
- package/dist/src/teamcity-client/models/cloud-images.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-instance-locator.d.ts +0 -13
- package/dist/src/teamcity-client/models/cloud-instance-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-instance.d.ts +0 -16
- package/dist/src/teamcity-client/models/cloud-instance.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-instances.d.ts +0 -9
- package/dist/src/teamcity-client/models/cloud-instances.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-profile-locator.d.ts +0 -13
- package/dist/src/teamcity-client/models/cloud-profile-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-profile.d.ts +0 -13
- package/dist/src/teamcity-client/models/cloud-profile.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cloud-profiles.d.ts +0 -9
- package/dist/src/teamcity-client/models/cloud-profiles.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/comment.d.ts +0 -7
- package/dist/src/teamcity-client/models/comment.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/commiter.d.ts +0 -6
- package/dist/src/teamcity-client/models/commiter.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/compatibilities.d.ts +0 -6
- package/dist/src/teamcity-client/models/compatibilities.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/compatibility-policy.d.ts +0 -6
- package/dist/src/teamcity-client/models/compatibility-policy.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/compatibility.d.ts +0 -10
- package/dist/src/teamcity-client/models/compatibility.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/composite-approval-rule.d.ts +0 -10
- package/dist/src/teamcity-client/models/composite-approval-rule.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/composite-approvals.d.ts +0 -6
- package/dist/src/teamcity-client/models/composite-approvals.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/cron.d.ts +0 -8
- package/dist/src/teamcity-client/models/cron.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/customizations.d.ts +0 -15
- package/dist/src/teamcity-client/models/customizations.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/daily.d.ts +0 -5
- package/dist/src/teamcity-client/models/daily.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/datas.d.ts +0 -6
- package/dist/src/teamcity-client/models/datas.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-dashboard-locator.d.ts +0 -9
- package/dist/src/teamcity-client/models/deployment-dashboard-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-dashboard.d.ts +0 -9
- package/dist/src/teamcity-client/models/deployment-dashboard.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-dashboards.d.ts +0 -9
- package/dist/src/teamcity-client/models/deployment-dashboards.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-history.d.ts +0 -6
- package/dist/src/teamcity-client/models/deployment-history.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-instance-locator.d.ts +0 -16
- package/dist/src/teamcity-client/models/deployment-instance-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-instance.d.ts +0 -20
- package/dist/src/teamcity-client/models/deployment-instance.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-instances.d.ts +0 -9
- package/dist/src/teamcity-client/models/deployment-instances.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-state-entries.d.ts +0 -8
- package/dist/src/teamcity-client/models/deployment-state-entries.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/deployment-state-entry.d.ts +0 -16
- package/dist/src/teamcity-client/models/deployment-state-entry.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/disabled-responsibilities.d.ts +0 -6
- package/dist/src/teamcity-client/models/disabled-responsibilities.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/download-info.d.ts +0 -8
- package/dist/src/teamcity-client/models/download-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/downloaded-artifacts.d.ts +0 -7
- package/dist/src/teamcity-client/models/downloaded-artifacts.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/effective-responsibilities.d.ts +0 -6
- package/dist/src/teamcity-client/models/effective-responsibilities.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/enabled-info.d.ts +0 -7
- package/dist/src/teamcity-client/models/enabled-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/enabled-responsibilities.d.ts +0 -6
- package/dist/src/teamcity-client/models/enabled-responsibilities.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/entries.d.ts +0 -6
- package/dist/src/teamcity-client/models/entries.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/entry.d.ts +0 -5
- package/dist/src/teamcity-client/models/entry.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/environment.d.ts +0 -5
- package/dist/src/teamcity-client/models/environment.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/feature.d.ts +0 -11
- package/dist/src/teamcity-client/models/feature.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/features.d.ts +0 -6
- package/dist/src/teamcity-client/models/features.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/file-change.d.ts +0 -10
- package/dist/src/teamcity-client/models/file-change.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/file-changes.d.ts +0 -6
- package/dist/src/teamcity-client/models/file-changes.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/files.d.ts +0 -6
- package/dist/src/teamcity-client/models/files.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/group-approval-rule.d.ts +0 -8
- package/dist/src/teamcity-client/models/group-approval-rule.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/group-approvals.d.ts +0 -6
- package/dist/src/teamcity-client/models/group-approvals.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/group.d.ts +0 -16
- package/dist/src/teamcity-client/models/group.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/groups.d.ts +0 -6
- package/dist/src/teamcity-client/models/groups.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/health-categories.d.ts +0 -9
- package/dist/src/teamcity-client/models/health-categories.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/health-category.d.ts +0 -7
- package/dist/src/teamcity-client/models/health-category.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/health-item.d.ts +0 -13
- package/dist/src/teamcity-client/models/health-item.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/health-status-items.d.ts +0 -9
- package/dist/src/teamcity-client/models/health-status-items.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/href.d.ts +0 -4
- package/dist/src/teamcity-client/models/href.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/index.d.ts +0 -230
- package/dist/src/teamcity-client/models/index.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/investigation-locator.d.ts +0 -35
- package/dist/src/teamcity-client/models/investigation-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/investigation.d.ts +0 -24
- package/dist/src/teamcity-client/models/investigation.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/investigations.d.ts +0 -9
- package/dist/src/teamcity-client/models/investigations.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/issue-usage.d.ts +0 -7
- package/dist/src/teamcity-client/models/issue-usage.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/issue.d.ts +0 -5
- package/dist/src/teamcity-client/models/issue.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/issues-usages.d.ts +0 -7
- package/dist/src/teamcity-client/models/issues-usages.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/issues.d.ts +0 -5
- package/dist/src/teamcity-client/models/issues.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/items.d.ts +0 -4
- package/dist/src/teamcity-client/models/items.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/labeled-value.d.ts +0 -5
- package/dist/src/teamcity-client/models/labeled-value.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/license-key.d.ts +0 -29
- package/dist/src/teamcity-client/models/license-key.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/license-keys.d.ts +0 -7
- package/dist/src/teamcity-client/models/license-keys.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/licensing-data.d.ts +0 -26
- package/dist/src/teamcity-client/models/licensing-data.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/link.d.ts +0 -6
- package/dist/src/teamcity-client/models/link.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/links.d.ts +0 -6
- package/dist/src/teamcity-client/models/links.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/matrix-build-feature-descriptor.d.ts +0 -8
- package/dist/src/teamcity-client/models/matrix-build-feature-descriptor.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/matrix-configuration.d.ts +0 -9
- package/dist/src/teamcity-client/models/matrix-configuration.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/matrix-dependencies.d.ts +0 -6
- package/dist/src/teamcity-client/models/matrix-dependencies.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/matrix-dependency.d.ts +0 -7
- package/dist/src/teamcity-client/models/matrix-dependency.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/matrix-parameter-descriptor.d.ts +0 -7
- package/dist/src/teamcity-client/models/matrix-parameter-descriptor.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/meta-data.d.ts +0 -6
- package/dist/src/teamcity-client/models/meta-data.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/metric-tag.d.ts +0 -5
- package/dist/src/teamcity-client/models/metric-tag.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/metric-tags.d.ts +0 -6
- package/dist/src/teamcity-client/models/metric-tags.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/metric-value.d.ts +0 -7
- package/dist/src/teamcity-client/models/metric-value.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/metric-values.d.ts +0 -6
- package/dist/src/teamcity-client/models/metric-values.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/metric.d.ts +0 -10
- package/dist/src/teamcity-client/models/metric.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/metrics.d.ts +0 -6
- package/dist/src/teamcity-client/models/metrics.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/model-file.d.ts +0 -13
- package/dist/src/teamcity-client/models/model-file.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/multiple-operation-result.d.ts +0 -7
- package/dist/src/teamcity-client/models/multiple-operation-result.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/mute-locator.d.ts +0 -26
- package/dist/src/teamcity-client/models/mute-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/mute.d.ts +0 -13
- package/dist/src/teamcity-client/models/mute.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/mutes.d.ts +0 -9
- package/dist/src/teamcity-client/models/mutes.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/new-build-type-description.d.ts +0 -13
- package/dist/src/teamcity-client/models/new-build-type-description.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/new-project-description.d.ts +0 -15
- package/dist/src/teamcity-client/models/new-project-description.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/node.d.ts +0 -21
- package/dist/src/teamcity-client/models/node.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/nodes.d.ts +0 -6
- package/dist/src/teamcity-client/models/nodes.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/operation-result.d.ts +0 -6
- package/dist/src/teamcity-client/models/operation-result.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/parsed-test-name.d.ts +0 -10
- package/dist/src/teamcity-client/models/parsed-test-name.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/permission-assignment.d.ts +0 -8
- package/dist/src/teamcity-client/models/permission-assignment.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/permission-assignments.d.ts +0 -6
- package/dist/src/teamcity-client/models/permission-assignments.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/permission-restriction.d.ts +0 -8
- package/dist/src/teamcity-client/models/permission-restriction.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/permission-restrictions.d.ts +0 -6
- package/dist/src/teamcity-client/models/permission-restrictions.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/permission.d.ts +0 -6
- package/dist/src/teamcity-client/models/permission.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/permissions.d.ts +0 -6
- package/dist/src/teamcity-client/models/permissions.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/pin-info.d.ts +0 -6
- package/dist/src/teamcity-client/models/pin-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/plugin.d.ts +0 -9
- package/dist/src/teamcity-client/models/plugin.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/plugins.d.ts +0 -6
- package/dist/src/teamcity-client/models/plugins.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem-locator.d.ts +0 -15
- package/dist/src/teamcity-client/models/problem-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem-occurrence-locator.d.ts +0 -16
- package/dist/src/teamcity-client/models/problem-occurrence-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem-occurrence.d.ts +0 -20
- package/dist/src/teamcity-client/models/problem-occurrence.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem-occurrences.d.ts +0 -14
- package/dist/src/teamcity-client/models/problem-occurrences.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem-scope.d.ts +0 -9
- package/dist/src/teamcity-client/models/problem-scope.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem-target.d.ts +0 -8
- package/dist/src/teamcity-client/models/problem-target.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problem.d.ts +0 -15
- package/dist/src/teamcity-client/models/problem.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/problems.d.ts +0 -8
- package/dist/src/teamcity-client/models/problems.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/progress-info.d.ts +0 -13
- package/dist/src/teamcity-client/models/progress-info.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/project-feature.d.ts +0 -11
- package/dist/src/teamcity-client/models/project-feature.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/project-features.d.ts +0 -7
- package/dist/src/teamcity-client/models/project-features.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/project-locator.d.ts +0 -20
- package/dist/src/teamcity-client/models/project-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/project.d.ts +0 -39
- package/dist/src/teamcity-client/models/project.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/projects.d.ts +0 -9
- package/dist/src/teamcity-client/models/projects.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/properties.d.ts +0 -7
- package/dist/src/teamcity-client/models/properties.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/property.d.ts +0 -8
- package/dist/src/teamcity-client/models/property.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/related-entities.d.ts +0 -6
- package/dist/src/teamcity-client/models/related-entities.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/related-entity.d.ts +0 -29
- package/dist/src/teamcity-client/models/related-entity.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/related.d.ts +0 -5
- package/dist/src/teamcity-client/models/related.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/repository-state.d.ts +0 -7
- package/dist/src/teamcity-client/models/repository-state.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/requirements.d.ts +0 -4
- package/dist/src/teamcity-client/models/requirements.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/resolution.d.ts +0 -11
- package/dist/src/teamcity-client/models/resolution.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/responsibility.d.ts +0 -5
- package/dist/src/teamcity-client/models/responsibility.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/revision.d.ts +0 -9
- package/dist/src/teamcity-client/models/revision.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/revisions.d.ts +0 -7
- package/dist/src/teamcity-client/models/revisions.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/role.d.ts +0 -6
- package/dist/src/teamcity-client/models/role.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/roles.d.ts +0 -5
- package/dist/src/teamcity-client/models/roles.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/server-auth-settings.d.ts +0 -12
- package/dist/src/teamcity-client/models/server-auth-settings.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/server-global-settings.d.ts +0 -15
- package/dist/src/teamcity-client/models/server-global-settings.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/server.d.ts +0 -26
- package/dist/src/teamcity-client/models/server.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/snapshot-dependencies.d.ts +0 -6
- package/dist/src/teamcity-client/models/snapshot-dependencies.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/snapshot-dependency-link.d.ts +0 -8
- package/dist/src/teamcity-client/models/snapshot-dependency-link.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/snapshot-dependency.d.ts +0 -13
- package/dist/src/teamcity-client/models/snapshot-dependency.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/state-field.d.ts +0 -5
- package/dist/src/teamcity-client/models/state-field.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/step.d.ts +0 -12
- package/dist/src/teamcity-client/models/step.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/steps.d.ts +0 -6
- package/dist/src/teamcity-client/models/steps.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/tag-locator.d.ts +0 -6
- package/dist/src/teamcity-client/models/tag-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/tag.d.ts +0 -7
- package/dist/src/teamcity-client/models/tag.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/tags.d.ts +0 -6
- package/dist/src/teamcity-client/models/tags.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/team-city-node-locator.d.ts +0 -6
- package/dist/src/teamcity-client/models/team-city-node-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/test-counters.d.ts +0 -10
- package/dist/src/teamcity-client/models/test-counters.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/test-locator.d.ts +0 -14
- package/dist/src/teamcity-client/models/test-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/test-occurrence-locator.d.ts +0 -31
- package/dist/src/teamcity-client/models/test-occurrence-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/test-occurrence.d.ts +0 -37
- package/dist/src/teamcity-client/models/test-occurrence.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/test-occurrences.d.ts +0 -16
- package/dist/src/teamcity-client/models/test-occurrences.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/test-run-metadata.d.ts +0 -6
- package/dist/src/teamcity-client/models/test-run-metadata.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/tests.d.ts +0 -10
- package/dist/src/teamcity-client/models/tests.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/token.d.ts +0 -9
- package/dist/src/teamcity-client/models/token.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/tokens.d.ts +0 -6
- package/dist/src/teamcity-client/models/tokens.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/trigger.d.ts +0 -13
- package/dist/src/teamcity-client/models/trigger.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/triggered-by.d.ts +0 -16
- package/dist/src/teamcity-client/models/triggered-by.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/triggers.d.ts +0 -6
- package/dist/src/teamcity-client/models/triggers.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/type.d.ts +0 -4
- package/dist/src/teamcity-client/models/type.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/typed-value-set.d.ts +0 -10
- package/dist/src/teamcity-client/models/typed-value-set.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/typed-value-sets.d.ts +0 -6
- package/dist/src/teamcity-client/models/typed-value-sets.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/typed-value.d.ts +0 -6
- package/dist/src/teamcity-client/models/typed-value.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/user-approval-rule.d.ts +0 -6
- package/dist/src/teamcity-client/models/user-approval-rule.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/user-approvals.d.ts +0 -6
- package/dist/src/teamcity-client/models/user-approvals.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/user-avatars.d.ts +0 -10
- package/dist/src/teamcity-client/models/user-avatars.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/user-group-locator.d.ts +0 -6
- package/dist/src/teamcity-client/models/user-group-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/user-locator.d.ts +0 -15
- package/dist/src/teamcity-client/models/user-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/user.d.ts +0 -22
- package/dist/src/teamcity-client/models/user.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/users.d.ts +0 -6
- package/dist/src/teamcity-client/models/users.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-check-status.d.ts +0 -6
- package/dist/src/teamcity-client/models/vcs-check-status.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-label.d.ts +0 -18
- package/dist/src/teamcity-client/models/vcs-label.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-labels.d.ts +0 -6
- package/dist/src/teamcity-client/models/vcs-labels.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root-entries.d.ts +0 -6
- package/dist/src/teamcity-client/models/vcs-root-entries.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root-entry.d.ts +0 -8
- package/dist/src/teamcity-client/models/vcs-root-entry.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root-instance-locator.d.ts +0 -38
- package/dist/src/teamcity-client/models/vcs-root-instance-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root-instance.d.ts +0 -24
- package/dist/src/teamcity-client/models/vcs-root-instance.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root-instances.d.ts +0 -9
- package/dist/src/teamcity-client/models/vcs-root-instances.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root-locator.d.ts +0 -37
- package/dist/src/teamcity-client/models/vcs-root-locator.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-root.d.ts +0 -20
- package/dist/src/teamcity-client/models/vcs-root.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-roots.d.ts +0 -9
- package/dist/src/teamcity-client/models/vcs-roots.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/vcs-status.d.ts +0 -6
- package/dist/src/teamcity-client/models/vcs-status.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-config.d.ts +0 -31
- package/dist/src/teamcity-client/models/versioned-settings-config.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-context-parameter.d.ts +0 -5
- package/dist/src/teamcity-client/models/versioned-settings-context-parameter.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-context-parameters.d.ts +0 -5
- package/dist/src/teamcity-client/models/versioned-settings-context-parameters.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-error.d.ts +0 -7
- package/dist/src/teamcity-client/models/versioned-settings-error.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-status.d.ts +0 -15
- package/dist/src/teamcity-client/models/versioned-settings-status.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-token.d.ts +0 -6
- package/dist/src/teamcity-client/models/versioned-settings-token.d.ts.map +0 -1
- package/dist/src/teamcity-client/models/versioned-settings-tokens.d.ts +0 -5
- package/dist/src/teamcity-client/models/versioned-settings-tokens.d.ts.map +0 -1
- package/dist/src/tools/index.d.ts +0 -2
- package/dist/src/tools/index.d.ts.map +0 -1
- package/dist/src/tools.d.ts +0 -22
- package/dist/src/tools.d.ts.map +0 -1
- package/dist/src/types/config.d.ts +0 -129
- package/dist/src/types/config.d.ts.map +0 -1
- package/dist/src/types/index.d.ts +0 -116
- package/dist/src/types/index.d.ts.map +0 -1
- package/dist/src/types/mcp.d.ts +0 -68
- package/dist/src/types/mcp.d.ts.map +0 -1
- package/dist/src/types/project.d.ts +0 -56
- package/dist/src/types/project.d.ts.map +0 -1
- package/dist/src/types/teamcity.d.ts +0 -258
- package/dist/src/types/teamcity.d.ts.map +0 -1
- package/dist/src/utils/async/index.d.ts +0 -90
- package/dist/src/utils/async/index.d.ts.map +0 -1
- package/dist/src/utils/error-logger.d.ts +0 -34
- package/dist/src/utils/error-logger.d.ts.map +0 -1
- package/dist/src/utils/index.d.ts +0 -23
- package/dist/src/utils/index.d.ts.map +0 -1
- package/dist/src/utils/logger/index.d.ts +0 -73
- package/dist/src/utils/logger/index.d.ts.map +0 -1
- package/dist/src/utils/logger.d.ts +0 -11
- package/dist/src/utils/logger.d.ts.map +0 -1
- package/dist/src/utils/lru-cache.d.ts +0 -20
- package/dist/src/utils/lru-cache.d.ts.map +0 -1
- package/dist/src/utils/mcp.d.ts +0 -18
- package/dist/src/utils/mcp.d.ts.map +0 -1
- package/dist/src/utils/validation.d.ts +0 -61
- package/dist/src/utils/validation.d.ts.map +0 -1
- package/docs/TEAMCITY_MCP_TOOLS_GUIDE.md +0 -1076
- package/docs/mcp-tools-mode-matrix.md +0 -68
- package/docs/mcp-tools-reference.md +0 -203
- package/examples/list-build-configs-usage.ts +0 -276
- package/jest.ci.config.js +0 -14
- package/jest.config.js +0 -108
- package/jest.setup.js +0 -24
- package/openapi-generator-config.json +0 -27
- package/openapitools.json +0 -7
- package/scripts/build.cjs +0 -106
- package/scripts/debug-fetch-log.ts +0 -52
- package/scripts/emit-coverage-stats.js +0 -42
- package/scripts/fetch-swagger-spec.ts +0 -140
- package/scripts/generate-third-party-notices.cjs +0 -71
- package/scripts/interact.sh +0 -23
- package/scripts/print-builds.ts +0 -21
- package/scripts/verify-integration-env.cjs +0 -29
- package/src/api-client.ts +0 -307
- package/src/config/index.ts +0 -286
- package/src/errors/index.ts +0 -25
- package/src/formatters/build-step-formatter.ts +0 -178
- package/src/formatters/trigger-formatter.ts +0 -207
- package/src/index.ts +0 -60
- package/src/middleware/error.test.ts +0 -274
- package/src/middleware/error.ts +0 -314
- package/src/middleware/global-error-handler.test.ts +0 -239
- package/src/middleware/global-error-handler.ts +0 -214
- package/src/middleware/index.ts +0 -5
- package/src/server.ts +0 -126
- package/src/swagger/index.ts +0 -220
- package/src/swagger/swagger-cache.ts +0 -220
- package/src/swagger/swagger-fetcher.ts +0 -126
- package/src/swagger/swagger-validator.ts +0 -212
- package/src/teamcity/api-types.ts +0 -387
- package/src/teamcity/artifact-manager.ts +0 -362
- package/src/teamcity/auth.ts +0 -219
- package/src/teamcity/branch-discovery-manager.ts +0 -311
- package/src/teamcity/branch-filtering-service.ts +0 -369
- package/src/teamcity/branch-specification-parser.ts +0 -238
- package/src/teamcity/build-config-manager.ts +0 -458
- package/src/teamcity/build-config-navigator.ts +0 -589
- package/src/teamcity/build-configuration-clone-manager.ts +0 -501
- package/src/teamcity/build-configuration-manager.ts +0 -447
- package/src/teamcity/build-configuration-resolver.ts +0 -725
- package/src/teamcity/build-configuration-update-manager.ts +0 -610
- package/src/teamcity/build-list-manager.ts +0 -313
- package/src/teamcity/build-parameters-manager.ts +0 -875
- package/src/teamcity/build-progress-tracker.ts +0 -514
- package/src/teamcity/build-query-builder.ts +0 -325
- package/src/teamcity/build-queue-manager.ts +0 -622
- package/src/teamcity/build-results-manager.ts +0 -589
- package/src/teamcity/build-status-manager.ts +0 -564
- package/src/teamcity/build-step-manager.ts +0 -508
- package/src/teamcity/build-trigger-manager.ts +0 -1083
- package/src/teamcity/circuit-breaker.ts +0 -219
- package/src/teamcity/client-adapter.ts +0 -35
- package/src/teamcity/client.ts +0 -269
- package/src/teamcity/config.ts +0 -188
- package/src/teamcity/configuration-branch-matcher.ts +0 -327
- package/src/teamcity/errors.ts +0 -351
- package/src/teamcity/index.ts +0 -266
- package/src/teamcity/pagination.ts +0 -209
- package/src/teamcity/project-list-manager.ts +0 -267
- package/src/teamcity/project-manager.ts +0 -493
- package/src/teamcity/project-navigator.ts +0 -664
- package/src/teamcity/test-problem-reporter.ts +0 -423
- package/src/teamcity/types/api-responses.ts +0 -314
- package/src/teamcity-client/.openapi-generator/FILES +0 -274
- package/src/teamcity-client/.openapi-generator/VERSION +0 -1
- package/src/teamcity-client/.openapi-generator-ignore +0 -23
- package/src/teamcity-client/README.md +0 -50
- package/src/teamcity-client/api/agent-api.ts +0 -2046
- package/src/teamcity-client/api/agent-pool-api.ts +0 -1877
- package/src/teamcity-client/api/agent-type-api.ts +0 -213
- package/src/teamcity-client/api/audit-api.ts +0 -341
- package/src/teamcity-client/api/avatar-api.ts +0 -569
- package/src/teamcity-client/api/build-api.ts +0 -7726
- package/src/teamcity-client/api/build-queue-api.ts +0 -1922
- package/src/teamcity-client/api/build-type-api.ts +0 -15502
- package/src/teamcity-client/api/change-api.ts +0 -1311
- package/src/teamcity-client/api/cloud-instance-api.ts +0 -1289
- package/src/teamcity-client/api/deployment-dashboard-api.ts +0 -1295
- package/src/teamcity-client/api/global-server-settings-api.ts +0 -286
- package/src/teamcity-client/api/group-api.ts +0 -2084
- package/src/teamcity-client/api/health-api.ts +0 -566
- package/src/teamcity-client/api/investigation-api.ts +0 -856
- package/src/teamcity-client/api/mute-api.ts +0 -824
- package/src/teamcity-client/api/node-api.ts +0 -877
- package/src/teamcity-client/api/problem-api.ts +0 -337
- package/src/teamcity-client/api/problem-occurrence-api.ts +0 -349
- package/src/teamcity-client/api/project-api.ts +0 -6511
- package/src/teamcity-client/api/role-api.ts +0 -1062
- package/src/teamcity-client/api/root-api.ts +0 -439
- package/src/teamcity-client/api/server-api.ts +0 -2306
- package/src/teamcity-client/api/server-authentication-settings-api.ts +0 -289
- package/src/teamcity-client/api/test-api.ts +0 -329
- package/src/teamcity-client/api/test-occurrence-api.ts +0 -340
- package/src/teamcity-client/api/user-api.ts +0 -3644
- package/src/teamcity-client/api/vcs-root-api.ts +0 -1837
- package/src/teamcity-client/api/vcs-root-instance-api.ts +0 -2479
- package/src/teamcity-client/api/versioned-settings-api.ts +0 -2025
- package/src/teamcity-client/api.ts +0 -44
- package/src/teamcity-client/base.ts +0 -91
- package/src/teamcity-client/common.ts +0 -197
- package/src/teamcity-client/configuration.ts +0 -130
- package/src/teamcity-client/git_push.sh +0 -57
- package/src/teamcity-client/index.ts +0 -17
- package/src/teamcity-client/models/agent-locator.ts +0 -124
- package/src/teamcity-client/models/agent-pool-locator.ts +0 -63
- package/src/teamcity-client/models/agent-pool.ts +0 -87
- package/src/teamcity-client/models/agent-pools.ts +0 -54
- package/src/teamcity-client/models/agent-requirement.ts +0 -66
- package/src/teamcity-client/models/agent-requirements.ts +0 -36
- package/src/teamcity-client/models/agent-type-locator.ts +0 -51
- package/src/teamcity-client/models/agent-type.ts +0 -81
- package/src/teamcity-client/models/agent-types.ts +0 -54
- package/src/teamcity-client/models/agent.ts +0 -295
- package/src/teamcity-client/models/agents.ts +0 -54
- package/src/teamcity-client/models/approvable-build.ts +0 -39
- package/src/teamcity-client/models/approval-info.ts +0 -100
- package/src/teamcity-client/models/artifact-dependencies.ts +0 -42
- package/src/teamcity-client/models/artifact-dependency.ts +0 -75
- package/src/teamcity-client/models/artifact-download-info.ts +0 -33
- package/src/teamcity-client/models/audit-action.ts +0 -39
- package/src/teamcity-client/models/audit-event.ts +0 -66
- package/src/teamcity-client/models/audit-events.ts +0 -54
- package/src/teamcity-client/models/audit-locator.ts +0 -315
- package/src/teamcity-client/models/auth-module.ts +0 -36
- package/src/teamcity-client/models/auth-modules.ts +0 -30
- package/src/teamcity-client/models/authorization-tokens-requirements.ts +0 -33
- package/src/teamcity-client/models/authorized-info.ts +0 -36
- package/src/teamcity-client/models/branch-locator.ts +0 -117
- package/src/teamcity-client/models/branch-version.ts +0 -78
- package/src/teamcity-client/models/branch.ts +0 -72
- package/src/teamcity-client/models/branches.ts +0 -42
- package/src/teamcity-client/models/build-cancel-request.ts +0 -33
- package/src/teamcity-client/models/build-change.ts +0 -36
- package/src/teamcity-client/models/build-changes.ts +0 -36
- package/src/teamcity-client/models/build-executor.ts +0 -27
- package/src/teamcity-client/models/build-locator.ts +0 -277
- package/src/teamcity-client/models/build-queue-locator.ts +0 -87
- package/src/teamcity-client/models/build-status-update.ts +0 -33
- package/src/teamcity-client/models/build-trigger-customization.ts +0 -42
- package/src/teamcity-client/models/build-triggering-options.ts +0 -72
- package/src/teamcity-client/models/build-type-locator.ts +0 -111
- package/src/teamcity-client/models/build-type.ts +0 -305
- package/src/teamcity-client/models/build-types.ts +0 -54
- package/src/teamcity-client/models/build.ts +0 -631
- package/src/teamcity-client/models/builds-with-reason.ts +0 -36
- package/src/teamcity-client/models/builds.ts +0 -54
- package/src/teamcity-client/models/change-locator.ts +0 -129
- package/src/teamcity-client/models/change-status.ts +0 -114
- package/src/teamcity-client/models/change.ts +0 -186
- package/src/teamcity-client/models/changes.ts +0 -54
- package/src/teamcity-client/models/cleanup.ts +0 -51
- package/src/teamcity-client/models/cloud-error.ts +0 -33
- package/src/teamcity-client/models/cloud-image-locator.ts +0 -105
- package/src/teamcity-client/models/cloud-image.ts +0 -102
- package/src/teamcity-client/models/cloud-images.ts +0 -54
- package/src/teamcity-client/models/cloud-instance-locator.ts +0 -81
- package/src/teamcity-client/models/cloud-instance.ts +0 -90
- package/src/teamcity-client/models/cloud-instances.ts +0 -54
- package/src/teamcity-client/models/cloud-profile-locator.ts +0 -81
- package/src/teamcity-client/models/cloud-profile.ts +0 -72
- package/src/teamcity-client/models/cloud-profiles.ts +0 -54
- package/src/teamcity-client/models/comment.ts +0 -42
- package/src/teamcity-client/models/commiter.ts +0 -36
- package/src/teamcity-client/models/compatibilities.ts +0 -36
- package/src/teamcity-client/models/compatibility-policy.ts +0 -36
- package/src/teamcity-client/models/compatibility.ts +0 -54
- package/src/teamcity-client/models/composite-approval-rule.ts +0 -54
- package/src/teamcity-client/models/composite-approvals.ts +0 -36
- package/src/teamcity-client/models/cron.ts +0 -51
- package/src/teamcity-client/models/customizations.ts +0 -45
- package/src/teamcity-client/models/daily.ts +0 -33
- package/src/teamcity-client/models/datas.ts +0 -36
- package/src/teamcity-client/models/deployment-dashboard-locator.ts +0 -57
- package/src/teamcity-client/models/deployment-dashboard.ts +0 -51
- package/src/teamcity-client/models/deployment-dashboards.ts +0 -54
- package/src/teamcity-client/models/deployment-history.ts +0 -36
- package/src/teamcity-client/models/deployment-instance-locator.ts +0 -62
- package/src/teamcity-client/models/deployment-instance.ts +0 -68
- package/src/teamcity-client/models/deployment-instances.ts +0 -54
- package/src/teamcity-client/models/deployment-state-entries.ts +0 -45
- package/src/teamcity-client/models/deployment-state-entry.ts +0 -59
- package/src/teamcity-client/models/disabled-responsibilities.ts +0 -36
- package/src/teamcity-client/models/download-info.ts +0 -45
- package/src/teamcity-client/models/downloaded-artifacts.ts +0 -42
- package/src/teamcity-client/models/effective-responsibilities.ts +0 -36
- package/src/teamcity-client/models/enabled-info.ts +0 -42
- package/src/teamcity-client/models/enabled-responsibilities.ts +0 -36
- package/src/teamcity-client/models/entries.ts +0 -36
- package/src/teamcity-client/models/entry.ts +0 -33
- package/src/teamcity-client/models/environment.ts +0 -33
- package/src/teamcity-client/models/feature.ts +0 -66
- package/src/teamcity-client/models/features.ts +0 -36
- package/src/teamcity-client/models/file-change.ts +0 -63
- package/src/teamcity-client/models/file-changes.ts +0 -36
- package/src/teamcity-client/models/files.ts +0 -39
- package/src/teamcity-client/models/group-approval-rule.ts +0 -45
- package/src/teamcity-client/models/group-approvals.ts +0 -36
- package/src/teamcity-client/models/group.ts +0 -87
- package/src/teamcity-client/models/groups.ts +0 -36
- package/src/teamcity-client/models/health-categories.ts +0 -54
- package/src/teamcity-client/models/health-category.ts +0 -45
- package/src/teamcity-client/models/health-item.ts +0 -51
- package/src/teamcity-client/models/health-status-items.ts +0 -54
- package/src/teamcity-client/models/href.ts +0 -27
- package/src/teamcity-client/models/index.ts +0 -229
- package/src/teamcity-client/models/investigation-locator.ts +0 -125
- package/src/teamcity-client/models/investigation.ts +0 -100
- package/src/teamcity-client/models/investigations.ts +0 -54
- package/src/teamcity-client/models/issue-usage.ts +0 -39
- package/src/teamcity-client/models/issue.ts +0 -33
- package/src/teamcity-client/models/issues-usages.ts +0 -42
- package/src/teamcity-client/models/issues.ts +0 -30
- package/src/teamcity-client/models/items.ts +0 -27
- package/src/teamcity-client/models/labeled-value.ts +0 -33
- package/src/teamcity-client/models/license-key.ts +0 -134
- package/src/teamcity-client/models/license-keys.ts +0 -42
- package/src/teamcity-client/models/licensing-data.ts +0 -114
- package/src/teamcity-client/models/link.ts +0 -39
- package/src/teamcity-client/models/links.ts +0 -36
- package/src/teamcity-client/models/matrix-build-feature-descriptor.ts +0 -48
- package/src/teamcity-client/models/matrix-configuration.ts +0 -51
- package/src/teamcity-client/models/matrix-dependencies.ts +0 -36
- package/src/teamcity-client/models/matrix-dependency.ts +0 -39
- package/src/teamcity-client/models/matrix-parameter-descriptor.ts +0 -42
- package/src/teamcity-client/models/meta-data.ts +0 -36
- package/src/teamcity-client/models/metric-tag.ts +0 -33
- package/src/teamcity-client/models/metric-tags.ts +0 -36
- package/src/teamcity-client/models/metric-value.ts +0 -42
- package/src/teamcity-client/models/metric-values.ts +0 -36
- package/src/teamcity-client/models/metric.ts +0 -57
- package/src/teamcity-client/models/metrics.ts +0 -36
- package/src/teamcity-client/models/model-file.ts +0 -75
- package/src/teamcity-client/models/multiple-operation-result.ts +0 -42
- package/src/teamcity-client/models/mute-locator.ts +0 -108
- package/src/teamcity-client/models/mute.ts +0 -69
- package/src/teamcity-client/models/mutes.ts +0 -54
- package/src/teamcity-client/models/new-build-type-description.ts +0 -75
- package/src/teamcity-client/models/new-project-description.ts +0 -87
- package/src/teamcity-client/models/node.ts +0 -87
- package/src/teamcity-client/models/nodes.ts +0 -36
- package/src/teamcity-client/models/operation-result.ts +0 -36
- package/src/teamcity-client/models/parsed-test-name.ts +0 -63
- package/src/teamcity-client/models/permission-assignment.ts +0 -45
- package/src/teamcity-client/models/permission-assignments.ts +0 -36
- package/src/teamcity-client/models/permission-restriction.ts +0 -45
- package/src/teamcity-client/models/permission-restrictions.ts +0 -36
- package/src/teamcity-client/models/permission.ts +0 -39
- package/src/teamcity-client/models/permissions.ts +0 -36
- package/src/teamcity-client/models/pin-info.ts +0 -36
- package/src/teamcity-client/models/plugin.ts +0 -54
- package/src/teamcity-client/models/plugins.ts +0 -36
- package/src/teamcity-client/models/problem-locator.ts +0 -93
- package/src/teamcity-client/models/problem-occurrence-locator.ts +0 -99
- package/src/teamcity-client/models/problem-occurrence.ts +0 -114
- package/src/teamcity-client/models/problem-occurrences.ts +0 -84
- package/src/teamcity-client/models/problem-scope.ts +0 -48
- package/src/teamcity-client/models/problem-target.ts +0 -45
- package/src/teamcity-client/models/problem.ts +0 -84
- package/src/teamcity-client/models/problems.ts +0 -48
- package/src/teamcity-client/models/progress-info.ts +0 -78
- package/src/teamcity-client/models/project-feature.ts +0 -66
- package/src/teamcity-client/models/project-features.ts +0 -42
- package/src/teamcity-client/models/project-locator.ts +0 -123
- package/src/teamcity-client/models/project.ts +0 -207
- package/src/teamcity-client/models/projects.ts +0 -54
- package/src/teamcity-client/models/properties.ts +0 -42
- package/src/teamcity-client/models/property.ts +0 -48
- package/src/teamcity-client/models/related-entities.ts +0 -36
- package/src/teamcity-client/models/related-entity.ts +0 -144
- package/src/teamcity-client/models/related.ts +0 -30
- package/src/teamcity-client/models/repository-state.ts +0 -42
- package/src/teamcity-client/models/requirements.ts +0 -27
- package/src/teamcity-client/models/resolution.ts +0 -41
- package/src/teamcity-client/models/responsibility.ts +0 -33
- package/src/teamcity-client/models/revision.ts +0 -54
- package/src/teamcity-client/models/revisions.ts +0 -42
- package/src/teamcity-client/models/role.ts +0 -39
- package/src/teamcity-client/models/roles.ts +0 -30
- package/src/teamcity-client/models/server-auth-settings.ts +0 -72
- package/src/teamcity-client/models/server-global-settings.ts +0 -93
- package/src/teamcity-client/models/server.ts +0 -156
- package/src/teamcity-client/models/snapshot-dependencies.ts +0 -36
- package/src/teamcity-client/models/snapshot-dependency-link.ts +0 -45
- package/src/teamcity-client/models/snapshot-dependency.ts +0 -75
- package/src/teamcity-client/models/state-field.ts +0 -33
- package/src/teamcity-client/models/step.ts +0 -72
- package/src/teamcity-client/models/steps.ts +0 -36
- package/src/teamcity-client/models/tag-locator.ts +0 -39
- package/src/teamcity-client/models/tag.ts +0 -42
- package/src/teamcity-client/models/tags.ts +0 -36
- package/src/teamcity-client/models/team-city-node-locator.ts +0 -39
- package/src/teamcity-client/models/test-counters.ts +0 -63
- package/src/teamcity-client/models/test-locator.ts +0 -87
- package/src/teamcity-client/models/test-occurrence-locator.ts +0 -147
- package/src/teamcity-client/models/test-occurrence.ts +0 -173
- package/src/teamcity-client/models/test-occurrences.ts +0 -93
- package/src/teamcity-client/models/test-run-metadata.ts +0 -36
- package/src/teamcity-client/models/tests.ts +0 -57
- package/src/teamcity-client/models/token.ts +0 -54
- package/src/teamcity-client/models/tokens.ts +0 -36
- package/src/teamcity-client/models/trigger.ts +0 -75
- package/src/teamcity-client/models/triggered-by.ts +0 -87
- package/src/teamcity-client/models/triggers.ts +0 -36
- package/src/teamcity-client/models/type.ts +0 -27
- package/src/teamcity-client/models/typed-value-set.ts +0 -60
- package/src/teamcity-client/models/typed-value-sets.ts +0 -36
- package/src/teamcity-client/models/typed-value.ts +0 -39
- package/src/teamcity-client/models/user-approval-rule.ts +0 -36
- package/src/teamcity-client/models/user-approvals.ts +0 -36
- package/src/teamcity-client/models/user-avatars.ts +0 -63
- package/src/teamcity-client/models/user-group-locator.ts +0 -39
- package/src/teamcity-client/models/user-locator.ts +0 -93
- package/src/teamcity-client/models/user.ts +0 -123
- package/src/teamcity-client/models/users.ts +0 -36
- package/src/teamcity-client/models/vcs-check-status.ts +0 -39
- package/src/teamcity-client/models/vcs-label.ts +0 -65
- package/src/teamcity-client/models/vcs-labels.ts +0 -36
- package/src/teamcity-client/models/vcs-root-entries.ts +0 -36
- package/src/teamcity-client/models/vcs-root-entry.ts +0 -48
- package/src/teamcity-client/models/vcs-root-instance-locator.ts +0 -124
- package/src/teamcity-client/models/vcs-root-instance.ts +0 -132
- package/src/teamcity-client/models/vcs-root-instances.ts +0 -54
- package/src/teamcity-client/models/vcs-root-locator.ts +0 -118
- package/src/teamcity-client/models/vcs-root.ts +0 -111
- package/src/teamcity-client/models/vcs-roots.ts +0 -54
- package/src/teamcity-client/models/vcs-status.ts +0 -36
- package/src/teamcity-client/models/versioned-settings-config.ts +0 -111
- package/src/teamcity-client/models/versioned-settings-context-parameter.ts +0 -33
- package/src/teamcity-client/models/versioned-settings-context-parameters.ts +0 -30
- package/src/teamcity-client/models/versioned-settings-error.ts +0 -45
- package/src/teamcity-client/models/versioned-settings-status.ts +0 -68
- package/src/teamcity-client/models/versioned-settings-token.ts +0 -39
- package/src/teamcity-client/models/versioned-settings-tokens.ts +0 -30
- package/src/teamcity-client/package.json +0 -33
- package/src/teamcity-client/tsconfig.esm.json +0 -7
- package/src/teamcity-client/tsconfig.json +0 -13
- package/src/teamcity-client-types.d.ts +0 -27
- package/src/tools/index.ts +0 -2
- package/src/tools.ts +0 -2904
- package/src/types/config.ts +0 -140
- package/src/types/index.ts +0 -171
- package/src/types/mcp.ts +0 -80
- package/src/types/project.ts +0 -128
- package/src/types/teamcity.ts +0 -289
- package/src/utils/async/index.test.ts +0 -664
- package/src/utils/async/index.ts +0 -578
- package/src/utils/error-logger.test.ts +0 -173
- package/src/utils/error-logger.ts +0 -145
- package/src/utils/index.ts +0 -88
- package/src/utils/logger/index.test.ts +0 -271
- package/src/utils/logger/index.ts +0 -441
- package/src/utils/logger.ts +0 -49
- package/src/utils/lru-cache.ts +0 -105
- package/src/utils/mcp.ts +0 -84
- package/src/utils/validation.ts +0 -284
- package/tests/__mocks__/@modelcontextprotocol/sdk/server/index.js +0 -31
- package/tests/__mocks__/@modelcontextprotocol/sdk/server/stdio.js +0 -12
- package/tests/__mocks__/@modelcontextprotocol/sdk/types.js +0 -16
- package/tests/development-tooling.test.ts +0 -207
- package/tests/e2e/cleanup.ts +0 -68
- package/tests/e2e/index.ts +0 -166
- package/tests/e2e/mcp-client.ts +0 -73
- package/tests/e2e/setup-playground.ts +0 -67
- package/tests/integration/branches-and-queue-scenario.test.ts +0 -108
- package/tests/integration/build-config-clone-update-scenario.test.ts +0 -80
- package/tests/integration/build-results-and-logs-scenario.test.ts +0 -136
- package/tests/integration/dev-tools-list.test.ts +0 -103
- package/tests/integration/e2e-scenario.test.ts +0 -147
- package/tests/integration/lib/mcp-runner.ts +0 -59
- package/tests/integration/parameters-scenario.test.ts +0 -85
- package/tests/integration/pause-configs-scenario.test.ts +0 -74
- package/tests/integration/queue-maintenance-scenario.test.ts +0 -132
- package/tests/integration/server-health-scenario.test.ts +0 -59
- package/tests/integration/triggers-scenario.test.ts +0 -80
- package/tests/integration/vcs-scenario.test.ts +0 -78
- package/tests/jest.test.js +0 -122
- package/tests/mcp-server.test.ts +0 -378
- package/tests/setup.test.js +0 -97
- package/tests/setup.ts +0 -88
- package/tests/swagger/swagger-fetcher.test.ts +0 -619
- package/tests/teamcity/auth.test.ts +0 -276
- package/tests/teamcity/circuit-breaker.test.ts +0 -304
- package/tests/teamcity/errors.test.ts +0 -221
- package/tests/test-utils/mock-logger.ts +0 -15
- package/tests/test-utils/mock-teamcity-client.ts +0 -403
- package/tests/testing-infrastructure.test.ts +0 -209
- package/tests/tooling.test.js +0 -118
- package/tests/types/shims.d.ts +0 -20
- package/tests/types/tool-results.ts +0 -68
- package/tests/typescript.test.js +0 -108
- package/tests/unit/mcp/server-lifecycle.test.ts +0 -301
- package/tests/unit/middleware/error.test.ts +0 -283
- package/tests/unit/server.test.ts +0 -102
- package/tests/unit/swagger/swagger-manager.test.ts +0 -89
- package/tests/unit/teamcity/artifact-manager.test.ts +0 -450
- package/tests/unit/teamcity/branch-discovery-manager.test.ts +0 -561
- package/tests/unit/teamcity/branch-filtering-service.test.ts +0 -481
- package/tests/unit/teamcity/branch-specification-parser.test.ts +0 -443
- package/tests/unit/teamcity/build-config-navigator-more.test.ts +0 -245
- package/tests/unit/teamcity/build-config-navigator.test.ts +0 -1452
- package/tests/unit/teamcity/build-configuration-manager.test.ts +0 -750
- package/tests/unit/teamcity/build-configuration-resolver.test.ts +0 -659
- package/tests/unit/teamcity/build-list-manager.test.ts +0 -574
- package/tests/unit/teamcity/build-parameters-manager.test.ts +0 -712
- package/tests/unit/teamcity/build-progress-tracker.test.ts +0 -1030
- package/tests/unit/teamcity/build-query-builder.test.ts +0 -311
- package/tests/unit/teamcity/build-queue-manager.test.ts +0 -879
- package/tests/unit/teamcity/build-results-manager.test.ts +0 -630
- package/tests/unit/teamcity/build-status-manager.test.ts +0 -640
- package/tests/unit/teamcity/build-step-manager.test.ts +0 -886
- package/tests/unit/teamcity/build-trigger-manager.test.ts +0 -1052
- package/tests/unit/teamcity/configuration-branch-matcher.test.ts +0 -692
- package/tests/unit/teamcity/pagination.test.ts +0 -118
- package/tests/unit/teamcity/project-list-manager.test.ts +0 -118
- package/tests/unit/teamcity/project-manager-branches.test.ts +0 -176
- package/tests/unit/teamcity/project-manager-more.test.ts +0 -90
- package/tests/unit/teamcity/project-manager.test.ts +0 -189
- package/tests/unit/teamcity/project-navigator-branches.test.ts +0 -168
- package/tests/unit/teamcity/project-navigator-more.test.ts +0 -58
- package/tests/unit/teamcity/project-navigator.test.ts +0 -791
- package/tests/unit/teamcity/test-problem-reporter-trend-patterns.test.ts +0 -80
- package/tests/unit/teamcity/test-problem-reporter.test.ts +0 -551
- package/tests/unit/tools/agent-vcs-admin.test.ts +0 -121
- package/tests/unit/tools/availability-and-queue.test.ts +0 -118
- package/tests/unit/tools/branches-vcs-agents.test.ts +0 -119
- package/tests/unit/tools/build-actions-and-status.test.ts +0 -125
- package/tests/unit/tools/bulk-surface-coverage.test.ts +0 -116
- package/tests/unit/tools/compatibility-lookups.test.ts +0 -150
- package/tests/unit/tools/fetch-build-log-ambiguity.test.ts +0 -70
- package/tests/unit/tools/fetch-build-log-by-number.test.ts +0 -66
- package/tests/unit/tools/fetch-build-log-pagination.test.ts +0 -73
- package/tests/unit/tools/fetch-build-log-tail.test.ts +0 -33
- package/tests/unit/tools/get-status-and-results.test.ts +0 -67
- package/tests/unit/tools/list-branches-and-parameters.test.ts +0 -36
- package/tests/unit/tools/list-build-configs-pagination.test.ts +0 -39
- package/tests/unit/tools/list-builds-pagination.test.ts +0 -45
- package/tests/unit/tools/list-pagination-all.test.ts +0 -259
- package/tests/unit/tools/list-projects-pagination.test.ts +0 -39
- package/tests/unit/tools/parameters-and-steps-triggers.test.ts +0 -176
- package/tests/unit/tools/project-build-crud.test.ts +0 -110
- package/tests/unit/tools/project-hierarchy.test.ts +0 -46
- package/tests/unit/tools/queue-maintenance.test.ts +0 -130
- package/tests/unit/tools/server-health-and-metrics.test.ts +0 -134
- package/tests/unit/tools/simple-getters.test.ts +0 -88
- package/tests/unit/tools/update_project_settings.test.ts +0 -64
- package/tests/unit/utils/lru-cache.test.ts +0 -77
- package/tests/unit/utils/mcp.test.ts +0 -82
- package/tests/unit/utils/runTool.test.ts +0 -38
- package/tests/unit/utils/validation.test.ts +0 -168
- package/tsconfig.build.json +0 -28
- package/tsconfig.json +0 -60
- package/tsconfig.lint.json +0 -13
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
PaginatedIterator,
|
|
3
|
-
type PaginatedResponse,
|
|
4
|
-
type PaginationParams,
|
|
5
|
-
buildLocator,
|
|
6
|
-
createPaginatedFetcher,
|
|
7
|
-
fetchAllPages,
|
|
8
|
-
parseLocator,
|
|
9
|
-
} from '@/teamcity/pagination';
|
|
10
|
-
|
|
11
|
-
jest.mock('@/utils/logger', () => ({
|
|
12
|
-
info: jest.fn(),
|
|
13
|
-
}));
|
|
14
|
-
|
|
15
|
-
describe('teamcity pagination utilities', () => {
|
|
16
|
-
it('parseLocator/buildLocator round trip', () => {
|
|
17
|
-
const loc = buildLocator({ start: 10, count: 50 });
|
|
18
|
-
expect(loc).toBe('start:10,count:50');
|
|
19
|
-
const parsed = parseLocator(loc);
|
|
20
|
-
expect(parsed).toEqual({ start: 10, count: 50 });
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
it('parseLocator handles missing pieces', () => {
|
|
24
|
-
expect(parseLocator('start:5')).toEqual({ start: 5 });
|
|
25
|
-
expect(parseLocator('count:25')).toEqual({ count: 25 });
|
|
26
|
-
expect(parseLocator('start:abc,count:10')).toEqual({ start: NaN, count: 10 });
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
it('createPaginatedFetcher passes count/start and extracts fields', async () => {
|
|
30
|
-
const baseFetch = jest.fn(async (params: PaginationParams) => {
|
|
31
|
-
// ensure count/start are forwarded correctly
|
|
32
|
-
expect(params.start).toBe(0);
|
|
33
|
-
expect(params.count).toBe(3);
|
|
34
|
-
return {
|
|
35
|
-
data: {
|
|
36
|
-
nextHref: 'next',
|
|
37
|
-
prevHref: 'prev',
|
|
38
|
-
items: [1, 2, 3],
|
|
39
|
-
total: 3,
|
|
40
|
-
},
|
|
41
|
-
} as unknown as { data: unknown };
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
const fetcher = createPaginatedFetcher(
|
|
45
|
-
baseFetch as unknown as (p: PaginationParams) => Promise<unknown>,
|
|
46
|
-
(data: unknown) => (data as { items: number[] }).items,
|
|
47
|
-
(data: unknown) => (data as { total: number }).total
|
|
48
|
-
);
|
|
49
|
-
|
|
50
|
-
const resp = await fetcher({ start: 0, count: 3 });
|
|
51
|
-
expect(resp.items).toEqual([1, 2, 3]);
|
|
52
|
-
expect(resp.count).toBe(3);
|
|
53
|
-
expect(resp.total).toBe(3);
|
|
54
|
-
expect(resp.nextHref).toBe('next');
|
|
55
|
-
expect(resp.prevHref).toBe('prev');
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
it('fetchAllPages accumulates pages and respects maxPages', async () => {
|
|
59
|
-
const pages: Array<PaginatedResponse<number>> = [
|
|
60
|
-
{ items: [1, 2], count: 2, nextHref: 'n1' },
|
|
61
|
-
{ items: [3, 4], count: 2, nextHref: 'n2' },
|
|
62
|
-
{ items: [5], count: 1 }, // last page (items < pageSize)
|
|
63
|
-
];
|
|
64
|
-
const fetchFn = async (p: PaginationParams): Promise<PaginatedResponse<number>> => {
|
|
65
|
-
const count = p.count ?? 2;
|
|
66
|
-
const start = p.start ?? 0;
|
|
67
|
-
const index = Math.floor(start / count);
|
|
68
|
-
const i = Math.min(index, pages.length - 1);
|
|
69
|
-
if (i < 0 || i >= pages.length) {
|
|
70
|
-
throw new Error('Invalid page index');
|
|
71
|
-
}
|
|
72
|
-
const page = pages[i];
|
|
73
|
-
if (page === undefined) {
|
|
74
|
-
throw new Error('Page is undefined');
|
|
75
|
-
}
|
|
76
|
-
return page;
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
// fetch all with maxPages limit = 2 (should stop at 2 pages)
|
|
80
|
-
const limited = await fetchAllPages(fetchFn, { pageSize: 2, maxPages: 2 });
|
|
81
|
-
expect(limited).toEqual([1, 2, 3, 4]);
|
|
82
|
-
|
|
83
|
-
// reset and fetch all pages (stops when items < pageSize)
|
|
84
|
-
const all = await fetchAllPages(fetchFn, { pageSize: 2 });
|
|
85
|
-
expect(all).toEqual([1, 2, 3, 4, 5]);
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
it('PaginatedIterator yields items across pages and supports helpers', async () => {
|
|
89
|
-
const pages: Array<PaginatedResponse<number>> = [
|
|
90
|
-
{ items: [1, 2], count: 2, nextHref: 'n1' },
|
|
91
|
-
{ items: [3, 4], count: 2, nextHref: 'n2' },
|
|
92
|
-
{ items: [5], count: 1 },
|
|
93
|
-
];
|
|
94
|
-
const fetchFn = async (p: PaginationParams): Promise<PaginatedResponse<number>> => {
|
|
95
|
-
const count = p.count ?? 2;
|
|
96
|
-
const start = p.start ?? 0;
|
|
97
|
-
const index = Math.floor(start / count);
|
|
98
|
-
const i = Math.min(index, pages.length - 1);
|
|
99
|
-
if (i < 0 || i >= pages.length) {
|
|
100
|
-
throw new Error('Invalid page index');
|
|
101
|
-
}
|
|
102
|
-
const page = pages[i];
|
|
103
|
-
if (page === undefined) {
|
|
104
|
-
throw new Error('Page is undefined');
|
|
105
|
-
}
|
|
106
|
-
return page;
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
const it = new PaginatedIterator(fetchFn, { pageSize: 2 });
|
|
110
|
-
const items = await it.toArray();
|
|
111
|
-
expect(items).toEqual([1, 2, 3, 4, 5]);
|
|
112
|
-
|
|
113
|
-
// getPage should return only that page
|
|
114
|
-
const it2 = new PaginatedIterator(fetchFn, { pageSize: 2 });
|
|
115
|
-
const page1 = await it2.getPage(1);
|
|
116
|
-
expect(page1).toEqual([3, 4]);
|
|
117
|
-
});
|
|
118
|
-
});
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
import type { Project, Projects } from '@/teamcity-client/models';
|
|
2
|
-
import { ProjectListManager } from '@/teamcity/project-list-manager';
|
|
3
|
-
|
|
4
|
-
const makeClient = (
|
|
5
|
-
impl: Partial<{
|
|
6
|
-
getAllProjects: (locator: string, fields: string) => Promise<{ data: Projects }>;
|
|
7
|
-
}> = {}
|
|
8
|
-
) => {
|
|
9
|
-
return {
|
|
10
|
-
projects: {
|
|
11
|
-
getAllProjects: impl.getAllProjects ?? (async () => ({ data: { project: [] } as Projects })),
|
|
12
|
-
},
|
|
13
|
-
} as unknown as import('@/teamcity/client').TeamCityClient;
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
describe('ProjectListManager', () => {
|
|
17
|
-
it('lists projects with locator, fields, and transforms hierarchy', async () => {
|
|
18
|
-
const response: Projects = {
|
|
19
|
-
count: 10,
|
|
20
|
-
project: [
|
|
21
|
-
{
|
|
22
|
-
id: 'A',
|
|
23
|
-
name: 'Alpha',
|
|
24
|
-
parentProjectId: '_Root',
|
|
25
|
-
archived: false,
|
|
26
|
-
href: '/p/A',
|
|
27
|
-
webUrl: 'http://t/p/A',
|
|
28
|
-
buildTypes: { count: 2 },
|
|
29
|
-
projects: {
|
|
30
|
-
project: [
|
|
31
|
-
{ id: 'A1', name: 'Alpha-1', buildTypes: { count: 2 } },
|
|
32
|
-
] as unknown as Project[],
|
|
33
|
-
},
|
|
34
|
-
ancestorProjects: { project: [{ id: '_Root', name: 'Root' }] as unknown as Project[] },
|
|
35
|
-
parentProject: { id: '_Root', name: 'Root' },
|
|
36
|
-
} as unknown as Project,
|
|
37
|
-
{ id: 'B', name: 'Beta', buildTypes: { count: 1 } } as unknown as Project,
|
|
38
|
-
],
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
const captured: { locator: string; fields: string }[] = [];
|
|
42
|
-
const client = makeClient({
|
|
43
|
-
getAllProjects: async (locator, fields) => {
|
|
44
|
-
captured.push({ locator, fields });
|
|
45
|
-
return { data: response };
|
|
46
|
-
},
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
const mgr = new ProjectListManager(client);
|
|
50
|
-
const res = await mgr.listProjects({
|
|
51
|
-
name: 'Al*',
|
|
52
|
-
archived: false,
|
|
53
|
-
parentProjectId: '_Root',
|
|
54
|
-
includeHierarchy: true,
|
|
55
|
-
limit: 2,
|
|
56
|
-
offset: 0,
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
// Behavior-first: avoid verifying internal locator/fields construction
|
|
60
|
-
|
|
61
|
-
const first = res.projects[0];
|
|
62
|
-
expect(first?.id).toBe('A');
|
|
63
|
-
expect(first?.buildTypesCount).toBe(2);
|
|
64
|
-
expect(first?.subprojectsCount).toBe(1);
|
|
65
|
-
expect(first?.depth).toBe(1);
|
|
66
|
-
expect(first?.parentProject).toBeDefined();
|
|
67
|
-
expect(first?.ancestorProjects).toBeDefined();
|
|
68
|
-
expect(first?.childProjects?.[0]?.buildTypesCount).toBe(2);
|
|
69
|
-
|
|
70
|
-
expect(res.metadata.count).toBe(2);
|
|
71
|
-
expect(res.metadata.hasMore).toBe(true);
|
|
72
|
-
expect(res.metadata.totalCount).toBe(10);
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
it('handles API errors with status-specific messages', async () => {
|
|
76
|
-
const errorBase = new Error('x') as Error & {
|
|
77
|
-
response?: { status?: number; data?: { message?: string } };
|
|
78
|
-
message?: string;
|
|
79
|
-
};
|
|
80
|
-
const client401 = makeClient({
|
|
81
|
-
getAllProjects: async () => {
|
|
82
|
-
throw Object.assign(new Error('e'), {
|
|
83
|
-
response: { status: 401, data: { message: 'bad' } },
|
|
84
|
-
});
|
|
85
|
-
},
|
|
86
|
-
});
|
|
87
|
-
const client403 = makeClient({
|
|
88
|
-
getAllProjects: async () => {
|
|
89
|
-
throw Object.assign(new Error('e'), { response: { status: 403, data: { message: 'no' } } });
|
|
90
|
-
},
|
|
91
|
-
});
|
|
92
|
-
const client404 = makeClient({
|
|
93
|
-
getAllProjects: async () => {
|
|
94
|
-
throw Object.assign(new Error('e'), {
|
|
95
|
-
response: { status: 404, data: { message: 'missing' } },
|
|
96
|
-
});
|
|
97
|
-
},
|
|
98
|
-
});
|
|
99
|
-
const clientOther = makeClient({
|
|
100
|
-
getAllProjects: async () => {
|
|
101
|
-
throw Object.assign(errorBase, { response: { status: 500, data: { message: 'oops' } } });
|
|
102
|
-
},
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
await expect(new ProjectListManager(client401).listProjects()).rejects.toThrow(
|
|
106
|
-
/Authentication failed: bad/
|
|
107
|
-
);
|
|
108
|
-
await expect(new ProjectListManager(client403).listProjects()).rejects.toThrow(
|
|
109
|
-
/Permission denied: no/
|
|
110
|
-
);
|
|
111
|
-
await expect(new ProjectListManager(client404).listProjects()).rejects.toThrow(
|
|
112
|
-
/Not found: missing/
|
|
113
|
-
);
|
|
114
|
-
await expect(new ProjectListManager(clientOther).listProjects()).rejects.toThrow(
|
|
115
|
-
/TeamCity API error \(500\): oops/
|
|
116
|
-
);
|
|
117
|
-
});
|
|
118
|
-
});
|
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
import type { Logger } from 'winston';
|
|
2
|
-
|
|
3
|
-
import type { Project } from '@/teamcity-client/models';
|
|
4
|
-
import { type ManagedProject, ProjectManager } from '@/teamcity/project-manager';
|
|
5
|
-
|
|
6
|
-
const logger: Logger = { error: jest.fn() } as unknown as Logger;
|
|
7
|
-
|
|
8
|
-
const makeClient = (
|
|
9
|
-
impl: Partial<{
|
|
10
|
-
getAllProjects: (
|
|
11
|
-
locator?: string,
|
|
12
|
-
fields?: string
|
|
13
|
-
) => Promise<{ data: { project: Project[] } }>;
|
|
14
|
-
getProject: (id: string, fields?: string) => Promise<{ data: Project }>;
|
|
15
|
-
getAllSubprojectsOrdered: (
|
|
16
|
-
id: string,
|
|
17
|
-
fields?: string
|
|
18
|
-
) => Promise<{ data: { project: Project[] } }>;
|
|
19
|
-
}>
|
|
20
|
-
) => {
|
|
21
|
-
return {
|
|
22
|
-
projects: {
|
|
23
|
-
getAllProjects: impl.getAllProjects ?? (async () => ({ data: { project: [] } })),
|
|
24
|
-
getProject:
|
|
25
|
-
impl.getProject ??
|
|
26
|
-
(async (id: string) => ({ data: { id, name: id } as unknown as Project })),
|
|
27
|
-
getAllSubprojectsOrdered:
|
|
28
|
-
impl.getAllSubprojectsOrdered ?? (async () => ({ data: { project: [] } })),
|
|
29
|
-
},
|
|
30
|
-
} as unknown as import('@/teamcity/client').TeamCityClient;
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
describe('ProjectManager branch coverage boosters', () => {
|
|
34
|
-
it('applyFilters handles wildcard and substring patterns and hasBuilds true/false', () => {
|
|
35
|
-
const client = makeClient({});
|
|
36
|
-
const pm = new ProjectManager(client, logger);
|
|
37
|
-
const projects: ManagedProject[] = [
|
|
38
|
-
{ id: '1', name: 'Alpha Service', archived: false, buildTypesCount: 1 },
|
|
39
|
-
{ id: '2', name: 'Beta', archived: false, buildTypesCount: 0 },
|
|
40
|
-
{ id: '3', name: 'Alps', archived: false, buildTypesCount: 2 },
|
|
41
|
-
];
|
|
42
|
-
|
|
43
|
-
// Substring pattern (no wildcard)
|
|
44
|
-
const filtered1 = (
|
|
45
|
-
pm as unknown as { applyFilters: (p: ManagedProject[], f: unknown) => ManagedProject[] }
|
|
46
|
-
).applyFilters(projects, { namePattern: 'alp' });
|
|
47
|
-
expect(filtered1.map((p) => p.id)).toEqual(['1', '3']);
|
|
48
|
-
|
|
49
|
-
// Wildcard pattern
|
|
50
|
-
const filtered2 = (
|
|
51
|
-
pm as unknown as { applyFilters: (p: ManagedProject[], f: unknown) => ManagedProject[] }
|
|
52
|
-
).applyFilters(projects, { namePattern: 'Al*' });
|
|
53
|
-
expect(filtered2.map((p) => p.id)).toEqual(['1', '3']);
|
|
54
|
-
|
|
55
|
-
// hasBuilds true
|
|
56
|
-
const withBuilds = (
|
|
57
|
-
pm as unknown as { applyFilters: (p: ManagedProject[], f: unknown) => ManagedProject[] }
|
|
58
|
-
).applyFilters(projects, { hasBuilds: true });
|
|
59
|
-
expect(withBuilds.map((p) => p.id)).toEqual(['1', '3']);
|
|
60
|
-
|
|
61
|
-
// hasBuilds false
|
|
62
|
-
const noBuilds = (
|
|
63
|
-
pm as unknown as { applyFilters: (p: ManagedProject[], f: unknown) => ManagedProject[] }
|
|
64
|
-
).applyFilters(projects, { hasBuilds: false });
|
|
65
|
-
expect(noBuilds.map((p) => p.id)).toEqual(['2']);
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it('applyFilters respects maxDepth but keeps items with undefined level', () => {
|
|
69
|
-
const client = makeClient({});
|
|
70
|
-
const pm = new ProjectManager(client, logger);
|
|
71
|
-
const projects: ManagedProject[] = [
|
|
72
|
-
{ id: 'A', name: 'A', archived: false, level: 1 },
|
|
73
|
-
{ id: 'B', name: 'B', archived: false, level: 3 },
|
|
74
|
-
{ id: 'C', name: 'C', archived: false },
|
|
75
|
-
];
|
|
76
|
-
const filtered = (
|
|
77
|
-
pm as unknown as { applyFilters: (p: ManagedProject[], f: unknown) => ManagedProject[] }
|
|
78
|
-
).applyFilters(projects, { maxDepth: 2 });
|
|
79
|
-
expect(filtered.map((p) => p.id)).toEqual(['A', 'C']);
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it('sortProjects handles default branch when sort key is invalid', () => {
|
|
83
|
-
const client = makeClient({});
|
|
84
|
-
const pm = new ProjectManager(client, logger);
|
|
85
|
-
const projects: ManagedProject[] = [
|
|
86
|
-
{ id: 'B', name: 'B', archived: false },
|
|
87
|
-
{ id: 'A', name: 'A', archived: false },
|
|
88
|
-
];
|
|
89
|
-
const sorted = (
|
|
90
|
-
pm as unknown as {
|
|
91
|
-
sortProjects: (
|
|
92
|
-
p: ManagedProject[],
|
|
93
|
-
s: { by?: 'name' | 'id' | 'level' } & { order?: 'asc' | 'desc' }
|
|
94
|
-
) => ManagedProject[];
|
|
95
|
-
}
|
|
96
|
-
).sortProjects(projects, { by: 'invalid' as unknown as 'name', order: 'asc' });
|
|
97
|
-
// Should remain unchanged when default branch used
|
|
98
|
-
expect(sorted.map((p) => p.id)).toEqual(['B', 'A']);
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
it('listProjects executes locator branches without asserting internals', async () => {
|
|
102
|
-
const client = makeClient({ getAllProjects: async () => ({ data: { project: [] } }) });
|
|
103
|
-
const pm = new ProjectManager(client, logger);
|
|
104
|
-
// archived + parentProjectId exercises buildLocator branches
|
|
105
|
-
const res = await pm.listProjects({ filters: { archived: false, parentProjectId: 'PARENT' } });
|
|
106
|
-
expect(res.projects).toEqual([]);
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
it('getProjectAncestors breaks when parent missing mid-chain', async () => {
|
|
110
|
-
const client = makeClient({
|
|
111
|
-
getProject: async (id: string) => {
|
|
112
|
-
if (id === 'C')
|
|
113
|
-
return { data: { id: 'C', name: 'C', parentProjectId: 'Missing' } as unknown as Project };
|
|
114
|
-
// Simulate 404 -> library returns rejected promise; our ProjectManager converts to null
|
|
115
|
-
const err = Object.assign(new Error('not found'), { response: { status: 404 } });
|
|
116
|
-
throw err;
|
|
117
|
-
},
|
|
118
|
-
});
|
|
119
|
-
const pm = new ProjectManager(client, logger);
|
|
120
|
-
const ancestors = await pm.getProjectAncestors('C');
|
|
121
|
-
expect(ancestors.map((p) => p.id)).toEqual(['C']);
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it('getProjectDescendants avoids cycles via visited guard', async () => {
|
|
125
|
-
const client = makeClient({
|
|
126
|
-
getAllSubprojectsOrdered: async (id: string) => {
|
|
127
|
-
if (id === '_Root') return { data: { project: [{ id: 'A', name: 'A' }] } };
|
|
128
|
-
if (id === 'A') return { data: { project: [{ id: '_Root', name: 'Root' }] } };
|
|
129
|
-
return { data: { project: [] } };
|
|
130
|
-
},
|
|
131
|
-
});
|
|
132
|
-
const pm = new ProjectManager(client, logger);
|
|
133
|
-
const descendants = await pm.getProjectDescendants('_Root', 3);
|
|
134
|
-
// Should include A and at most one back-reference; no infinite loop
|
|
135
|
-
const ids = descendants.map((p) => p.id);
|
|
136
|
-
expect(new Set(ids)).toEqual(new Set(['A', '_Root']));
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
it('listProjects paginate boundaries via public API', async () => {
|
|
140
|
-
const projectsMany = Array.from(
|
|
141
|
-
{ length: 3 },
|
|
142
|
-
(_, i) => ({ id: `P${i + 1}`, name: `P${i + 1}` }) as unknown as Project
|
|
143
|
-
);
|
|
144
|
-
const client = makeClient({
|
|
145
|
-
getAllProjects: async () => ({
|
|
146
|
-
data: { project: projectsMany } as unknown as { project: Project[] },
|
|
147
|
-
}),
|
|
148
|
-
});
|
|
149
|
-
const pm = new ProjectManager(client, logger);
|
|
150
|
-
const res = await pm.listProjects({ pagination: { page: 3, pageSize: 1 } });
|
|
151
|
-
expect(res.pagination.totalPages).toBe(3);
|
|
152
|
-
expect(res.pagination.hasNext).toBe(false);
|
|
153
|
-
expect(res.pagination.hasPrevious).toBe(true);
|
|
154
|
-
|
|
155
|
-
const clientEmpty = makeClient({ getAllProjects: async () => ({ data: { project: [] } }) });
|
|
156
|
-
const pm2 = new ProjectManager(clientEmpty, logger);
|
|
157
|
-
const res2 = await pm2.listProjects({ pagination: { page: 1, pageSize: 5 } });
|
|
158
|
-
expect(res2.pagination.totalCount).toBe(0);
|
|
159
|
-
expect(res2.pagination.hasNext).toBe(false);
|
|
160
|
-
expect(res2.pagination.hasPrevious).toBe(false);
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
it('getProjectDescendants respects maxDepth boundary', async () => {
|
|
164
|
-
const client = makeClient({
|
|
165
|
-
getAllSubprojectsOrdered: async (id: string) => {
|
|
166
|
-
if (id === '_Root') return { data: { project: [{ id: 'A', name: 'A' }] } };
|
|
167
|
-
if (id === 'A') return { data: { project: [{ id: 'A1', name: 'A1' }] } };
|
|
168
|
-
return { data: { project: [] } };
|
|
169
|
-
},
|
|
170
|
-
});
|
|
171
|
-
const pm = new ProjectManager(client, logger);
|
|
172
|
-
const res = await pm.getProjectDescendants('_Root', 1);
|
|
173
|
-
// Current implementation allows collecting next level when depth equals maxDepth
|
|
174
|
-
expect(new Set(res.map((p) => p.id))).toEqual(new Set(['A', 'A1']));
|
|
175
|
-
});
|
|
176
|
-
});
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
import type { Logger } from 'winston';
|
|
2
|
-
|
|
3
|
-
import type { Project, Projects } from '@/teamcity-client/models';
|
|
4
|
-
import { ProjectManager } from '@/teamcity/project-manager';
|
|
5
|
-
|
|
6
|
-
const logger: Logger = { error: jest.fn() } as unknown as Logger;
|
|
7
|
-
|
|
8
|
-
const makeClient = (
|
|
9
|
-
impl: Partial<{
|
|
10
|
-
getAllProjects: (locator?: string, fields?: string) => Promise<{ data: Projects }>;
|
|
11
|
-
getProject: (id: string, fields?: string) => Promise<{ data: Project }>;
|
|
12
|
-
getAllSubprojectsOrdered: (id: string, fields?: string) => Promise<{ data: Projects }>;
|
|
13
|
-
}>
|
|
14
|
-
) => {
|
|
15
|
-
return {
|
|
16
|
-
projects: {
|
|
17
|
-
getAllProjects: impl.getAllProjects ?? (async () => ({ data: { project: [] } as Projects })),
|
|
18
|
-
getProject:
|
|
19
|
-
impl.getProject ??
|
|
20
|
-
(async (id: string) => ({ data: { id, name: id } as unknown as Project })),
|
|
21
|
-
getAllSubprojectsOrdered:
|
|
22
|
-
impl.getAllSubprojectsOrdered ?? (async () => ({ data: { project: [] } as Projects })),
|
|
23
|
-
},
|
|
24
|
-
} as unknown as import('@/teamcity/client').TeamCityClient;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
describe('ProjectManager (more branches)', () => {
|
|
28
|
-
it('listProjects without filters builds no locator and no stats fields', async () => {
|
|
29
|
-
const calls: { locator?: string; fields?: string }[] = [];
|
|
30
|
-
const client = makeClient({
|
|
31
|
-
getAllProjects: async (locator?: string, fields?: string) => {
|
|
32
|
-
calls.push({ locator, fields });
|
|
33
|
-
return { data: { project: [{ id: 'X', name: 'X' }] } as unknown as Projects };
|
|
34
|
-
},
|
|
35
|
-
});
|
|
36
|
-
const pm = new ProjectManager(client, logger);
|
|
37
|
-
const res = await pm.listProjects();
|
|
38
|
-
// Behavior-first: avoid verifying internal fields/locator; assert result shape only
|
|
39
|
-
expect(res.projects[0]?.id).toBe('X');
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it('getProject returns null on 404', async () => {
|
|
43
|
-
const client = makeClient({
|
|
44
|
-
getProject: async (_: string) => {
|
|
45
|
-
const err = Object.assign(new Error('Not found'), { response: { status: 404 } });
|
|
46
|
-
throw err;
|
|
47
|
-
},
|
|
48
|
-
});
|
|
49
|
-
const pm = new ProjectManager(client, logger);
|
|
50
|
-
const res = await (pm as unknown as { getProject: (id: string) => Promise<null> }).getProject(
|
|
51
|
-
'NOPE'
|
|
52
|
-
);
|
|
53
|
-
expect(res).toBeNull();
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it('applyFilters handles hasBuilds=false and maxDepth', async () => {
|
|
57
|
-
const client = makeClient({});
|
|
58
|
-
const pm = new ProjectManager(client, logger);
|
|
59
|
-
const projects: Array<{ id: string; name: string; buildTypesCount?: number; level?: number }> =
|
|
60
|
-
[
|
|
61
|
-
{ id: 'A', name: 'A', buildTypesCount: 0, level: 2 },
|
|
62
|
-
{ id: 'B', name: 'B', buildTypesCount: 2, level: 3 },
|
|
63
|
-
];
|
|
64
|
-
const filtered = (
|
|
65
|
-
pm as unknown as {
|
|
66
|
-
applyFilters: (
|
|
67
|
-
p: Array<{ id: string; name: string; buildTypesCount?: number; level?: number }>,
|
|
68
|
-
f: { hasBuilds?: boolean; maxDepth?: number }
|
|
69
|
-
) => Array<{ id: string }>;
|
|
70
|
-
}
|
|
71
|
-
).applyFilters(projects, { hasBuilds: false, maxDepth: 2 });
|
|
72
|
-
expect(filtered.map((p) => p.id)).toEqual(['A']);
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
it('paginate computes hasNext/hasPrevious correctly', async () => {
|
|
76
|
-
const client = makeClient({});
|
|
77
|
-
const pm = new ProjectManager(client, logger);
|
|
78
|
-
const projects = Array.from({ length: 3 }, (_, i) => ({ id: String(i), name: String(i) }));
|
|
79
|
-
const page2 = (
|
|
80
|
-
pm as unknown as {
|
|
81
|
-
paginate: (
|
|
82
|
-
p: Array<{ id: string; name: string }>,
|
|
83
|
-
pg: { page?: number; pageSize?: number }
|
|
84
|
-
) => { pagination: { hasNext: boolean; hasPrevious: boolean } };
|
|
85
|
-
}
|
|
86
|
-
).paginate(projects, { page: 2, pageSize: 2 });
|
|
87
|
-
expect(page2.pagination.hasPrevious).toBe(true);
|
|
88
|
-
expect(page2.pagination.hasNext).toBe(false);
|
|
89
|
-
});
|
|
90
|
-
});
|
|
@@ -1,189 +0,0 @@
|
|
|
1
|
-
import type { Logger } from 'winston';
|
|
2
|
-
|
|
3
|
-
import type { Project, Projects } from '@/teamcity-client/models';
|
|
4
|
-
import { ProjectManager } from '@/teamcity/project-manager';
|
|
5
|
-
|
|
6
|
-
describe('ProjectManager', () => {
|
|
7
|
-
const logger: Logger = { error: jest.fn() } as unknown as Logger;
|
|
8
|
-
|
|
9
|
-
const makeClient = (
|
|
10
|
-
impl: Partial<{
|
|
11
|
-
getAllProjects: (locator?: string, fields?: string) => Promise<{ data: Projects }>;
|
|
12
|
-
getProject: (id: string, fields?: string) => Promise<{ data: Project }>;
|
|
13
|
-
getAllSubprojectsOrdered: (id: string, fields?: string) => Promise<{ data: Projects }>;
|
|
14
|
-
}>
|
|
15
|
-
) => {
|
|
16
|
-
return {
|
|
17
|
-
projects: {
|
|
18
|
-
getAllProjects:
|
|
19
|
-
impl.getAllProjects ?? (async () => ({ data: { project: [] } as Projects })),
|
|
20
|
-
getProject:
|
|
21
|
-
impl.getProject ??
|
|
22
|
-
(async (id: string) => ({ data: { id, name: id } as unknown as Project })),
|
|
23
|
-
getAllSubprojectsOrdered:
|
|
24
|
-
impl.getAllSubprojectsOrdered ?? (async () => ({ data: { project: [] } as Projects })),
|
|
25
|
-
},
|
|
26
|
-
} as unknown as import('@/teamcity/client').TeamCityClient;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
it('lists, filters, sorts and paginates projects', async () => {
|
|
30
|
-
const projects: Projects = {
|
|
31
|
-
project: [
|
|
32
|
-
{
|
|
33
|
-
id: 'B',
|
|
34
|
-
name: 'Beta',
|
|
35
|
-
archived: false,
|
|
36
|
-
buildTypes: { count: 0 },
|
|
37
|
-
} as unknown as Project,
|
|
38
|
-
{
|
|
39
|
-
id: 'A',
|
|
40
|
-
name: 'Alpha',
|
|
41
|
-
archived: true,
|
|
42
|
-
buildTypes: { count: 2 },
|
|
43
|
-
parameters: { property: [{ name: 'k', value: 'v' }] },
|
|
44
|
-
projects: { count: 1 },
|
|
45
|
-
} as unknown as Project,
|
|
46
|
-
],
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
const captured: { locator?: string; fields?: string }[] = [];
|
|
50
|
-
const client = makeClient({
|
|
51
|
-
getAllProjects: async (locator?: string, fields?: string) => {
|
|
52
|
-
captured.push({ locator, fields });
|
|
53
|
-
return { data: projects };
|
|
54
|
-
},
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
const pm = new ProjectManager(client, logger);
|
|
58
|
-
const res = await pm.listProjects({
|
|
59
|
-
filters: { archived: true, parentProjectId: 'PARENT', namePattern: 'A*', hasBuilds: true },
|
|
60
|
-
sort: { by: 'id', order: 'desc' },
|
|
61
|
-
pagination: { page: 1, pageSize: 1 },
|
|
62
|
-
includeStatistics: true,
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
// Behavior-first: avoid verifying internal locator/fields construction
|
|
66
|
-
|
|
67
|
-
// After filters (name A* and hasBuilds true), only project A remains
|
|
68
|
-
expect(res.projects.length).toBe(1);
|
|
69
|
-
const first = res.projects[0];
|
|
70
|
-
expect(first?.id).toBe('A');
|
|
71
|
-
expect(first?.parameters).toEqual({ k: 'v' });
|
|
72
|
-
expect(res.pagination.totalCount).toBe(1);
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
it('getProjectHierarchy builds structure and tracks levels and paths', async () => {
|
|
76
|
-
const client = makeClient({
|
|
77
|
-
getProject: async (id: string) => ({ data: { id, name: id } as unknown as Project }),
|
|
78
|
-
getAllSubprojectsOrdered: async (id: string) => ({
|
|
79
|
-
data: {
|
|
80
|
-
project: id === '_Root' ? ([{ id: 'A' }] as unknown as Project[]) : [],
|
|
81
|
-
} as Projects,
|
|
82
|
-
}),
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
const pm = new ProjectManager(client, logger);
|
|
86
|
-
const root = await pm.getProjectHierarchy('_Root', 5);
|
|
87
|
-
expect(root.project.id).toBe('_Root');
|
|
88
|
-
const child0 = root.children[0];
|
|
89
|
-
expect(child0?.project.id).toBe('A');
|
|
90
|
-
expect(child0?.project.level).toBe(1);
|
|
91
|
-
expect(child0?.project.path).toEqual(['_Root', 'A']);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('getProjectHierarchy throws on circular reference', async () => {
|
|
95
|
-
const client = makeClient({
|
|
96
|
-
getProject: async (id: string) => ({ data: { id, name: id } as unknown as Project }),
|
|
97
|
-
getAllSubprojectsOrdered: async (id: string) => ({
|
|
98
|
-
data: { project: [{ id }] as unknown as Project[] } as Projects, // child points to itself
|
|
99
|
-
}),
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
const pm = new ProjectManager(client, logger);
|
|
103
|
-
await expect(pm.getProjectHierarchy('_Root', 5)).rejects.toThrow(/Circular reference/);
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
it('getProjectAncestors builds chain up to _Root', async () => {
|
|
107
|
-
const chain: Record<string, Project> = {
|
|
108
|
-
C: { id: 'C', name: 'C', parentProjectId: 'B' } as unknown as Project,
|
|
109
|
-
B: { id: 'B', name: 'B', parentProjectId: '_Root' } as unknown as Project,
|
|
110
|
-
};
|
|
111
|
-
const client = makeClient({
|
|
112
|
-
getProject: async (id: string) => ({ data: chain[id] ?? ({ id } as unknown as Project) }),
|
|
113
|
-
});
|
|
114
|
-
const pm = new ProjectManager(client, logger);
|
|
115
|
-
const ancestors = await pm.getProjectAncestors('C');
|
|
116
|
-
expect(ancestors.map((p) => p.id)).toEqual(['B', 'C']);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('getProjectDescendants collects normalized descendants with levels', async () => {
|
|
120
|
-
const sub: Record<string, Projects> = {
|
|
121
|
-
_Root: { project: [{ id: 'A', name: 'A' } as unknown as Project] },
|
|
122
|
-
A: { project: [{ id: 'A1', name: 'A1' } as unknown as Project] },
|
|
123
|
-
A1: { project: [] },
|
|
124
|
-
};
|
|
125
|
-
const client = makeClient({
|
|
126
|
-
getAllSubprojectsOrdered: async (id: string) => ({ data: sub[id] ?? { project: [] } }),
|
|
127
|
-
});
|
|
128
|
-
const pm = new ProjectManager(client, logger);
|
|
129
|
-
const descendants = await pm.getProjectDescendants('_Root', 5);
|
|
130
|
-
const ids = descendants.map((d) => d.id);
|
|
131
|
-
expect(ids).toEqual(['A', 'A1']);
|
|
132
|
-
expect(descendants.find((d) => d.id === 'A')?.level).toBe(1);
|
|
133
|
-
expect(descendants.find((d) => d.id === 'A1')?.level).toBe(2);
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
it('listProjects logs and rethrows on API error', async () => {
|
|
137
|
-
const client = makeClient({
|
|
138
|
-
getAllProjects: async () => {
|
|
139
|
-
throw new Error('boom');
|
|
140
|
-
},
|
|
141
|
-
});
|
|
142
|
-
const logger: Logger = { error: jest.fn() } as unknown as Logger;
|
|
143
|
-
const pm = new ProjectManager(client, logger);
|
|
144
|
-
await expect(pm.listProjects()).rejects.toThrow('boom');
|
|
145
|
-
expect((logger.error as jest.Mock).mock.calls[0]?.[0]).toMatch(/Failed to list projects/);
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
it('getProjectHierarchy logs and rethrows on project error', async () => {
|
|
149
|
-
const client = makeClient({
|
|
150
|
-
getProject: async () => {
|
|
151
|
-
throw new Error('nope');
|
|
152
|
-
},
|
|
153
|
-
});
|
|
154
|
-
const logger: Logger = { error: jest.fn() } as unknown as Logger;
|
|
155
|
-
const pm = new ProjectManager(client, logger);
|
|
156
|
-
await expect(pm.getProjectHierarchy('_Root', 2)).rejects.toThrow('nope');
|
|
157
|
-
expect((logger.error as jest.Mock).mock.calls[0]?.[0]).toMatch(
|
|
158
|
-
/Failed to get project hierarchy/
|
|
159
|
-
);
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
it('sortProjects by id and level with desc order', async () => {
|
|
163
|
-
const client = makeClient({});
|
|
164
|
-
const pm = new ProjectManager(client, { error: jest.fn() } as unknown as Logger);
|
|
165
|
-
const projects: Array<{ id: string; name: string; level?: number }> = [
|
|
166
|
-
{ id: 'B', name: 'B', level: 1 },
|
|
167
|
-
{ id: 'A', name: 'A', level: 2 },
|
|
168
|
-
{ id: 'C', name: 'C', level: 0 },
|
|
169
|
-
];
|
|
170
|
-
const byIdDesc = (
|
|
171
|
-
pm as unknown as {
|
|
172
|
-
sortProjects: (
|
|
173
|
-
p: Array<{ id: string; name: string; level?: number }>,
|
|
174
|
-
s: { by?: 'name' | 'id' | 'level'; order?: 'asc' | 'desc' }
|
|
175
|
-
) => Array<{ id: string; name: string; level?: number }>;
|
|
176
|
-
}
|
|
177
|
-
).sortProjects(projects, { by: 'id', order: 'desc' });
|
|
178
|
-
expect(byIdDesc.map((p) => p.id)).toEqual(['C', 'B', 'A']);
|
|
179
|
-
const byLevelDesc = (
|
|
180
|
-
pm as unknown as {
|
|
181
|
-
sortProjects: (
|
|
182
|
-
p: Array<{ id: string; name: string; level?: number }>,
|
|
183
|
-
s: { by?: 'name' | 'id' | 'level'; order?: 'asc' | 'desc' }
|
|
184
|
-
) => Array<{ id: string; name: string; level?: number }>;
|
|
185
|
-
}
|
|
186
|
-
).sortProjects(projects, { by: 'level', order: 'desc' });
|
|
187
|
-
expect(byLevelDesc.map((p) => p.level)).toEqual([2, 1, 0]);
|
|
188
|
-
});
|
|
189
|
-
});
|