chore: Migrate modules to use the Module util (#7964)

**What**
Apply the `Module` util to each module to handle the export and provide the linkable configuration object.

- Most joiner config that does not have any special config are removed/cleaned up in favor of the autogenerated one or simpler one
- linkable are now available in all modules
- cleaned up the dependencies of the modules

FIXES CORE-2410
This commit is contained in:
Adrien de Peretti
2024-07-05 15:00:40 +02:00
committed by GitHub
parent eafa3560ae
commit b368251ca3
99 changed files with 1267 additions and 488 deletions

View File

@@ -1,11 +1,12 @@
import { IPaymentModuleService } from "@medusajs/types"
import { Modules, promiseAll } from "@medusajs/utils"
import { Module, Modules, promiseAll } from "@medusajs/utils"
import { moduleIntegrationTestRunner } from "medusa-test-utils"
import {
createPaymentCollections,
createPaymentSessions,
createPayments,
createPaymentSessions,
} from "../../../__fixtures__"
import { PaymentModuleService } from "@services"
jest.setTimeout(30000)
@@ -13,6 +14,49 @@ moduleIntegrationTestRunner<IPaymentModuleService>({
moduleName: Modules.PAYMENT,
testSuite: ({ MikroOrmWrapper, service }) => {
describe("Payment Module Service", () => {
it(`should export the appropriate linkable configuration`, () => {
const linkable = Module(Modules.PAYMENT, {
service: PaymentModuleService,
}).linkable
expect(Object.keys(linkable)).toEqual([
"payment",
"paymentCollection",
"paymentProvider",
])
Object.keys(linkable).forEach((key) => {
delete linkable[key].toJSON
})
expect(linkable).toEqual({
payment: {
id: {
linkable: "payment_id",
primaryKey: "id",
serviceName: "payment",
field: "payment",
},
},
paymentCollection: {
id: {
linkable: "payment_collection_id",
primaryKey: "id",
serviceName: "payment",
field: "paymentCollection",
},
},
paymentProvider: {
id: {
linkable: "payment_provider_id",
primaryKey: "id",
serviceName: "payment",
field: "paymentProvider",
},
},
})
})
describe("Payment Flow", () => {
it("complete payment flow successfully", async () => {
let paymentCollection = await service.createPaymentCollections({

View File

@@ -52,8 +52,6 @@
"@mikro-orm/migrations": "5.9.7",
"@mikro-orm/postgresql": "5.9.7",
"awilix": "^8.0.0",
"bignumber.js": "^9.1.2",
"dotenv": "^16.4.5",
"knex": "2.4.2"
"bignumber.js": "^9.1.2"
}
}

View File

@@ -1,13 +1,10 @@
import { ModuleExports } from "@medusajs/types"
import { PaymentModuleService } from "@services"
import loadProviders from "./loaders/providers"
import { Module, Modules } from "@medusajs/utils"
const moduleDefinition: ModuleExports = {
export default Module(Modules.PAYMENT, {
service: PaymentModuleService,
loaders: [loadProviders],
}
export default moduleDefinition
})
export { PaymentModuleOptions } from "./types"