**What** I have created a new method on the cart service which is `addLineItems`, allowing a user to add one or multiple items in an optimized way. Also updated the `generate` method from the line item service which now also accept a object data or a collection of data which. Various places have been optimized and cache support has been added to the price selection strategy. The overall optimization allows to reach another 9000% improvement in the response time as a median (Creating a cart with 6 items): | | Min (ms) | Median (ms) | Max (ms) | Median Improvement (%) |---|:-:|---|---|---| | Before optimisation | 1200 | 9999 | 12698 | N/A | After optimisation | 63 | 252 | 500 | 39x | After re optimisation | 56 | 82 | 399 | 121x | After including addressed feedback | 65 | 202 | 495 | 49x FIXES CORE-722
91 lines
2.2 KiB
JavaScript
91 lines
2.2 KiB
JavaScript
const { ProductCollection } = require("@medusajs/medusa")
|
|
const path = require("path")
|
|
const setupServer = require("../../../helpers/setup-server")
|
|
const { useApi } = require("../../../helpers/use-api")
|
|
const { initDb, useDb } = require("../../../helpers/use-db")
|
|
|
|
const productSeeder = require("../../helpers/product-seeder")
|
|
|
|
jest.setTimeout(30000)
|
|
describe("/store/collections", () => {
|
|
let medusaProcess
|
|
let dbConnection
|
|
|
|
beforeAll(async () => {
|
|
const cwd = path.resolve(path.join(__dirname, "..", ".."))
|
|
dbConnection = await initDb({ cwd })
|
|
medusaProcess = await setupServer({ cwd })
|
|
})
|
|
|
|
afterAll(async () => {
|
|
const db = useDb()
|
|
await db.shutdown()
|
|
medusaProcess.kill()
|
|
})
|
|
|
|
describe("/store/collections/:id", () => {
|
|
beforeEach(async () => {
|
|
await productSeeder(dbConnection)
|
|
})
|
|
|
|
afterEach(async () => {
|
|
const db = useDb()
|
|
await db.teardown()
|
|
})
|
|
|
|
it("gets collection", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api.get("/store/collections/test-collection")
|
|
|
|
expect(response.data).toMatchSnapshot({
|
|
collection: {
|
|
id: "test-collection",
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
},
|
|
})
|
|
})
|
|
})
|
|
|
|
describe("/store/collections", () => {
|
|
beforeEach(async () => {
|
|
await productSeeder(dbConnection)
|
|
})
|
|
|
|
afterEach(async () => {
|
|
const db = useDb()
|
|
await db.teardown()
|
|
})
|
|
|
|
it("lists collections", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api.get("/store/collections")
|
|
|
|
expect(response.data).toMatchSnapshot({
|
|
collections: [
|
|
{
|
|
id: "test-collection2",
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
},
|
|
{
|
|
id: "test-collection1",
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
},
|
|
{
|
|
id: "test-collection",
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
},
|
|
],
|
|
count: 3,
|
|
limit: 10,
|
|
offset: 0,
|
|
})
|
|
})
|
|
})
|
|
})
|