feat(utils): define file config (#13283)

** What
 - Allow auto-loaded Medusa files to export a config object.
 - Currently supports isDisabled to control loading.
 - new instance `FeatureFlag` exported by `@medusajs/framework/utils`
 - `feature-flags` is now a supported folder for medusa projects, modules, providers and plugins. They will be loaded and added to `FeatureFlag`

** Why
 - Enables conditional loading of routes, migrations, jobs, subscribers, workflows, and other files based on feature flags.

```ts
// /src/feature-flags

import { FlagSettings } from "@medusajs/framework/feature-flags"

const CustomFeatureFlag: FlagSettings = {
  key: "custom_feature",
  default_val: false,
  env_key: "FF_MY_CUSTOM_FEATURE",
  description: "Enable xyz",
}

export default CustomFeatureFlag
```

```ts
// /src/modules/my-custom-module/migration/Migration20250822135845.ts

import { FeatureFlag } from "@medusajs/framework/utils"

export class Migration20250822135845 extends Migration {
  override async up(){ }
  override async down(){ }
}

defineFileConfig({
  isDisabled: () => !FeatureFlag.isFeatureEnabled("custom_feature")
})
```
This commit is contained in:
Carlos R. L. Rodrigues
2025-08-26 09:22:30 -03:00
committed by GitHub
parent 4cda412243
commit e413cfefc2
183 changed files with 1089 additions and 605 deletions
@@ -0,0 +1,26 @@
const { defineConfig } = require("@medusajs/framework/utils")
const DB_HOST = process.env.DB_HOST
const DB_USERNAME = process.env.DB_USERNAME
const DB_PASSWORD = process.env.DB_PASSWORD
const DB_NAME = process.env.DB_TEMP_NAME
const DB_URL = `postgres://${DB_USERNAME}:${DB_PASSWORD}@${DB_HOST}/${DB_NAME}`
process.env.DATABASE_URL = DB_URL
module.exports = defineConfig({
admin: {
disable: true,
},
projectConfig: {
http: {
jwtSecret: "secret",
},
},
modules: [
{
key: "custom",
resolve: "src/modules/custom",
},
],
})
@@ -0,0 +1,10 @@
import { MedusaRequest, MedusaResponse } from "@medusajs/framework/http"
import { defineFileConfig, FeatureFlag } from "@medusajs/utils"
defineFileConfig({
isDisabled: () => !FeatureFlag.isFeatureEnabled("custom_ff"),
})
export const GET = async (req: MedusaRequest, res: MedusaResponse) => {
res.json({ message: "Custom GET" })
}
@@ -0,0 +1,8 @@
import { FlagSettings } from "@medusajs/framework/feature-flags"
export const CustomFeatureFlag: FlagSettings = {
key: "custom_ff",
default_val: false,
env_key: "CUSTOM_FF",
description: "Custom feature flag",
}
@@ -0,0 +1,18 @@
import { MedusaContainer } from "@medusajs/framework/types"
import { defineFileConfig, FeatureFlag } from "@medusajs/framework/utils"
export const testJobHandler = jest.fn()
export default async function greetingJob(container: MedusaContainer) {
testJobHandler()
}
export const config = {
name: "greeting-every-second",
numberOfExecutions: 1,
schedule: "* * * * * *",
}
defineFileConfig({
isDisabled: () => !FeatureFlag.isFeatureEnabled("custom_ff"),
})
@@ -0,0 +1,8 @@
import { ModuleExports } from "@medusajs/types"
import { ModuleService } from "./services/module-service"
const moduleExports: ModuleExports = {
service: ModuleService,
}
export default moduleExports
@@ -0,0 +1,12 @@
import { FeatureFlag, defineFileConfig } from "@medusajs/framework/utils"
import { Migration } from "@mikro-orm/migrations"
defineFileConfig({
isDisabled: () => !FeatureFlag.isFeatureEnabled("custom_ff"),
})
export class MigrationTest extends Migration {
override async up(): Promise<void> {}
override async down(): Promise<void> {}
}
@@ -0,0 +1,12 @@
import { IModuleService } from "@medusajs/types"
import { MedusaContext } from "@medusajs/utils"
// @ts-expect-error
export class ModuleService implements IModuleService {
public property = "value"
constructor() {}
async methodName(input, @MedusaContext() context) {
return input + " called"
}
}
@@ -0,0 +1,13 @@
import { defineFileConfig, FeatureFlag } from "@medusajs/framework/utils"
const testProductCreatedHandlerMock = jest.fn()
export default testProductCreatedHandlerMock
export const config = {
event: "event.test",
}
defineFileConfig({
isDisabled: () => !FeatureFlag.isFeatureEnabled("custom_ff"),
})
@@ -0,0 +1,14 @@
import { defineFileConfig, FeatureFlag } from "@medusajs/framework/utils"
import { createStep, createWorkflow } from "@medusajs/framework/workflows-sdk"
const testWorkflowHandler = jest.fn()
const step1 = createStep("step1", () => testWorkflowHandler())
export const testWorkflow = createWorkflow("test-workflow", () => {
step1()
})
defineFileConfig({
isDisabled: () => !FeatureFlag.isFeatureEnabled("custom_ff"),
})
@@ -1,12 +1,12 @@
import { generateResetPasswordTokenWorkflow } from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ContainerRegistrationKeys } from "@medusajs/utils"
import jwt from "jsonwebtoken"
import path from "path"
import {
adminHeaders,
createAdminUser,
} from "../../../../helpers/create-admin-user"
import path from "path"
import { ContainerRegistrationKeys } from "@medusajs/utils"
jest.setTimeout(100000)
@@ -76,7 +76,7 @@ const promotionData = {
],
}
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -20,7 +20,7 @@ import { medusaTshirtProduct } from "../../../__fixtures__/product"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = { headers: { "x-medusa-access-token": "test_token" } }
const shippingAddressData = {
@@ -0,0 +1,49 @@
import { MedusaWorkflow } from "@medusajs/framework/workflows-sdk"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import path from "path"
import { setTimeout as setTimeoutPromise } from "timers/promises"
import { testJobHandler } from "../../__fixtures__/feature-flag/src/jobs/test-job"
jest.setTimeout(100000)
medusaIntegrationTestRunner({
cwd: path.join(__dirname, "../../__fixtures__/feature-flag"),
env: {
CUSTOM_FF: true,
},
testSuite: ({ api, dbConnection }) => {
describe("Resources loaded with feature flags", () => {
it("should load migration when feature flag is enabled and run job", async () => {
const migrationNotExecuted = await dbConnection.raw(
`SELECT name FROM "mikro_orm_migrations" WHERE name = 'Noop'`
)
expect(migrationNotExecuted.rows).toHaveLength(0)
const migrationExecuted = await dbConnection.raw(
`SELECT name FROM "mikro_orm_migrations" WHERE name = 'MigrationTest'`
)
expect(migrationExecuted.rows).toHaveLength(1)
expect(migrationExecuted.rows[0].name).toBe("MigrationTest")
await setTimeoutPromise(1000)
expect(testJobHandler).toHaveBeenCalledTimes(1)
})
it("should load workflow when feature flag is enabled", async () => {
expect(MedusaWorkflow.getWorkflow("test-workflow")).toBeDefined()
})
it("should load scheduled job when feature flag is enabled", async () => {
expect(
MedusaWorkflow.getWorkflow("job-greeting-every-second")
).toBeDefined()
})
it("should load endpoint when feature flag is enabled", async () => {
expect((await api.get("/custom")).status).toBe(200)
})
})
},
})
@@ -0,0 +1,46 @@
import { MedusaWorkflow } from "@medusajs/framework/workflows-sdk"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import path from "path"
import { setTimeout as setTimeoutPromise } from "timers/promises"
import { testJobHandler } from "../../__fixtures__/feature-flag/src/jobs/test-job"
jest.setTimeout(100000)
medusaIntegrationTestRunner({
cwd: path.join(__dirname, "../../__fixtures__/feature-flag"),
testSuite: ({ api, dbConnection }) => {
describe("Resources loaded without feature flags", () => {
it("should not load migration when feature flag is disabled and not run job", async () => {
const migrationNotExecuted = await dbConnection.raw(
`SELECT name FROM "mikro_orm_migrations" WHERE name = 'MigrationTest'`
)
expect(migrationNotExecuted.rows).toHaveLength(0)
const migrationExecuted = await dbConnection.raw(
`SELECT name FROM "mikro_orm_migrations" WHERE name = 'Noop'`
)
expect(migrationExecuted.rows).toHaveLength(1)
expect(migrationExecuted.rows[0].name).toBe("Noop")
await setTimeoutPromise(1000)
expect(testJobHandler).toHaveBeenCalledTimes(0)
})
it("should not load workflow when feature flag is disabled", async () => {
expect(MedusaWorkflow.getWorkflow("test-workflow")).toBeUndefined()
})
it("should not load scheduled job when feature flag is disabled", async () => {
expect(
MedusaWorkflow.getWorkflow("job-greeting-every-second")
).toBeUndefined()
})
it("should not load endpoint when feature flag is disabled", async () => {
expect(api.get("/custom")).rejects.toThrow()
})
})
},
})
@@ -7,7 +7,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = { headers: { "x-medusa-access-token": "test_token" } }
medusaIntegrationTestRunner({
@@ -7,7 +7,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = { headers: { "x-medusa-access-token": "test_token" } }
medusaIntegrationTestRunner({
@@ -3,7 +3,7 @@ import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,10 +1,9 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { adminHeaders, createAdminUser } from "../../helpers/create-admin-user"
import { Modules, ContainerRegistrationKeys } from "@medusajs/framework/utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true, MEDUSA_FF_VIEW_CONFIGURATIONS: true }
const env = { MEDUSA_FF_VIEW_CONFIGURATIONS: true }
medusaIntegrationTestRunner({
env,
@@ -1,6 +1,6 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IAuthModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import Scrypt from "scrypt-kdf"
import {
adminHeaders,
@@ -9,7 +9,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -16,7 +16,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -39,7 +39,7 @@ import { createAuthenticatedCustomer } from "../../../helpers/create-authenticat
jest.setTimeout(200000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -49,7 +49,7 @@ import { createAuthenticatedCustomer } from "../../../helpers/create-authenticat
jest.setTimeout(200000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -33,7 +33,7 @@ import { setupTaxStructure } from "../../fixtures"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = { headers: { "x-medusa-access-token": "test_token" } }
medusaIntegrationTestRunner({
@@ -16,7 +16,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -3,7 +3,7 @@ import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -6,7 +6,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,9 +1,9 @@
import { createAdminUser } from "../../../../helpers/create-admin-user"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,9 +1,9 @@
import { createAdminUser } from "../../../../helpers/create-admin-user"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -11,9 +11,7 @@ const { medusaIntegrationTestRunner } = require("@medusajs/test-utils")
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: {
MEDUSA_FF_MEDUSA_V2: true,
},
env: {},
testSuite: ({ dbConnection, getContainer, api }) => {
describe("GET /admin/customers", () => {
let appContainer
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICustomerModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -9,7 +9,7 @@ import { createAuthenticatedCustomer } from "../../../helpers/create-authenticat
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,8 +1,8 @@
import { IAuthModuleService } from "@medusajs/types"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ContainerRegistrationKeys, Modules } from "@medusajs/utils"
import jwt from "jsonwebtoken"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
adminHeaders,
createAdminUser,
@@ -12,7 +12,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -7,7 +7,7 @@ import {
} from "../../../../helpers/create-admin-user"
import { createAuthenticatedCustomer } from "../../../helpers/create-authenticated-customer"
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
jest.setTimeout(50000)
@@ -7,7 +7,7 @@ import { createAuthenticatedCustomer } from "../../../helpers/create-authenticat
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -7,7 +7,7 @@ import {
} from "../../../../helpers/create-admin-user"
import { createAuthenticatedCustomer } from "../../../helpers/create-authenticated-customer"
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
jest.setTimeout(100000)
@@ -9,7 +9,7 @@ import { createAuthenticatedCustomer } from "../../../helpers/create-authenticat
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IFulfillmentModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -6,13 +6,13 @@ import {
updateFulfillmentWorkflow,
updateFulfillmentWorkflowId,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
IFulfillmentModuleService,
MedusaContainer,
StockLocationDTO,
} from "@medusajs/types"
import { ContainerRegistrationKeys, Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
generateCreateFulfillmentData,
generateCreateShippingOptionsData,
@@ -23,7 +23,7 @@ jest.setTimeout(50000)
const providerId = "manual_test-provider"
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
describe("Workflows: Fulfillment", () => {
let location: StockLocationDTO
@@ -1,6 +1,6 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IFulfillmentModuleService, StockLocationDTO } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
import {
generateCreateFulfillmentData,
@@ -10,7 +10,7 @@ import {
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IUserModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,9 +1,9 @@
import { createAdminUser } from "../../../helpers/create-admin-user"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IUserModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IUserModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IUserModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IUserModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,3 +1,4 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
ICartModuleService,
ICustomerModuleService,
@@ -6,11 +7,10 @@ import {
ISalesChannelModuleService,
} from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,10 +1,10 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICartModuleService, IRegionModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,3 +1,4 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
IFulfillmentModuleService,
IStockLocationService,
@@ -7,11 +8,10 @@ import {
Modules,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -8,7 +8,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,13 +1,13 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
IApiKeyModuleService,
ISalesChannelModuleService,
} from "@medusajs/types"
import { Modules, remoteQueryObjectFromString } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,10 +1,10 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IRegionModuleService } from "@medusajs/types"
import { ContainerRegistrationKeys, Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,13 +1,13 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
ISalesChannelModuleService,
IStockLocationService,
} from "@medusajs/types"
import { Modules, remoteQueryObjectFromString } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,9 +1,9 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
IFulfillmentModuleService,
IPricingModuleService,
} from "@medusajs/types"
import { ContainerRegistrationKeys, Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
adminHeaders,
createAdminUser,
@@ -11,7 +11,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,10 +1,10 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { ICurrencyModuleService, IStoreModuleService } from "@medusajs/types"
import { Modules, remoteQueryObjectFromString } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,5 +1,5 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { MedusaApp } from "@medusajs/modules-sdk"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IProductModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
@@ -14,7 +14,7 @@ import { adminHeaders } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,7 +1,5 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
ICartModuleService,
IFulfillmentModuleService,
IInventoryServiceNext,
IPricingModuleService,
IProductModuleService,
@@ -24,7 +22,7 @@ import { setupTaxStructure } from "../fixtures"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -16,7 +16,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -23,7 +23,7 @@ import {
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const providerId = "manual_test-provider"
async function prepareDataFixtures({ container }) {
@@ -25,7 +25,7 @@ import {
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const providerId = "manual_test-provider"
async function prepareDataFixtures({ container }) {
@@ -21,7 +21,7 @@ import {
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const providerId = "manual_test-provider"
async function prepareDataFixtures({ container }) {
@@ -3,6 +3,7 @@ import {
cancelOrderWorkflow,
createOrderFulfillmentWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
IOrderModuleService,
InventoryItemDTO,
@@ -17,12 +18,11 @@ import {
Modules,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "./__fixtures__"
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -6,18 +6,18 @@ import {
orderClaimRequestItemReturnWorkflow,
updateClaimAddItemWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IFulfillmentModuleService, OrderDTO } from "@medusajs/types"
import {
ContainerRegistrationKeys,
Modules,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "../__fixtures__"
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
let container
@@ -25,7 +25,7 @@ import {
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const providerId = "manual_test-provider"
async function prepareDataFixtures({ container }) {
@@ -24,7 +24,7 @@ import {
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const providerId = "manual_test-provider"
const variantSkuWithInventory = "test-variant"
let inventoryItem
@@ -24,7 +24,7 @@ import {
jest.setTimeout(500000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const providerId = "manual_test-provider"
let inventoryItem
@@ -6,18 +6,18 @@ import {
orderExchangeRequestItemReturnWorkflow,
updateExchangeAddItemWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IFulfillmentModuleService, OrderDTO } from "@medusajs/types"
import {
ContainerRegistrationKeys,
Modules,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "../__fixtures__"
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
let container
@@ -7,6 +7,7 @@ import {
updateOrderChangeActionsWorkflow,
updateOrderChangeActionsWorkflowId,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
IOrderModuleService,
OrderChangeActionDTO,
@@ -14,13 +15,12 @@ import {
OrderDTO,
} from "@medusajs/types"
import { ChangeActionType, Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "./__fixtures__"
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
let container
@@ -7,15 +7,15 @@ import {
deleteOrderChangeWorkflow,
deleteOrderChangeWorkflowId,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IOrderModuleService, OrderChangeDTO, OrderDTO } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "./__fixtures__"
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
let container
@@ -5,18 +5,18 @@ import {
requestItemReturnWorkflow,
updateRequestItemReturnWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IFulfillmentModuleService, OrderDTO, ReturnDTO } from "@medusajs/types"
import {
ContainerRegistrationKeys,
Modules,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "../__fixtures__"
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
let container
@@ -3,19 +3,19 @@ import {
createOrderFulfillmentWorkflow,
requestItemReturnWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IOrderModuleService, OrderDTO, ReturnDTO } from "@medusajs/types"
import {
ContainerRegistrationKeys,
Modules,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createOrderFixture, prepareDataFixtures } from "../__fixtures__"
jest.setTimeout(50000)
medusaIntegrationTestRunner({
env: { MEDUSA_FF_MEDUSA_V2: true },
env: {},
testSuite: ({ getContainer }) => {
let container
@@ -6,7 +6,7 @@ import {
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -12,7 +12,7 @@ import { ContainerRegistrationKeys, Modules } from "@medusajs/utils"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
medusaIntegrationTestRunner({
env,
@@ -11,7 +11,7 @@ import { createVariantPriceSet } from "../../../helpers/create-variant-price-set
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,5 +1,5 @@
import { PriceListStatus, PriceListType } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { PriceListStatus, PriceListType } from "@medusajs/utils"
import {
createAdminUser,
generatePublishableKey,
@@ -15,9 +15,7 @@ const adminHeaders = {
},
}
const env = {
MEDUSA_FF_MEDUSA_V2: true,
}
const env = {}
medusaIntegrationTestRunner({
env,
@@ -1,3 +1,4 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
CreateProductDTO,
IPricingModuleService,
@@ -6,13 +7,12 @@ import {
ProductVariantDTO,
} from "@medusajs/types"
import { Modules, PriceListStatus, PriceListType } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
import { createVariantPriceSet } from "../../../helpers/create-variant-price-set"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = { headers: { "x-medusa-access-token": "test_token" } }
async function createProductsWithVariants(
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IRegionModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,15 +1,15 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createRegionsWorkflow } from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { MedusaContainer, RegionDTO } from "@medusajs/types"
import { createAdminUser } from "../../../../helpers/create-admin-user"
import {
ContainerRegistrationKeys,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(200000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { updateRegionsWorkflow } from "@medusajs/core-flows"
import { ContainerLike, MedusaContainer, RegionDTO } from "@medusajs/types"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { MedusaContainer, RegionDTO } from "@medusajs/types"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(200000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -23,7 +23,7 @@ import {
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const provider_id = "manual_test-provider"
async function createShippingOptionFixture({
@@ -1,4 +1,5 @@
import { createShippingOptionsWorkflow } from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
FulfillmentSetDTO,
FulfillmentWorkflow,
@@ -13,11 +14,10 @@ import {
RuleOperator,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const provider_id = "manual_test-provider"
medusaIntegrationTestRunner({
@@ -2,6 +2,7 @@ import {
createShippingOptionsWorkflow,
deleteShippingOptionsWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
FulfillmentSetDTO,
FulfillmentWorkflow,
@@ -16,11 +17,10 @@ import {
RuleOperator,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const provider_id = "manual_test-provider"
medusaIntegrationTestRunner({
@@ -2,6 +2,7 @@ import {
createShippingOptionsWorkflow,
updateShippingOptionsWorkflow,
} from "@medusajs/core-flows"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import {
FulfillmentSetDTO,
FulfillmentWorkflow,
@@ -17,11 +18,10 @@ import {
RuleOperator,
remoteQueryObjectFromString,
} from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
jest.setTimeout(100000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const provider_id = "manual_test-provider"
medusaIntegrationTestRunner({
@@ -1,11 +1,11 @@
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { IStoreModuleService } from "@medusajs/types"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -5,7 +5,7 @@ import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -4,13 +4,13 @@ import {
createTaxRateRulesStepId,
updateTaxRatesWorkflow,
} from "@medusajs/core-flows"
import { Modules } from "@medusajs/utils"
import { medusaIntegrationTestRunner } from "@medusajs/test-utils"
import { Modules } from "@medusajs/utils"
import { createAdminUser } from "../../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}
@@ -3,7 +3,7 @@ import { createAdminUser } from "../../../helpers/create-admin-user"
jest.setTimeout(50000)
const env = { MEDUSA_FF_MEDUSA_V2: true }
const env = {}
const adminHeaders = {
headers: { "x-medusa-access-token": "test_token" },
}

Some files were not shown because too many files have changed in this diff Show More