* add pricing integraiton feature flag * init * first endpoint * cleanup * remove console.logs * refactor to util and implement across endpoints * add changeset * rename variables * remove mistype * feat(medusa): move price module integration to pricing service (#5322) * initial changes * chore: make product service always internal for pricing module * add notes --------- Co-authored-by: Riqwan Thamir <rmthamir@gmail.com> * nit * cleanup * update to object querying * update cart integration test * remove uppercase currency_code * nit * Feat/admin product pricing module reads (#5354) * initial changes to list prices for admin * working price module implementation of list prices * nit * variant pricing * redo integration test changes * cleanup * cleanup * fix unit tests * [wip] Core <> Pricing - price updates (#5364) * chore: update medusa-app * wip * get links and modules working with migration * wip * chore: make test pass * Feat/rule type utils (#5371) * initial rule type utils * update migration script * chore: cleanup * ensure prices are always decorated * chore: use seed instead * chore: fix oas conflict * region id add to admin price read! --------- Co-authored-by: Philip Korsholm <88927411+pKorsholm@users.noreply.github.com> Co-authored-by: Philip Korsholm <philip.korsholm@hotmail.com> * pr feedback * create remoteQueryFunction type * fix merge * fix loaders issue * Feat(medusa, types, pricing): pricing module migration script (#5409) * add migration script for money amounts in pricing module * add changeset * rename file * cleanup imports * update changeset * add check for pricing module and ff * feat(medusa,workflows,types): update prices on product and variant update (#5412) * wip * chore: update product prices through workflow * chore: cleanup * chore: update product handler updates prices for variants * chore: handle reverts * chore: address pr comments * chore: scope workflow handlers to flag handlers * chore: update return * chore: update db url * chore: remove migration * chore: increase jest timeout * Feat(medusa): update migration and initDb to run link-migrations (#5437) * initial * loader update * more progress on loaders * update integration tests and remote-query loader * remove helper * migrate isolated modules * fix test * fix integration test * update with pr feedback * unregister medusa-app * re-register medusaApp * fix featureflag * set timeout * set timeout * conditionally run link-module migrations * pr feedback 1 * add driver options for db * throw if link is not defined in migration script * pass config module directly * include container in migrate command * chore: increase timeout * rm redis from api integration tests to test * chore: temporarily skip tests * chore: undo skips + add timeout for workflow tests * chore: increase timeout for order edits * re-add redis * include final resolution * add sharedcontainer to medusaapp loader * chore: move migration under run command * try removing redis_url from api tests * chore: cleanup server on process exit * chore: clear container on exit * chore: adjustments * chore: remove consoles * chore: close express app on finish * chore: destroy pg connection on shutdown * chore: skip * chore: unskip test * chore: cleanup container pg connection * chore: skip --------- Co-authored-by: Riqwan Thamir <rmthamir@gmail.com>
71 lines
1.8 KiB
JavaScript
71 lines
1.8 KiB
JavaScript
const path = require("path")
|
|
const { spawn } = require("child_process")
|
|
const { setPort, useExpressServer } = require("./use-api")
|
|
const { setContainer } = require("./use-container")
|
|
|
|
module.exports = ({
|
|
cwd,
|
|
redisUrl,
|
|
uploadDir,
|
|
verbose,
|
|
env,
|
|
bootstrapApp = false,
|
|
}) => {
|
|
const serverPath = path.join(__dirname, "test-server.js")
|
|
|
|
if (bootstrapApp) {
|
|
require(serverPath)
|
|
}
|
|
|
|
// in order to prevent conflicts in redis, use a different db for each worker
|
|
// same fix as for databases (works with up to 15)
|
|
// redis dbs are 0-indexed and jest worker ids are indexed from 1
|
|
const workerId = parseInt(process.env.JEST_WORKER_ID || "1")
|
|
const redisUrlWithDatabase = `${redisUrl}/${workerId - 1}`
|
|
|
|
verbose = verbose ?? false
|
|
|
|
return new Promise((resolve, reject) => {
|
|
const medusaProcess = spawn("node", [path.resolve(serverPath)], {
|
|
cwd,
|
|
env: {
|
|
...process.env,
|
|
NODE_ENV: "development",
|
|
JWT_SECRET: "test",
|
|
COOKIE_SECRET: "test",
|
|
REDIS_URL: redisUrl ? redisUrlWithDatabase : undefined, // If provided, will use a real instance, otherwise a fake instance
|
|
UPLOAD_DIR: uploadDir, // If provided, will be used for the fake local file service
|
|
...env,
|
|
},
|
|
stdio: verbose
|
|
? ["inherit", "inherit", "inherit", "ipc"]
|
|
: ["ignore", "ignore", "ignore", "ipc"],
|
|
})
|
|
|
|
medusaProcess.on("error", (err) => {
|
|
console.log(err)
|
|
process.exit()
|
|
})
|
|
|
|
medusaProcess.on("uncaughtException", (err) => {
|
|
console.log(err)
|
|
medusaProcess.kill()
|
|
})
|
|
|
|
medusaProcess.on("message", (port) => {
|
|
setPort(port)
|
|
resolve(medusaProcess)
|
|
})
|
|
|
|
medusaProcess.on("exit", () => {
|
|
const expressServer = useExpressServer()
|
|
|
|
setContainer(null)
|
|
|
|
if (expressServer) {
|
|
expressServer.close()
|
|
}
|
|
})
|
|
})
|
|
}
|