unleash-server 4.1.2 → 4.2.0-1
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 +920 -0
- package/README.md +3 -2
- package/dist/lib/addons/addon.js +1 -1
- package/dist/lib/addons/addon.js.map +1 -1
- package/dist/lib/addons/slack.js +9 -9
- package/dist/lib/addons/slack.js.map +1 -1
- package/dist/lib/addons/teams.js +1 -1
- package/dist/lib/addons/teams.js.map +1 -1
- package/dist/lib/app.js +20 -20
- package/dist/lib/app.js.map +1 -1
- package/dist/lib/app.test.js +11 -7
- package/dist/lib/app.test.js.map +1 -1
- package/dist/lib/create-config.js +9 -9
- package/dist/lib/create-config.js.map +1 -1
- package/dist/lib/db/api-token-store.d.ts +2 -1
- package/dist/lib/db/api-token-store.js +5 -0
- package/dist/lib/db/api-token-store.js.map +1 -1
- package/dist/lib/db/client-metrics-store.d.ts +6 -0
- package/dist/lib/db/client-metrics-store.js +6 -1
- package/dist/lib/db/client-metrics-store.js.map +1 -1
- package/dist/lib/db/db-pool.js +1 -1
- package/dist/lib/db/db-pool.js.map +1 -1
- package/dist/lib/db/environment-store.d.ts +7 -7
- package/dist/lib/db/environment-store.js +59 -54
- package/dist/lib/db/environment-store.js.map +1 -1
- package/dist/lib/db/event-store.d.ts +5 -2
- package/dist/lib/db/event-store.js +27 -4
- package/dist/lib/db/event-store.js.map +1 -1
- package/dist/lib/db/event-store.test.js +2 -2
- package/dist/lib/db/event-store.test.js.map +1 -1
- package/dist/lib/db/feature-environment-store.d.ts +8 -6
- package/dist/lib/db/feature-environment-store.js +53 -19
- package/dist/lib/db/feature-environment-store.js.map +1 -1
- package/dist/lib/db/feature-strategy-store.d.ts +7 -11
- package/dist/lib/db/feature-strategy-store.js +77 -147
- package/dist/lib/db/feature-strategy-store.js.map +1 -1
- package/dist/lib/db/feature-toggle-client-store.d.ts +26 -0
- package/dist/lib/db/feature-toggle-client-store.js +106 -0
- package/dist/lib/db/feature-toggle-client-store.js.map +1 -0
- package/dist/lib/db/feature-toggle-store.d.ts +10 -22
- package/dist/lib/db/feature-toggle-store.js +9 -42
- package/dist/lib/db/feature-toggle-store.js.map +1 -1
- package/dist/lib/db/index.js +2 -0
- package/dist/lib/db/index.js.map +1 -1
- package/dist/lib/db/project-store.d.ts +4 -6
- package/dist/lib/db/project-store.js +7 -43
- package/dist/lib/db/project-store.js.map +1 -1
- package/dist/lib/event-hook.test.js +8 -7
- package/dist/lib/event-hook.test.js.map +1 -1
- package/dist/lib/logger.js +1 -1
- package/dist/lib/logger.js.map +1 -1
- package/dist/lib/logger.test.js +26 -4
- package/dist/lib/logger.test.js.map +1 -1
- package/dist/lib/metrics.test.js +3 -3
- package/dist/lib/metrics.test.js.map +1 -1
- package/dist/lib/middleware/api-token-middleware.js +10 -2
- package/dist/lib/middleware/api-token-middleware.js.map +1 -1
- package/dist/lib/middleware/api-token-middleware.test.js +44 -8
- package/dist/lib/middleware/api-token-middleware.test.js.map +1 -1
- package/dist/lib/middleware/content_type_checker.test.js +4 -4
- package/dist/lib/middleware/content_type_checker.test.js.map +1 -1
- package/dist/lib/middleware/demo-authentication.js +1 -1
- package/dist/lib/middleware/demo-authentication.js.map +1 -1
- package/dist/lib/middleware/no-authentication.test.js +3 -3
- package/dist/lib/middleware/no-authentication.test.js.map +1 -1
- package/dist/lib/middleware/oss-authentication.js +0 -3
- package/dist/lib/middleware/oss-authentication.js.map +1 -1
- package/dist/lib/middleware/oss-authentication.test.js +7 -7
- package/dist/lib/middleware/oss-authentication.test.js.map +1 -1
- package/dist/lib/middleware/rbac-middleware.js +2 -2
- package/dist/lib/middleware/rbac-middleware.js.map +1 -1
- package/dist/lib/middleware/rbac-middleware.test.js +51 -12
- package/dist/lib/middleware/rbac-middleware.test.js.map +1 -1
- package/dist/lib/middleware/secure-headers.js +1 -1
- package/dist/lib/middleware/secure-headers.js.map +1 -1
- package/dist/lib/middleware/session-db.js +2 -2
- package/dist/lib/middleware/session-db.js.map +1 -1
- package/dist/lib/routes/admin-api/addon.d.ts +4 -3
- package/dist/lib/routes/admin-api/addon.js +4 -4
- package/dist/lib/routes/admin-api/addon.js.map +1 -1
- package/dist/lib/routes/admin-api/api-token-controller.js +10 -38
- package/dist/lib/routes/admin-api/api-token-controller.js.map +1 -1
- package/dist/lib/routes/admin-api/archive.d.ts +4 -3
- package/dist/lib/routes/admin-api/archive.js +3 -3
- package/dist/lib/routes/admin-api/archive.js.map +1 -1
- package/dist/lib/routes/admin-api/config.test.js +5 -5
- package/dist/lib/routes/admin-api/config.test.js.map +1 -1
- package/dist/lib/routes/admin-api/context.d.ts +4 -3
- package/dist/lib/routes/admin-api/context.js +4 -4
- package/dist/lib/routes/admin-api/context.js.map +1 -1
- package/dist/lib/routes/admin-api/context.test.js +6 -6
- package/dist/lib/routes/admin-api/context.test.js.map +1 -1
- package/dist/lib/routes/admin-api/email.test.js +6 -6
- package/dist/lib/routes/admin-api/email.test.js.map +1 -1
- package/dist/lib/routes/admin-api/environments-controller.d.ts +4 -4
- package/dist/lib/routes/admin-api/environments-controller.js +17 -43
- package/dist/lib/routes/admin-api/environments-controller.js.map +1 -1
- package/dist/lib/routes/admin-api/event.js +7 -1
- package/dist/lib/routes/admin-api/event.js.map +1 -1
- package/dist/lib/routes/admin-api/events.test.js +5 -5
- package/dist/lib/routes/admin-api/events.test.js.map +1 -1
- package/dist/lib/routes/admin-api/feature.d.ts +11 -10
- package/dist/lib/routes/admin-api/feature.js +26 -24
- package/dist/lib/routes/admin-api/feature.js.map +1 -1
- package/dist/lib/routes/admin-api/metrics.js +25 -66
- package/dist/lib/routes/admin-api/metrics.js.map +1 -1
- package/dist/lib/routes/admin-api/metrics.test.js +6 -6
- package/dist/lib/routes/admin-api/metrics.test.js.map +1 -1
- package/dist/lib/routes/admin-api/project/environments.js +6 -15
- package/dist/lib/routes/admin-api/project/environments.js.map +1 -1
- package/dist/lib/routes/admin-api/project/features.d.ts +29 -11
- package/dist/lib/routes/admin-api/project/features.js +97 -35
- package/dist/lib/routes/admin-api/project/features.js.map +1 -1
- package/dist/lib/routes/admin-api/project/health-report.js +7 -18
- package/dist/lib/routes/admin-api/project/health-report.js.map +1 -1
- package/dist/lib/routes/admin-api/project/index.d.ts +3 -0
- package/dist/lib/routes/admin-api/project/index.js +8 -0
- package/dist/lib/routes/admin-api/project/index.js.map +1 -1
- package/dist/lib/routes/admin-api/state.d.ts +2 -1
- package/dist/lib/routes/admin-api/state.js +7 -6
- package/dist/lib/routes/admin-api/state.js.map +1 -1
- package/dist/lib/routes/admin-api/strategy.d.ts +1 -1
- package/dist/lib/routes/admin-api/strategy.js +24 -22
- package/dist/lib/routes/admin-api/strategy.js.map +1 -1
- package/dist/lib/routes/admin-api/strategy.test.js +6 -6
- package/dist/lib/routes/admin-api/strategy.test.js.map +1 -1
- package/dist/lib/routes/admin-api/tag-type.d.ts +4 -3
- package/dist/lib/routes/admin-api/tag-type.js +19 -50
- package/dist/lib/routes/admin-api/tag-type.js.map +1 -1
- package/dist/lib/routes/admin-api/tag.d.ts +3 -2
- package/dist/lib/routes/admin-api/tag.js +3 -4
- package/dist/lib/routes/admin-api/tag.js.map +1 -1
- package/dist/lib/routes/admin-api/tag.test.js +6 -6
- package/dist/lib/routes/admin-api/tag.test.js.map +1 -1
- package/dist/lib/routes/admin-api/user-admin.js +11 -37
- package/dist/lib/routes/admin-api/user-admin.js.map +1 -1
- package/dist/lib/routes/admin-api/user.test.js +5 -5
- package/dist/lib/routes/admin-api/user.test.js.map +1 -1
- package/dist/lib/routes/api-def.d.ts +49 -52
- package/dist/lib/routes/api-def.js +13 -9
- package/dist/lib/routes/api-def.js.map +1 -1
- package/dist/lib/routes/backstage.test.js +5 -5
- package/dist/lib/routes/backstage.test.js.map +1 -1
- package/dist/lib/routes/client-api/feature.d.ts +7 -8
- package/dist/lib/routes/client-api/feature.js +40 -28
- package/dist/lib/routes/client-api/feature.js.map +1 -1
- package/dist/lib/routes/client-api/feature.test.js +15 -15
- package/dist/lib/routes/client-api/feature.test.js.map +1 -1
- package/dist/lib/routes/client-api/metrics.d.ts +3 -2
- package/dist/lib/routes/client-api/metrics.js +8 -13
- package/dist/lib/routes/client-api/metrics.js.map +1 -1
- package/dist/lib/routes/client-api/metrics.test.js +7 -12
- package/dist/lib/routes/client-api/metrics.test.js.map +1 -1
- package/dist/lib/routes/client-api/register.js +3 -14
- package/dist/lib/routes/client-api/register.js.map +1 -1
- package/dist/lib/routes/client-api/register.test.js +5 -5
- package/dist/lib/routes/client-api/register.test.js.map +1 -1
- package/dist/lib/routes/controller.d.ts +1 -0
- package/dist/lib/routes/controller.js +4 -1
- package/dist/lib/routes/controller.js.map +1 -1
- package/dist/lib/routes/health-check.test.js +9 -9
- package/dist/lib/routes/health-check.test.js.map +1 -1
- package/dist/lib/routes/index.js +5 -5
- package/dist/lib/routes/index.js.map +1 -1
- package/dist/lib/routes/index.test.js +5 -5
- package/dist/lib/routes/index.test.js.map +1 -1
- package/dist/lib/routes/logout.test.js +15 -15
- package/dist/lib/routes/logout.test.js.map +1 -1
- package/dist/lib/routes/unleash-types.d.ts +1 -2
- package/dist/lib/routes/util.js +1 -0
- package/dist/lib/routes/util.js.map +1 -1
- package/dist/lib/schema/api-token-schema.d.ts +2 -0
- package/dist/lib/schema/api-token-schema.js +28 -0
- package/dist/lib/schema/api-token-schema.js.map +1 -0
- package/dist/lib/schema/feature-schema.test.js +17 -16
- package/dist/lib/schema/feature-schema.test.js.map +1 -1
- package/dist/lib/schema/project-schema.d.ts +2 -0
- package/dist/lib/schema/project-schema.js +12 -0
- package/dist/lib/schema/project-schema.js.map +1 -0
- package/dist/lib/server-impl.d.ts +2 -2
- package/dist/lib/server-impl.js +20 -18
- package/dist/lib/server-impl.js.map +1 -1
- package/dist/lib/server-impl.test.js +28 -21
- package/dist/lib/server-impl.test.js.map +1 -1
- package/dist/lib/services/access-service.d.ts +1 -1
- package/dist/lib/services/access-service.js.map +1 -1
- package/dist/lib/services/addon-service.js +2 -2
- package/dist/lib/services/addon-service.js.map +1 -1
- package/dist/lib/services/addon-service.test.js +1 -1
- package/dist/lib/services/addon-service.test.js.map +1 -1
- package/dist/lib/services/api-token-service.d.ts +3 -8
- package/dist/lib/services/api-token-service.js +43 -8
- package/dist/lib/services/api-token-service.js.map +1 -1
- package/dist/lib/services/client-metrics/client-metrics-schema.js +1 -0
- package/dist/lib/services/client-metrics/client-metrics-schema.js.map +1 -1
- package/dist/lib/services/client-metrics/client-metrics.test.js +18 -18
- package/dist/lib/services/client-metrics/client-metrics.test.js.map +1 -1
- package/dist/lib/services/client-metrics/index.js +5 -3
- package/dist/lib/services/client-metrics/index.js.map +1 -1
- package/dist/lib/services/context-schema.d.ts +3 -3
- package/dist/lib/services/context-schema.js +15 -11
- package/dist/lib/services/context-schema.js.map +1 -1
- package/dist/lib/services/email-service.js +5 -5
- package/dist/lib/services/email-service.js.map +1 -1
- package/dist/lib/services/environment-service.d.ts +4 -5
- package/dist/lib/services/environment-service.js +14 -14
- package/dist/lib/services/environment-service.js.map +1 -1
- package/dist/lib/services/event-service.d.ts +1 -0
- package/dist/lib/services/event-service.js +4 -3
- package/dist/lib/services/event-service.js.map +1 -1
- package/dist/lib/services/feature-toggle-service-v2.d.ts +27 -12
- package/dist/lib/services/feature-toggle-service-v2.js +157 -55
- package/dist/lib/services/feature-toggle-service-v2.js.map +1 -1
- package/dist/lib/services/index.js +1 -1
- package/dist/lib/services/index.js.map +1 -1
- package/dist/lib/services/project-health-service.d.ts +3 -1
- package/dist/lib/services/project-health-service.js +7 -3
- package/dist/lib/services/project-health-service.js.map +1 -1
- package/dist/lib/services/project-schema.d.ts +2 -3
- package/dist/lib/services/project-schema.js +12 -7
- package/dist/lib/services/project-schema.js.map +1 -1
- package/dist/lib/services/project-service.d.ts +4 -2
- package/dist/lib/services/project-service.js +21 -11
- package/dist/lib/services/project-service.js.map +1 -1
- package/dist/lib/services/state-schema.d.ts +2 -0
- package/dist/lib/services/state-schema.js +16 -6
- package/dist/lib/services/state-schema.js.map +1 -1
- package/dist/lib/services/state-service.d.ts +7 -0
- package/dist/lib/services/state-service.js +75 -17
- package/dist/lib/services/state-service.js.map +1 -1
- package/dist/lib/services/state-service.test.js +73 -28
- package/dist/lib/services/state-service.test.js.map +1 -1
- package/dist/lib/services/state-util.js +1 -1
- package/dist/lib/services/state-util.js.map +1 -1
- package/dist/lib/services/user-service.js +1 -1
- package/dist/lib/services/user-service.js.map +1 -1
- package/dist/lib/services/user-service.test.js +1 -1
- package/dist/lib/services/user-service.test.js.map +1 -1
- package/dist/lib/services/version-service.js +1 -1
- package/dist/lib/services/version-service.js.map +1 -1
- package/dist/lib/services/version-service.test.js +3 -3
- package/dist/lib/services/version-service.test.js.map +1 -1
- package/dist/lib/types/api-user.d.ts +11 -4
- package/dist/lib/types/api-user.js +4 -1
- package/dist/lib/types/api-user.js.map +1 -1
- package/dist/lib/types/events.d.ts +7 -0
- package/dist/lib/types/events.js +9 -1
- package/dist/lib/types/events.js.map +1 -1
- package/dist/lib/types/model.d.ts +25 -7
- package/dist/lib/types/model.js.map +1 -1
- package/dist/lib/types/models/api-token.d.ts +19 -0
- package/dist/lib/types/models/api-token.js +10 -0
- package/dist/lib/types/models/api-token.js.map +1 -0
- package/dist/lib/types/permissions.d.ts +2 -0
- package/dist/lib/types/permissions.js +3 -1
- package/dist/lib/types/permissions.js.map +1 -1
- package/dist/lib/types/stores/api-token-store.d.ts +1 -14
- package/dist/lib/types/stores/api-token-store.js +0 -6
- package/dist/lib/types/stores/api-token-store.js.map +1 -1
- package/dist/lib/types/stores/environment-store.d.ts +6 -6
- package/dist/lib/types/stores/event-store.d.ts +1 -0
- package/dist/lib/types/stores/feature-environment-store.d.ts +8 -6
- package/dist/lib/types/stores/feature-strategies-store.d.ts +6 -12
- package/dist/lib/types/stores/feature-toggle-client-store.d.ts +5 -0
- package/dist/lib/types/stores/feature-toggle-client-store.js +3 -0
- package/dist/lib/types/stores/feature-toggle-client-store.js.map +1 -0
- package/dist/lib/types/stores/feature-toggle-store.d.ts +7 -14
- package/dist/lib/types/stores/project-store.d.ts +5 -2
- package/dist/lib/types/stores.d.ts +2 -0
- package/dist/lib/types/user.js +1 -1
- package/dist/lib/types/user.js.map +1 -1
- package/dist/lib/util/constants.d.ts +1 -0
- package/dist/lib/util/constants.js +2 -1
- package/dist/lib/util/constants.js.map +1 -1
- package/dist/lib/util/extract-user.d.ts +2 -0
- package/dist/lib/util/extract-user.js +8 -0
- package/dist/lib/util/extract-user.js.map +1 -0
- package/dist/lib/util/format-base-uri.test.js +6 -6
- package/dist/lib/util/format-base-uri.test.js.map +1 -1
- package/dist/lib/util/graceful-shutdown.js +1 -1
- package/dist/lib/util/graceful-shutdown.js.map +1 -1
- package/dist/lib/util/rewriteHTML.test.js +4 -4
- package/dist/lib/util/rewriteHTML.test.js.map +1 -1
- package/dist/lib/util/snakeCase.d.ts +6 -0
- package/dist/lib/util/snakeCase.js +28 -0
- package/dist/lib/util/snakeCase.js.map +1 -0
- package/dist/{test/e2e/api/admin/boostrap.test.d.ts → lib/util/snakeCase.test.d.ts} +0 -0
- package/dist/lib/util/snakeCase.test.js +23 -0
- package/dist/lib/util/snakeCase.test.js.map +1 -0
- package/dist/migrations/20210831072631-add-sort-order-and-type-to-env.d.ts +5 -0
- package/dist/migrations/20210831072631-add-sort-order-and-type-to-env.js +14 -0
- package/dist/migrations/20210831072631-add-sort-order-and-type-to-env.js.map +1 -0
- package/dist/migrations/20210907124058-add-dbcritic-indices.d.ts +5 -0
- package/dist/migrations/20210907124058-add-dbcritic-indices.js +30 -0
- package/dist/migrations/20210907124058-add-dbcritic-indices.js.map +1 -0
- package/dist/migrations/20210907124850-add-dbcritic-primary-keys.d.ts +5 -0
- package/dist/migrations/20210907124850-add-dbcritic-primary-keys.js +18 -0
- package/dist/migrations/20210907124850-add-dbcritic-primary-keys.js.map +1 -0
- package/dist/migrations/20210908100701-add-enabled-to-environments.d.ts +5 -0
- package/dist/migrations/20210908100701-add-enabled-to-environments.js +14 -0
- package/dist/migrations/20210908100701-add-enabled-to-environments.js.map +1 -0
- package/dist/migrations/20210909085651-add-protected-field-to-environments.d.ts +5 -0
- package/dist/migrations/20210909085651-add-protected-field-to-environments.js +15 -0
- package/dist/migrations/20210909085651-add-protected-field-to-environments.js.map +1 -0
- package/dist/migrations/20210913103159-api-keys-scoping.d.ts +2 -0
- package/dist/migrations/20210913103159-api-keys-scoping.js +13 -0
- package/dist/migrations/20210913103159-api-keys-scoping.js.map +1 -0
- package/dist/migrations/20210915122001-add-project-and-environment-columns-to-events.d.ts +2 -0
- package/dist/migrations/20210915122001-add-project-and-environment-columns-to-events.js +22 -0
- package/dist/migrations/20210915122001-add-project-and-environment-columns-to-events.js.map +1 -0
- package/dist/migrations/20210920104218-rename-global-env-to-default-env.d.ts +2 -0
- package/dist/migrations/20210920104218-rename-global-env-to-default-env.js +25 -0
- package/dist/migrations/20210920104218-rename-global-env-to-default-env.js.map +1 -0
- package/dist/migrations/20210921105032-client-api-tokens-default.d.ts +2 -0
- package/dist/migrations/20210921105032-client-api-tokens-default.js +13 -0
- package/dist/migrations/20210921105032-client-api-tokens-default.js.map +1 -0
- package/dist/migrations/20210922084509-add-non-null-constraint-to-environment-type.d.ts +2 -0
- package/dist/migrations/20210922084509-add-non-null-constraint-to-environment-type.js +10 -0
- package/dist/migrations/20210922084509-add-non-null-constraint-to-environment-type.js.map +1 -0
- package/dist/migrations/20210922120521-add-tag-type-permission.d.ts +2 -0
- package/dist/migrations/20210922120521-add-tag-type-permission.js +19 -0
- package/dist/migrations/20210922120521-add-tag-type-permission.js.map +1 -0
- package/dist/migrations/20210928065411-remove-displayname-from-environments.d.ts +2 -0
- package/dist/migrations/20210928065411-remove-displayname-from-environments.js +10 -0
- package/dist/migrations/20210928065411-remove-displayname-from-environments.js.map +1 -0
- package/dist/migrations/20210928080601-add-development-and-production-environments.d.ts +2 -0
- package/dist/migrations/20210928080601-add-development-and-production-environments.js +16 -0
- package/dist/migrations/20210928080601-add-development-and-production-environments.js.map +1 -0
- package/dist/migrations/20210928082228-connect-default-environment-to-all-existing-projects.d.ts +2 -0
- package/dist/migrations/20210928082228-connect-default-environment-to-all-existing-projects.js +16 -0
- package/dist/migrations/20210928082228-connect-default-environment-to-all-existing-projects.js.map +1 -0
- package/dist/migrator.d.ts +3 -4
- package/dist/migrator.js +19 -5
- package/dist/migrator.js.map +1 -1
- package/dist/server-dev.js +1 -1
- package/dist/server-dev.js.map +1 -1
- package/dist/test/config/create-config.test.js +20 -20
- package/dist/test/config/create-config.test.js.map +1 -1
- package/dist/test/config/test-config.js +1 -1
- package/dist/test/config/test-config.js.map +1 -1
- package/dist/test/e2e/api/admin/addon.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/addon.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/api-token.auth.e2e.test.js +8 -8
- package/dist/test/e2e/api/admin/api-token.auth.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/api-token.e2e.test.js +161 -12
- package/dist/test/e2e/api/admin/api-token.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/archive.test.js +2 -2
- package/dist/test/e2e/api/admin/archive.test.js.map +1 -1
- package/dist/test/e2e/api/admin/bootstrap.test.d.ts +1 -0
- package/dist/test/e2e/api/admin/{boostrap.test.js → bootstrap.test.js} +3 -3
- package/dist/test/e2e/api/admin/bootstrap.test.js.map +1 -0
- package/dist/test/e2e/api/admin/context.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/context.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/environment.test.js +82 -55
- package/dist/test/e2e/api/admin/environment.test.js.map +1 -1
- package/dist/test/e2e/api/admin/event.e2e.test.js +30 -2
- package/dist/test/e2e/api/admin/event.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/feature-archive.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/feature-archive.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/feature-type.test.js +2 -2
- package/dist/test/e2e/api/admin/feature-type.test.js.map +1 -1
- package/dist/test/e2e/api/admin/feature.auth.e2e.test.js +3 -3
- package/dist/test/e2e/api/admin/feature.auth.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/feature.custom-auth.e2e.test.js +3 -3
- package/dist/test/e2e/api/admin/feature.custom-auth.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/feature.e2e.test.js +71 -65
- package/dist/test/e2e/api/admin/feature.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/feedback.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/feedback.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/metrics.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/metrics.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/project/environments.e2e.test.d.ts +1 -0
- package/dist/test/e2e/api/admin/project/environments.e2e.test.js +65 -0
- package/dist/test/e2e/api/admin/project/environments.e2e.test.js.map +1 -0
- package/dist/test/e2e/api/admin/project/feature.strategy.e2e.test.js +503 -72
- package/dist/test/e2e/api/admin/project/feature.strategy.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/project/project.health.e2e.test.js +4 -2
- package/dist/test/e2e/api/admin/project/project.health.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/project/projects.e2e.test.d.ts +1 -0
- package/dist/test/e2e/api/admin/project/projects.e2e.test.js +30 -0
- package/dist/test/e2e/api/admin/project/projects.e2e.test.js.map +1 -0
- package/dist/test/e2e/api/admin/state.e2e.test.js +163 -2
- package/dist/test/e2e/api/admin/state.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/strategy.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/strategy.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/tag-types.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/tag-types.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/tags.e2e.test.js +2 -2
- package/dist/test/e2e/api/admin/tags.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/user-admin.e2e.test.js +3 -3
- package/dist/test/e2e/api/admin/user-admin.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/admin/user.test.js +2 -2
- package/dist/test/e2e/api/admin/user.test.js.map +1 -1
- package/dist/test/e2e/api/auth/reset-password-controller.e2e.test.js +5 -5
- package/dist/test/e2e/api/auth/reset-password-controller.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/client/feature.e2e.test.js +74 -19
- package/dist/test/e2e/api/client/feature.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/client/feature.env.disabled.e2e.test.d.ts +1 -0
- package/dist/test/e2e/api/client/feature.env.disabled.e2e.test.js +49 -0
- package/dist/test/e2e/api/client/feature.env.disabled.e2e.test.js.map +1 -0
- package/dist/test/e2e/api/client/feature.token.access.e2e.test.d.ts +1 -0
- package/dist/test/e2e/api/client/feature.token.access.e2e.test.js +156 -0
- package/dist/test/e2e/api/client/feature.token.access.e2e.test.js.map +1 -0
- package/dist/test/e2e/api/client/metrics.e2e.access.e2e.test.d.ts +1 -0
- package/dist/test/e2e/api/client/metrics.e2e.access.e2e.test.js +42 -0
- package/dist/test/e2e/api/client/metrics.e2e.access.e2e.test.js.map +1 -0
- package/dist/test/e2e/api/client/metrics.e2e.test.js +12 -8
- package/dist/test/e2e/api/client/metrics.e2e.test.js.map +1 -1
- package/dist/test/e2e/api/client/register.e2e.test.js +18 -14
- package/dist/test/e2e/api/client/register.e2e.test.js.map +1 -1
- package/dist/test/e2e/custom-auth.test.js +3 -3
- package/dist/test/e2e/custom-auth.test.js.map +1 -1
- package/dist/test/e2e/health.e2e.test.js +2 -2
- package/dist/test/e2e/health.e2e.test.js.map +1 -1
- package/dist/test/e2e/helpers/database-config.d.ts +1 -1
- package/dist/test/e2e/helpers/database-config.js +12 -8
- package/dist/test/e2e/helpers/database-config.js.map +1 -1
- package/dist/test/e2e/helpers/database-init.d.ts +7 -1
- package/dist/test/e2e/helpers/database-init.js +12 -11
- package/dist/test/e2e/helpers/database-init.js.map +1 -1
- package/dist/test/e2e/helpers/database.json +5 -2
- package/dist/test/e2e/helpers/test-helper.js +4 -4
- package/dist/test/e2e/helpers/test-helper.js.map +1 -1
- package/dist/test/e2e/routes/routes.test.js +2 -2
- package/dist/test/e2e/routes/routes.test.js.map +1 -1
- package/dist/test/e2e/services/access-service.e2e.test.js +1 -1
- package/dist/test/e2e/services/access-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/addon-service.e2e.test.js +2 -2
- package/dist/test/e2e/services/addon-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/api-token-service.e2e.test.js +30 -17
- package/dist/test/e2e/services/api-token-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/environment-service.test.js +38 -40
- package/dist/test/e2e/services/environment-service.test.js.map +1 -1
- package/dist/test/e2e/services/feature-toggle-service-v2.e2e.test.js +19 -13
- package/dist/test/e2e/services/feature-toggle-service-v2.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/project-health-service.e2e.test.js +12 -12
- package/dist/test/e2e/services/project-health-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/project-service.e2e.test.js +27 -4
- package/dist/test/e2e/services/project-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/reset-token-service.e2e.test.js +3 -3
- package/dist/test/e2e/services/reset-token-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/session-service.e2e.test.js +1 -1
- package/dist/test/e2e/services/session-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/services/setting-service.test.js +2 -2
- package/dist/test/e2e/services/setting-service.test.js.map +1 -1
- package/dist/test/e2e/services/user-service.e2e.test.js +2 -2
- package/dist/test/e2e/services/user-service.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/client-application-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/client-application-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/event-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/event-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/feature-tag-store.e2e.test.js +4 -4
- package/dist/test/e2e/stores/feature-tag-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/feature-toggle-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/feature-toggle-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/feature-type-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/feature-type-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/project-store.e2e.test.js +5 -2
- package/dist/test/e2e/stores/project-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/setting-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/setting-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/user-feedback-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/user-feedback-store.e2e.test.js.map +1 -1
- package/dist/test/e2e/stores/user-store.e2e.test.js +1 -1
- package/dist/test/e2e/stores/user-store.e2e.test.js.map +1 -1
- package/dist/test/fixtures/fake-api-token-store.d.ts +2 -1
- package/dist/test/fixtures/fake-api-token-store.js.map +1 -1
- package/dist/test/fixtures/fake-environment-store.d.ts +5 -3
- package/dist/test/fixtures/fake-environment-store.js +22 -15
- package/dist/test/fixtures/fake-environment-store.js.map +1 -1
- package/dist/test/fixtures/fake-event-store.d.ts +1 -0
- package/dist/test/fixtures/fake-event-store.js +3 -0
- package/dist/test/fixtures/fake-event-store.js.map +1 -1
- package/dist/test/fixtures/fake-feature-environment-store.d.ts +7 -5
- package/dist/test/fixtures/fake-feature-environment-store.js +31 -10
- package/dist/test/fixtures/fake-feature-environment-store.js.map +1 -1
- package/dist/test/fixtures/fake-feature-strategies-store.d.ts +7 -13
- package/dist/test/fixtures/fake-feature-strategies-store.js +14 -51
- package/dist/test/fixtures/fake-feature-strategies-store.js.map +1 -1
- package/dist/test/fixtures/fake-feature-toggle-client-store.d.ts +9 -0
- package/dist/test/fixtures/fake-feature-toggle-client-store.js +50 -0
- package/dist/test/fixtures/fake-feature-toggle-client-store.js.map +1 -0
- package/dist/test/fixtures/fake-feature-toggle-store.d.ts +7 -9
- package/dist/test/fixtures/fake-feature-toggle-store.js +7 -14
- package/dist/test/fixtures/fake-feature-toggle-store.js.map +1 -1
- package/dist/test/fixtures/fake-project-store.d.ts +1 -2
- package/dist/test/fixtures/fake-project-store.js +0 -7
- package/dist/test/fixtures/fake-project-store.js.map +1 -1
- package/dist/test/fixtures/permissions.d.ts +3 -3
- package/dist/test/fixtures/permissions.js +5 -4
- package/dist/test/fixtures/permissions.js.map +1 -1
- package/dist/test/fixtures/store.js +2 -0
- package/dist/test/fixtures/store.js.map +1 -1
- package/package.json +51 -45
- package/dist/lib/extract-user.d.ts +0 -2
- package/dist/lib/extract-user.js +0 -6
- package/dist/lib/extract-user.js.map +0 -1
- package/dist/test/e2e/api/admin/boostrap.test.js.map +0 -1
- package/docs/api/oas/swagger-ui-bundle.js +0 -3
- package/docs/api/oas/swagger-ui-bundle.js.map +0 -1
- package/docs/api/oas/swagger-ui-es-bundle-core.js +0 -3
- package/docs/api/oas/swagger-ui-es-bundle-core.js.map +0 -1
- package/docs/api/oas/swagger-ui-es-bundle.js +0 -3
- package/docs/api/oas/swagger-ui-es-bundle.js.map +0 -1
- package/docs/api/oas/swagger-ui-standalone-preset.js +0 -3
- package/docs/api/oas/swagger-ui-standalone-preset.js.map +0 -1
- package/docs/api/oas/swagger-ui.css +0 -8906
- package/docs/api/oas/swagger-ui.css.map +0 -1
- package/docs/api/oas/swagger-ui.js +0 -3
- package/docs/api/oas/swagger-ui.js.map +0 -1
- package/docs/api/oas/swagger.json +0 -1479
|
@@ -6,40 +6,17 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
const database_init_1 = __importDefault(require("../../helpers/database-init"));
|
|
7
7
|
const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
|
|
8
8
|
const test_helper_1 = require("../../helpers/test-helper");
|
|
9
|
+
const constants_1 = require("../../../../lib/util/constants");
|
|
9
10
|
let app;
|
|
10
11
|
let db;
|
|
11
12
|
beforeAll(async () => {
|
|
12
|
-
db = await database_init_1.default('environment_api_serial', no_logger_1.default);
|
|
13
|
-
app = await test_helper_1.setupApp(db.stores);
|
|
13
|
+
db = await (0, database_init_1.default)('environment_api_serial', no_logger_1.default);
|
|
14
|
+
app = await (0, test_helper_1.setupApp)(db.stores);
|
|
14
15
|
});
|
|
15
16
|
afterAll(async () => {
|
|
16
17
|
await app.destroy();
|
|
17
18
|
await db.destroy();
|
|
18
19
|
});
|
|
19
|
-
test('Should be able to create an environment', async () => {
|
|
20
|
-
const envName = 'environment-info';
|
|
21
|
-
// Create environment
|
|
22
|
-
await app.request
|
|
23
|
-
.post('/api/admin/environments')
|
|
24
|
-
.send({
|
|
25
|
-
name: envName,
|
|
26
|
-
displayName: 'Enable feature for environment',
|
|
27
|
-
})
|
|
28
|
-
.set('Content-Type', 'application/json')
|
|
29
|
-
.expect(201);
|
|
30
|
-
});
|
|
31
|
-
test('Environment names must be URL safe', async () => {
|
|
32
|
-
const envName = 'Something not url safe **/ */21312';
|
|
33
|
-
// Create environment
|
|
34
|
-
await app.request
|
|
35
|
-
.post('/api/admin/environments')
|
|
36
|
-
.send({
|
|
37
|
-
name: envName,
|
|
38
|
-
displayName: 'Enable feature for environment',
|
|
39
|
-
})
|
|
40
|
-
.set('Content-Type', 'application/json')
|
|
41
|
-
.expect(400);
|
|
42
|
-
});
|
|
43
20
|
test('Can list all existing environments', async () => {
|
|
44
21
|
await app.request
|
|
45
22
|
.get('/api/admin/environments')
|
|
@@ -48,53 +25,103 @@ test('Can list all existing environments', async () => {
|
|
|
48
25
|
.expect((res) => {
|
|
49
26
|
expect(res.body.version).toBe(1);
|
|
50
27
|
expect(res.body.environments[0]).toStrictEqual({
|
|
51
|
-
|
|
52
|
-
|
|
28
|
+
name: constants_1.DEFAULT_ENV,
|
|
29
|
+
enabled: true,
|
|
30
|
+
sortOrder: 1,
|
|
31
|
+
type: 'production',
|
|
32
|
+
protected: true,
|
|
53
33
|
});
|
|
54
34
|
});
|
|
55
35
|
});
|
|
56
|
-
test('Can
|
|
57
|
-
const envName = '
|
|
58
|
-
|
|
36
|
+
test('Can update sort order', async () => {
|
|
37
|
+
const envName = 'update-sort-order';
|
|
38
|
+
await db.stores.environmentStore.create({
|
|
39
|
+
name: envName,
|
|
40
|
+
type: 'production',
|
|
41
|
+
});
|
|
59
42
|
await app.request
|
|
60
|
-
.
|
|
43
|
+
.put('/api/admin/environments/sort-order')
|
|
61
44
|
.send({
|
|
62
|
-
|
|
63
|
-
|
|
45
|
+
[constants_1.DEFAULT_ENV]: 2,
|
|
46
|
+
[envName]: 1,
|
|
64
47
|
})
|
|
65
|
-
.
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
48
|
+
.expect(200);
|
|
49
|
+
await app.request
|
|
50
|
+
.get('/api/admin/environments')
|
|
51
|
+
.expect(200)
|
|
52
|
+
.expect('Content-Type', /json/)
|
|
53
|
+
.expect((res) => {
|
|
54
|
+
const updatedSort = res.body.environments.find((t) => t.name === envName);
|
|
55
|
+
const defaultEnv = res.body.environments.find((t) => t.name === constants_1.DEFAULT_ENV);
|
|
56
|
+
expect(updatedSort.sortOrder).toBe(1);
|
|
57
|
+
expect(defaultEnv.sortOrder).toBe(2);
|
|
58
|
+
});
|
|
70
59
|
});
|
|
71
|
-
test('
|
|
72
|
-
const envName = '
|
|
73
|
-
// Create environment
|
|
60
|
+
test('Sort order will fail on wrong data format', async () => {
|
|
61
|
+
const envName = 'sort-order-env';
|
|
74
62
|
await app.request
|
|
75
|
-
.
|
|
63
|
+
.put('/api/admin/environments/sort-order')
|
|
76
64
|
.send({
|
|
77
|
-
|
|
78
|
-
|
|
65
|
+
[constants_1.DEFAULT_ENV]: 'test',
|
|
66
|
+
[envName]: 1,
|
|
79
67
|
})
|
|
68
|
+
.expect(400);
|
|
69
|
+
});
|
|
70
|
+
test('Can update environment enabled status', async () => {
|
|
71
|
+
const envName = 'enable-environment';
|
|
72
|
+
await db.stores.environmentStore.create({
|
|
73
|
+
name: envName,
|
|
74
|
+
type: 'production',
|
|
75
|
+
});
|
|
76
|
+
await app.request
|
|
77
|
+
.post(`/api/admin/environments/${envName}/on`)
|
|
80
78
|
.set('Content-Type', 'application/json')
|
|
81
|
-
.expect(
|
|
82
|
-
|
|
79
|
+
.expect(204);
|
|
80
|
+
});
|
|
81
|
+
test('Can update environment disabled status', async () => {
|
|
82
|
+
const envName = 'disable-environment';
|
|
83
|
+
await db.stores.environmentStore.create({
|
|
84
|
+
name: envName,
|
|
85
|
+
type: 'production',
|
|
86
|
+
});
|
|
83
87
|
await app.request
|
|
84
|
-
.
|
|
85
|
-
.
|
|
86
|
-
.expect(
|
|
88
|
+
.post(`/api/admin/environments/${envName}/off`)
|
|
89
|
+
.set('Content-Type', 'application/json')
|
|
90
|
+
.expect(204);
|
|
91
|
+
});
|
|
92
|
+
test('Can not update non-existing environment enabled status', async () => {
|
|
93
|
+
const envName = 'non-existing-env';
|
|
94
|
+
await app.request
|
|
95
|
+
.post(`/api/admin/environments/${envName}/on`)
|
|
96
|
+
.set('Content-Type', 'application/json')
|
|
97
|
+
.expect(404);
|
|
98
|
+
});
|
|
99
|
+
test('Can not update non-existing environment disabled status', async () => {
|
|
100
|
+
const envName = 'non-existing-env';
|
|
101
|
+
await app.request
|
|
102
|
+
.post(`/api/admin/environments/${envName}/off`)
|
|
103
|
+
.set('Content-Type', 'application/json')
|
|
104
|
+
.expect(404);
|
|
105
|
+
});
|
|
106
|
+
test('Can get specific environment', async () => {
|
|
107
|
+
const envName = 'get-specific';
|
|
108
|
+
await db.stores.environmentStore.create({
|
|
109
|
+
name: envName,
|
|
110
|
+
type: 'production',
|
|
111
|
+
});
|
|
87
112
|
await app.request
|
|
88
113
|
.get(`/api/admin/environments/${envName}`)
|
|
114
|
+
.expect(200)
|
|
115
|
+
.expect('Content-Type', /json/)
|
|
89
116
|
.expect((res) => {
|
|
90
|
-
|
|
117
|
+
const { body } = res;
|
|
118
|
+
expect(body.name).toBe(envName);
|
|
119
|
+
expect(body.type).toBe('production');
|
|
91
120
|
});
|
|
92
121
|
});
|
|
93
|
-
test('
|
|
94
|
-
const envName = 'non-existing-env';
|
|
122
|
+
test('Getting a non existing environment yields 404', async () => {
|
|
95
123
|
await app.request
|
|
96
|
-
.
|
|
97
|
-
.send({ displayName: 'Update this' })
|
|
124
|
+
.get('/api/admin/environments/this-does-not-exist')
|
|
98
125
|
.expect(404);
|
|
99
126
|
});
|
|
100
127
|
//# sourceMappingURL=environment.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"environment.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/environment.test.ts"],"names":[],"mappings":";;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"environment.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/environment.test.ts"],"names":[],"mappings":";;;;;AAAA,gFAA8D;AAC9D,4EAAoD;AACpD,2DAAmE;AACnE,8DAA6D;AAE7D,IAAI,GAAiB,CAAC;AACtB,IAAI,EAAW,CAAC;AAEhB,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,IAAA,uBAAM,EAAC,wBAAwB,EAAE,mBAAS,CAAC,CAAC;IACvD,GAAG,GAAG,MAAM,IAAA,sBAAQ,EAAC,EAAE,CAAC,MAAM,CAAC,CAAC;AACpC,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,KAAK,IAAI,EAAE;IAChB,MAAM,GAAG,CAAC,OAAO,EAAE,CAAC;IACpB,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;AACvB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;IAClD,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,yBAAyB,CAAC;SAC9B,MAAM,CAAC,GAAG,CAAC;SACX,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC;SAC9B,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACZ,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAC3C,IAAI,EAAE,uBAAW;YACjB,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,CAAC;YACZ,IAAI,EAAE,YAAY;YAClB,SAAS,EAAE,IAAI;SAClB,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACX,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;IACrC,MAAM,OAAO,GAAG,mBAAmB,CAAC;IACpC,MAAM,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC;QACpC,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,YAAY;KACrB,CAAC,CAAC;IACH,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,oCAAoC,CAAC;SACzC,IAAI,CAAC;QACF,CAAC,uBAAW,CAAC,EAAE,CAAC;QAChB,CAAC,OAAO,CAAC,EAAE,CAAC;KACf,CAAC;SACD,MAAM,CAAC,GAAG,CAAC,CAAC;IAEjB,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,yBAAyB,CAAC;SAC9B,MAAM,CAAC,GAAG,CAAC;SACX,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC;SAC9B,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACZ,MAAM,WAAW,GAAG,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAC1C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAC5B,CAAC;QACF,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CACzC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,uBAAW,CAChC,CAAC;QACF,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACX,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;IACzD,MAAM,OAAO,GAAG,gBAAgB,CAAC;IAEjC,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,oCAAoC,CAAC;SACzC,IAAI,CAAC;QACF,CAAC,uBAAW,CAAC,EAAE,MAAM;QACrB,CAAC,OAAO,CAAC,EAAE,CAAC;KACf,CAAC;SACD,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;IACrD,MAAM,OAAO,GAAG,oBAAoB,CAAC;IACrC,MAAM,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC;QACpC,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,YAAY;KACrB,CAAC,CAAC;IACH,MAAM,GAAG,CAAC,OAAO;SACZ,IAAI,CAAC,2BAA2B,OAAO,KAAK,CAAC;SAC7C,GAAG,CAAC,cAAc,EAAE,kBAAkB,CAAC;SACvC,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;IACtD,MAAM,OAAO,GAAG,qBAAqB,CAAC;IAEtC,MAAM,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC;QACpC,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,YAAY;KACrB,CAAC,CAAC;IAEH,MAAM,GAAG,CAAC,OAAO;SACZ,IAAI,CAAC,2BAA2B,OAAO,MAAM,CAAC;SAC9C,GAAG,CAAC,cAAc,EAAE,kBAAkB,CAAC;SACvC,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;IACtE,MAAM,OAAO,GAAG,kBAAkB,CAAC;IAEnC,MAAM,GAAG,CAAC,OAAO;SACZ,IAAI,CAAC,2BAA2B,OAAO,KAAK,CAAC;SAC7C,GAAG,CAAC,cAAc,EAAE,kBAAkB,CAAC;SACvC,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;IACvE,MAAM,OAAO,GAAG,kBAAkB,CAAC;IAEnC,MAAM,GAAG,CAAC,OAAO;SACZ,IAAI,CAAC,2BAA2B,OAAO,MAAM,CAAC;SAC9C,GAAG,CAAC,cAAc,EAAE,kBAAkB,CAAC;SACvC,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;IAC5C,MAAM,OAAO,GAAG,cAAc,CAAC;IAC/B,MAAM,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC;QACpC,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,YAAY;KACrB,CAAC,CAAC;IACH,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,2BAA2B,OAAO,EAAE,CAAC;SACzC,MAAM,CAAC,GAAG,CAAC;SACX,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC;SAC9B,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACZ,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC;QACrB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACX,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;IAC7D,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,6CAA6C,CAAC;SAClD,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC"}
|
|
@@ -6,11 +6,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
const test_helper_1 = require("../../helpers/test-helper");
|
|
7
7
|
const database_init_1 = __importDefault(require("../../helpers/database-init"));
|
|
8
8
|
const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
|
|
9
|
+
const events_1 = require("../../../../lib/types/events");
|
|
9
10
|
let app;
|
|
10
11
|
let db;
|
|
12
|
+
let eventStore;
|
|
11
13
|
beforeAll(async () => {
|
|
12
|
-
db = await database_init_1.default('event_api_serial', no_logger_1.default);
|
|
13
|
-
app = await test_helper_1.setupApp(db.stores);
|
|
14
|
+
db = await (0, database_init_1.default)('event_api_serial', no_logger_1.default);
|
|
15
|
+
app = await (0, test_helper_1.setupApp)(db.stores);
|
|
16
|
+
eventStore = db.stores.eventStore;
|
|
14
17
|
});
|
|
15
18
|
afterAll(async () => {
|
|
16
19
|
await app.destroy();
|
|
@@ -30,4 +33,29 @@ test('returns events given a name', async () => {
|
|
|
30
33
|
.expect('Content-Type', /json/)
|
|
31
34
|
.expect(200);
|
|
32
35
|
});
|
|
36
|
+
test('Can filter by project', async () => {
|
|
37
|
+
await eventStore.store({
|
|
38
|
+
type: events_1.FEATURE_CREATED,
|
|
39
|
+
project: 'something-else',
|
|
40
|
+
data: { id: 'some-other-feature' },
|
|
41
|
+
tags: [],
|
|
42
|
+
createdBy: 'test-user',
|
|
43
|
+
environment: 'test',
|
|
44
|
+
});
|
|
45
|
+
await eventStore.store({
|
|
46
|
+
type: events_1.FEATURE_CREATED,
|
|
47
|
+
project: 'default',
|
|
48
|
+
data: { id: 'feature' },
|
|
49
|
+
tags: [],
|
|
50
|
+
createdBy: 'test-user',
|
|
51
|
+
environment: 'test',
|
|
52
|
+
});
|
|
53
|
+
await app.request
|
|
54
|
+
.get('/api/admin/events?project=default')
|
|
55
|
+
.expect(200)
|
|
56
|
+
.expect((res) => {
|
|
57
|
+
expect(res.body.events).toHaveLength(1);
|
|
58
|
+
expect(res.body.events[0].data.id).toEqual('feature');
|
|
59
|
+
});
|
|
60
|
+
});
|
|
33
61
|
//# sourceMappingURL=event.e2e.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/event.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"event.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/event.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,2DAAmE;AACnE,gFAA8D;AAC9D,4EAAoD;AACpD,yDAA+D;AAG/D,IAAI,GAAiB,CAAC;AACtB,IAAI,EAAW,CAAC;AAChB,IAAI,UAAuB,CAAC;AAE5B,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,IAAA,uBAAM,EAAC,kBAAkB,EAAE,mBAAS,CAAC,CAAC;IACjD,GAAG,GAAG,MAAM,IAAA,sBAAQ,EAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IAChC,UAAU,GAAG,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC;AACtC,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,KAAK,IAAI,EAAE;IAChB,MAAM,GAAG,CAAC,OAAO,EAAE,CAAC;IACpB,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;AACvB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE;IAC9B,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,OAAO,GAAG,CAAC,OAAO;SACb,GAAG,CAAC,mBAAmB,CAAC;SACxB,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC;SAC9B,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;IAC3C,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,OAAO,GAAG,CAAC,OAAO;SACb,GAAG,CAAC,0BAA0B,CAAC;SAC/B,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC;SAC9B,MAAM,CAAC,GAAG,CAAC,CAAC;AACrB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;IACrC,MAAM,UAAU,CAAC,KAAK,CAAC;QACnB,IAAI,EAAE,wBAAe;QACrB,OAAO,EAAE,gBAAgB;QACzB,IAAI,EAAE,EAAE,EAAE,EAAE,oBAAoB,EAAE;QAClC,IAAI,EAAE,EAAE;QACR,SAAS,EAAE,WAAW;QACtB,WAAW,EAAE,MAAM;KACtB,CAAC,CAAC;IACH,MAAM,UAAU,CAAC,KAAK,CAAC;QACnB,IAAI,EAAE,wBAAe;QACrB,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE;QACvB,IAAI,EAAE,EAAE;QACR,SAAS,EAAE,WAAW;QACtB,WAAW,EAAE,MAAM;KACtB,CAAC,CAAC;IACH,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,mCAAmC,CAAC;SACxC,MAAM,CAAC,GAAG,CAAC;SACX,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACZ,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;AACX,CAAC,CAAC,CAAC"}
|
|
@@ -9,8 +9,8 @@ const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
|
|
|
9
9
|
let app;
|
|
10
10
|
let db;
|
|
11
11
|
beforeAll(async () => {
|
|
12
|
-
db = await database_init_1.default('archive_serial', no_logger_1.default);
|
|
13
|
-
app = await test_helper_1.setupApp(db.stores);
|
|
12
|
+
db = await (0, database_init_1.default)('archive_serial', no_logger_1.default);
|
|
13
|
+
app = await (0, test_helper_1.setupApp)(db.stores);
|
|
14
14
|
await app.services.featureToggleServiceV2.createFeatureToggle('default', {
|
|
15
15
|
name: 'featureX',
|
|
16
16
|
description: 'the #1 feature',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feature-archive.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature-archive.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,2DAAqD;AACrD,gFAAiD;AACjD,4EAAoD;AAEpD,IAAI,GAAG,CAAC;AACR,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,uBAAM,
|
|
1
|
+
{"version":3,"file":"feature-archive.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature-archive.e2e.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,8 +9,8 @@ const test_helper_1 = require("../../helpers/test-helper");
|
|
|
9
9
|
let app;
|
|
10
10
|
let db;
|
|
11
11
|
beforeAll(async () => {
|
|
12
|
-
db = await database_init_1.default('feature_type_api_serial', no_logger_1.default);
|
|
13
|
-
app = await test_helper_1.setupApp(db.stores);
|
|
12
|
+
db = await (0, database_init_1.default)('feature_type_api_serial', no_logger_1.default);
|
|
13
|
+
app = await (0, test_helper_1.setupApp)(db.stores);
|
|
14
14
|
});
|
|
15
15
|
afterAll(async () => {
|
|
16
16
|
await app.destroy();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feature-type.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature-type.test.ts"],"names":[],"mappings":";;;;;AAAA,gFAAiD;AACjD,4EAAoD;AACpD,2DAAqD;AAErD,IAAI,GAAG,CAAC;AACR,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,uBAAM,
|
|
1
|
+
{"version":3,"file":"feature-type.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature-type.test.ts"],"names":[],"mappings":";;;;;AAAA,gFAAiD;AACjD,4EAAoD;AACpD,2DAAqD;AAErD,IAAI,GAAG,CAAC;AACR,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,IAAA,uBAAM,EAAC,yBAAyB,EAAE,mBAAS,CAAC,CAAC;IACxD,GAAG,GAAG,MAAM,IAAA,sBAAQ,EAAC,EAAE,CAAC,MAAM,CAAC,CAAC;AACpC,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,KAAK,IAAI,EAAE;IAChB,MAAM,GAAG,CAAC,OAAO,EAAE,CAAC;IACpB,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;AACvB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;IACpD,MAAM,GAAG,CAAC,OAAO;SACZ,GAAG,CAAC,0BAA0B,CAAC;SAC/B,MAAM,CAAC,GAAG,CAAC;SACX,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC;SAC9B,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACZ,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,GAAG,CAAC,IAAI,CAAC;QAEpC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACX,CAAC,CAAC,CAAC"}
|
|
@@ -8,14 +8,14 @@ const database_init_1 = __importDefault(require("../../helpers/database-init"));
|
|
|
8
8
|
const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
|
|
9
9
|
let db;
|
|
10
10
|
beforeAll(async () => {
|
|
11
|
-
db = await database_init_1.default('feature_api_auth', no_logger_1.default);
|
|
11
|
+
db = await (0, database_init_1.default)('feature_api_auth', no_logger_1.default);
|
|
12
12
|
});
|
|
13
13
|
afterAll(async () => {
|
|
14
14
|
await db.destroy();
|
|
15
15
|
});
|
|
16
16
|
test('creates new feature toggle with createdBy', async () => {
|
|
17
17
|
expect.assertions(1);
|
|
18
|
-
const { request, destroy } = await test_helper_1.setupAppWithAuth(db.stores);
|
|
18
|
+
const { request, destroy } = await (0, test_helper_1.setupAppWithAuth)(db.stores);
|
|
19
19
|
// Login
|
|
20
20
|
await request.post('/api/admin/login').send({
|
|
21
21
|
email: 'user@mail.com',
|
|
@@ -36,7 +36,7 @@ test('creates new feature toggle with createdBy', async () => {
|
|
|
36
36
|
});
|
|
37
37
|
test('should require authenticated user', async () => {
|
|
38
38
|
expect.assertions(0);
|
|
39
|
-
const { request, destroy } = await test_helper_1.setupAppWithAuth(db.stores);
|
|
39
|
+
const { request, destroy } = await (0, test_helper_1.setupAppWithAuth)(db.stores);
|
|
40
40
|
await request.get('/api/admin/features').expect(401);
|
|
41
41
|
await destroy();
|
|
42
42
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feature.auth.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature.auth.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,2DAA6D;AAC7D,gFAAiD;AACjD,4EAAoD;AAEpD,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,uBAAM,
|
|
1
|
+
{"version":3,"file":"feature.auth.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature.auth.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,2DAA6D;AAC7D,gFAAiD;AACjD,4EAAoD;AAEpD,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,IAAA,uBAAM,EAAC,kBAAkB,EAAE,mBAAS,CAAC,CAAC;AACrD,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,KAAK,IAAI,EAAE;IAChB,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;AACvB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;IACzD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAErB,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,8BAAgB,EAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IAE/D,QAAQ;IACR,MAAM,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC;QACxC,KAAK,EAAE,eAAe;KACzB,CAAC,CAAC;IAEH,gBAAgB;IAChB,MAAM,OAAO;SACR,IAAI,CAAC,qBAAqB,CAAC;SAC3B,IAAI,CAAC;QACF,IAAI,EAAE,mBAAmB;QACzB,OAAO,EAAE,KAAK;QACd,UAAU,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;KACpC,CAAC;SACD,MAAM,CAAC,GAAG,CAAC,CAAC;IAEjB,MAAM,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACpE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,MAAM,OAAO,EAAE,CAAC;AACpB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;IACjD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,8BAAgB,EAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IAC/D,MAAM,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACrD,MAAM,OAAO,EAAE,CAAC;AACpB,CAAC,CAAC,CAAC"}
|
|
@@ -10,7 +10,7 @@ const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
|
|
|
10
10
|
let stores;
|
|
11
11
|
let db;
|
|
12
12
|
beforeAll(async () => {
|
|
13
|
-
db = await database_init_1.default('feature_api_custom_auth', no_logger_1.default);
|
|
13
|
+
db = await (0, database_init_1.default)('feature_api_custom_auth', no_logger_1.default);
|
|
14
14
|
stores = db.stores;
|
|
15
15
|
});
|
|
16
16
|
afterAll(async () => {
|
|
@@ -30,7 +30,7 @@ test('should require authenticated user', async () => {
|
|
|
30
30
|
}))
|
|
31
31
|
.end());
|
|
32
32
|
};
|
|
33
|
-
const { request, destroy } = await test_helper_1.setupAppWithCustomAuth(stores, preHook);
|
|
33
|
+
const { request, destroy } = await (0, test_helper_1.setupAppWithCustomAuth)(stores, preHook);
|
|
34
34
|
await request.get('/api/admin/features').expect(401);
|
|
35
35
|
await destroy();
|
|
36
36
|
});
|
|
@@ -43,7 +43,7 @@ test('creates new feature toggle with createdBy', async () => {
|
|
|
43
43
|
next();
|
|
44
44
|
});
|
|
45
45
|
};
|
|
46
|
-
const { request, destroy } = await test_helper_1.setupAppWithCustomAuth(stores, preHook);
|
|
46
|
+
const { request, destroy } = await (0, test_helper_1.setupAppWithCustomAuth)(stores, preHook);
|
|
47
47
|
// create toggle
|
|
48
48
|
await request
|
|
49
49
|
.post('/api/admin/features')
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feature.custom-auth.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature.custom-auth.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,2DAAmE;AACnE,4GAAmF;AAEnF,gFAAiD;AACjD,4EAAoD;AAEpD,IAAI,MAAM,CAAC;AACX,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,uBAAM,
|
|
1
|
+
{"version":3,"file":"feature.custom-auth.e2e.test.js","sourceRoot":"","sources":["../../../../../src/test/e2e/api/admin/feature.custom-auth.e2e.test.ts"],"names":[],"mappings":";;;;;AAAA,2DAAmE;AACnE,4GAAmF;AAEnF,gFAAiD;AACjD,4EAAoD;AAEpD,IAAI,MAAM,CAAC;AACX,IAAI,EAAE,CAAC;AAEP,SAAS,CAAC,KAAK,IAAI,EAAE;IACjB,EAAE,GAAG,MAAM,IAAA,uBAAM,EAAC,yBAAyB,EAAE,mBAAS,CAAC,CAAC;IACxD,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;AACvB,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,KAAK,IAAI,EAAE;IAChB,IAAI,EAAE,EAAE;QACJ,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;KACtB;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;IACjD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,MAAM,OAAO,GAAG,CAAC,GAAG,EAAE,EAAE;QACpB,GAAG,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAChC,GAAG;aACE,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CACD,IAAI,iCAAsB,CAAC;YACvB,IAAI,EAAE,kBAAkB;YACxB,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,gCAAgC;SAC5C,CAAC,CACL;aACA,GAAG,EAAE,CACb,CAAC;IACN,CAAC,CAAC;IACF,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,oCAAsB,EAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3E,MAAM,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACrD,MAAM,OAAO,EAAE,CAAC;AACpB,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;IACzD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACrB,MAAM,KAAK,GAAG,sBAAsB,CAAC;IAErC,MAAM,OAAO,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE;QAC7C,GAAG,CAAC,GAAG,CAAC,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YAC5C,GAAG,CAAC,IAAI,GAAG,MAAM,WAAW,CAAC,wBAAwB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YACnE,IAAI,EAAE,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC,CAAC;IACF,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,oCAAsB,EAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAE3E,gBAAgB;IAChB,MAAM,OAAO;SACR,IAAI,CAAC,qBAAqB,CAAC;SAC3B,IAAI,CAAC;QACF,IAAI,EAAE,mBAAmB;QACzB,OAAO,EAAE,KAAK;QACd,UAAU,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;KACpC,CAAC;SACD,MAAM,CAAC,GAAG,CAAC,CAAC;IAEjB,MAAM,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;QACpE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,MAAM,OAAO,EAAE,CAAC;AACpB,CAAC,CAAC,CAAC"}
|
|
@@ -9,90 +9,93 @@ const test_helper_1 = require("../../helpers/test-helper");
|
|
|
9
9
|
const no_logger_1 = __importDefault(require("../../../fixtures/no-logger"));
|
|
10
10
|
let app;
|
|
11
11
|
let db;
|
|
12
|
+
const defaultStrategy = {
|
|
13
|
+
name: 'default',
|
|
14
|
+
parameters: {},
|
|
15
|
+
constraints: [],
|
|
16
|
+
};
|
|
12
17
|
beforeAll(async () => {
|
|
13
|
-
db = await database_init_1.default('feature_api_serial', no_logger_1.default);
|
|
14
|
-
app = await test_helper_1.setupApp(db.stores);
|
|
15
|
-
|
|
18
|
+
db = await (0, database_init_1.default)('feature_api_serial', no_logger_1.default);
|
|
19
|
+
app = await (0, test_helper_1.setupApp)(db.stores);
|
|
20
|
+
const createToggle = async (toggle, strategy = defaultStrategy, projectId = 'default', username = 'test') => {
|
|
21
|
+
await app.services.featureToggleServiceV2.createFeatureToggle(projectId, toggle, username);
|
|
22
|
+
await app.services.featureToggleServiceV2.createStrategy(strategy, projectId, toggle.name, username);
|
|
23
|
+
};
|
|
24
|
+
await createToggle({
|
|
16
25
|
name: 'featureX',
|
|
17
26
|
description: 'the #1 feature',
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
name: 'default',
|
|
21
|
-
parameters: {},
|
|
22
|
-
},
|
|
23
|
-
],
|
|
24
|
-
}, 'test');
|
|
25
|
-
await app.services.featureToggleServiceV2.createFeatureToggle('default', {
|
|
27
|
+
});
|
|
28
|
+
await createToggle({
|
|
26
29
|
name: 'featureY',
|
|
27
30
|
description: 'soon to be the #1 feature',
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
}, 'userName');
|
|
37
|
-
await app.services.featureToggleServiceV2.createFeatureToggle('default', {
|
|
31
|
+
}, {
|
|
32
|
+
name: 'baz',
|
|
33
|
+
constraints: [],
|
|
34
|
+
parameters: {
|
|
35
|
+
foo: 'bar',
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
await createToggle({
|
|
38
39
|
name: 'featureZ',
|
|
39
40
|
description: 'terrible feature',
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
}, 'test');
|
|
49
|
-
await app.services.featureToggleServiceV2.createFeatureToggle('default', {
|
|
41
|
+
}, {
|
|
42
|
+
name: 'baz',
|
|
43
|
+
constraints: [],
|
|
44
|
+
parameters: {
|
|
45
|
+
foo: 'rab',
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
await createToggle({
|
|
50
49
|
name: 'featureArchivedX',
|
|
51
50
|
description: 'the #1 feature',
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
],
|
|
58
|
-
}, 'test');
|
|
51
|
+
}, {
|
|
52
|
+
name: 'default',
|
|
53
|
+
constraints: [],
|
|
54
|
+
parameters: {},
|
|
55
|
+
});
|
|
59
56
|
await app.services.featureToggleServiceV2.archiveToggle('featureArchivedX', 'test');
|
|
60
|
-
await
|
|
57
|
+
await createToggle({
|
|
61
58
|
name: 'featureArchivedY',
|
|
62
59
|
description: 'soon to be the #1 feature',
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
],
|
|
71
|
-
}, 'test');
|
|
60
|
+
}, {
|
|
61
|
+
name: 'baz',
|
|
62
|
+
constraints: [],
|
|
63
|
+
parameters: {
|
|
64
|
+
foo: 'bar',
|
|
65
|
+
},
|
|
66
|
+
});
|
|
72
67
|
await app.services.featureToggleServiceV2.archiveToggle('featureArchivedY', 'test');
|
|
73
|
-
await
|
|
68
|
+
await createToggle({
|
|
74
69
|
name: 'featureArchivedZ',
|
|
75
70
|
description: 'terrible feature',
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
],
|
|
84
|
-
}, 'test');
|
|
71
|
+
}, {
|
|
72
|
+
name: 'baz',
|
|
73
|
+
constraints: [],
|
|
74
|
+
parameters: {
|
|
75
|
+
foo: 'rab',
|
|
76
|
+
},
|
|
77
|
+
});
|
|
85
78
|
await app.services.featureToggleServiceV2.archiveToggle('featureArchivedZ', 'test');
|
|
86
|
-
await
|
|
79
|
+
await createToggle({
|
|
87
80
|
name: 'feature.with.variants',
|
|
88
81
|
description: 'A feature toggle with variants',
|
|
89
|
-
enabled: true,
|
|
90
|
-
strategies: [{ name: 'default' }],
|
|
91
82
|
variants: [
|
|
92
|
-
{
|
|
93
|
-
|
|
83
|
+
{
|
|
84
|
+
name: 'control',
|
|
85
|
+
weight: 50,
|
|
86
|
+
weightType: 'variable',
|
|
87
|
+
overrides: [],
|
|
88
|
+
stickiness: 'default',
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
name: 'new',
|
|
92
|
+
weight: 50,
|
|
93
|
+
weightType: 'variable',
|
|
94
|
+
overrides: [],
|
|
95
|
+
stickiness: 'default',
|
|
96
|
+
},
|
|
94
97
|
],
|
|
95
|
-
}
|
|
98
|
+
});
|
|
96
99
|
});
|
|
97
100
|
afterAll(async () => {
|
|
98
101
|
await app.destroy();
|
|
@@ -208,9 +211,12 @@ test('can not toggle of feature that does not exist', async () => {
|
|
|
208
211
|
});
|
|
209
212
|
test('can toggle a feature that does exist', async () => {
|
|
210
213
|
expect.assertions(0);
|
|
214
|
+
const featureName = 'existing.feature';
|
|
215
|
+
const username = 'toggle-feature';
|
|
211
216
|
const feature = await app.services.featureToggleServiceV2.createFeatureToggle('default', {
|
|
212
|
-
name:
|
|
217
|
+
name: featureName,
|
|
213
218
|
}, 'test');
|
|
219
|
+
await app.services.featureToggleServiceV2.createStrategy(defaultStrategy, 'default', featureName, username);
|
|
214
220
|
return app.request
|
|
215
221
|
.post(`/api/admin/features/${feature.name}/toggle`)
|
|
216
222
|
.set('Content-Type', 'application/json')
|