feat(medusa): Allow to query product tags by condition id (#2340)

This commit is contained in:
Adrien de Peretti
2022-10-11 11:24:50 +02:00
committed by GitHub
parent 94c242f476
commit a9c703d56c
9 changed files with 207 additions and 120 deletions
@@ -4,9 +4,9 @@ exports[`/admin/product-tags GET /admin/product-tags returns a list of product t
Array [
Object {
"created_at": Any<String>,
"id": "tag1",
"id": "tag4",
"updated_at": Any<String>,
"value": "123",
"value": "1234",
},
Object {
"created_at": Any<String>,
@@ -16,9 +16,9 @@ Array [
},
Object {
"created_at": Any<String>,
"id": "tag4",
"id": "tag1",
"updated_at": Any<String>,
"value": "1234",
"value": "123",
},
]
`;
@@ -27,9 +27,9 @@ exports[`/admin/product-tags GET /admin/product-tags returns a list of product t
Array [
Object {
"created_at": Any<String>,
"id": "tag1",
"id": "tag4",
"updated_at": Any<String>,
"value": "123",
"value": "1234",
},
Object {
"created_at": Any<String>,
@@ -39,9 +39,9 @@ Array [
},
Object {
"created_at": Any<String>,
"id": "tag4",
"id": "tag1",
"updated_at": Any<String>,
"value": "1234",
"value": "123",
},
]
`;
@@ -1,14 +1,28 @@
const path = require("path")
const { IdMap } = require("medusa-test-utils")
const setupServer = require("../../../helpers/setup-server")
const { useApi } = require("../../../helpers/use-api")
const { initDb, useDb } = require("../../../helpers/use-db")
const adminSeeder = require("../../helpers/admin-seeder")
const productSeeder = require("../../helpers/product-seeder")
const {
DiscountConditionType,
DiscountConditionOperator,
} = require("@medusajs/medusa")
const { simpleDiscountFactory } = require("../../factories")
const { DiscountRuleType, AllocationType } = require("@medusajs/medusa/dist")
jest.setTimeout(50000)
const adminReqConfig = {
headers: {
Authorization: "Bearer test_token",
},
}
describe("/admin/product-tags", () => {
let medusaProcess
let dbConnection
@@ -28,8 +42,8 @@ describe("/admin/product-tags", () => {
describe("GET /admin/product-tags", () => {
beforeEach(async () => {
await productSeeder(dbConnection)
await adminSeeder(dbConnection)
await productSeeder(dbConnection)
})
afterEach(async () => {
@@ -41,11 +55,7 @@ describe("/admin/product-tags", () => {
const api = useApi()
const res = await api
.get("/admin/product-tags", {
headers: {
Authorization: "Bearer test_token",
},
})
.get("/admin/product-tags", adminReqConfig)
.catch((err) => {
console.log(err)
})
@@ -68,11 +78,7 @@ describe("/admin/product-tags", () => {
const api = useApi()
const res = await api
.get("/admin/product-tags?q=123", {
headers: {
Authorization: "Bearer test_token",
},
})
.get("/admin/product-tags?q=123", adminReqConfig)
.catch((err) => {
console.log(err)
})
@@ -95,5 +101,78 @@ describe("/admin/product-tags", () => {
tagMatch,
])
})
it("returns a list of product tags filtered by discount condition id", async () => {
const api = useApi()
const resTags = await api.get("/admin/product-tags", adminReqConfig)
const tag1 = resTags.data.product_tags[0]
const tag2 = resTags.data.product_tags[2]
const buildDiscountData = (code, conditionId, tags) => {
return {
code,
rule: {
type: DiscountRuleType.PERCENTAGE,
value: 10,
allocation: AllocationType.TOTAL,
conditions: [
{
id: conditionId,
type: DiscountConditionType.PRODUCT_TAGS,
operator: DiscountConditionOperator.IN,
product_tags: tags,
},
],
},
}
}
const discountConditionId = IdMap.getId("discount-condition-tag-1")
await simpleDiscountFactory(
dbConnection,
buildDiscountData("code-1", discountConditionId, [tag1.id])
)
const discountConditionId2 = IdMap.getId("discount-condition-tag-2")
await simpleDiscountFactory(
dbConnection,
buildDiscountData("code-2", discountConditionId2, [tag2.id])
)
let res = await api.get(
`/admin/product-tags?discount_condition_id=${discountConditionId}`,
adminReqConfig
)
expect(res.status).toEqual(200)
expect(res.data.product_tags).toHaveLength(1)
expect(res.data.product_tags).toEqual(
expect.arrayContaining([expect.objectContaining({ id: tag1.id })])
)
res = await api.get(
`/admin/product-tags?discount_condition_id=${discountConditionId2}`,
adminReqConfig
)
expect(res.status).toEqual(200)
expect(res.data.product_tags).toHaveLength(1)
expect(res.data.product_tags).toEqual(
expect.arrayContaining([expect.objectContaining({ id: tag2.id })])
)
res = await api.get(`/admin/product-tags`, adminReqConfig)
expect(res.status).toEqual(200)
expect(res.data.product_tags).toHaveLength(3)
expect(res.data.product_tags).toEqual(
expect.arrayContaining([
expect.objectContaining({ id: tag1.id }),
expect.objectContaining({ id: tag2.id }),
])
)
})
})
})