Skip to content

Commit

Permalink
Merge branch 'develop' into fix/avoid-dev-cli-auth
Browse files Browse the repository at this point in the history
  • Loading branch information
olivermrbl authored Oct 11, 2022
2 parents 6d3bf21 + c717442 commit 5764ada
Show file tree
Hide file tree
Showing 22 changed files with 455 additions and 188 deletions.
5 changes: 5 additions & 0 deletions .changeset/brown-cups-draw.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@medusajs/medusa": patch
---

feat(medusa): Allow to filter collections by discount condition id
5 changes: 5 additions & 0 deletions .changeset/perfect-beers-notice.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@medusajs/medusa": patch
---

feat(medusa): Allow to query product tags by condition id
Original file line number Diff line number Diff line change
Expand Up @@ -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>,
Expand All @@ -16,9 +16,9 @@ Array [
},
Object {
"created_at": Any<String>,
"id": "tag4",
"id": "tag1",
"updated_at": Any<String>,
"value": "1234",
"value": "123",
},
]
`;
Expand All @@ -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>,
Expand All @@ -39,9 +39,9 @@ Array [
},
Object {
"created_at": Any<String>,
"id": "tag4",
"id": "tag1",
"updated_at": Any<String>,
"value": "1234",
"value": "123",
},
]
`;
92 changes: 92 additions & 0 deletions integration-tests/api/__tests__/admin/colllections.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,23 @@ const { initDb, useDb } = require("../../../helpers/use-db")

const productSeeder = require("../../helpers/product-seeder")
const adminSeeder = require("../../helpers/admin-seeder")
const {
DiscountRuleType,
AllocationType,
DiscountConditionType,
DiscountConditionOperator,
} = require("@medusajs/medusa")
const { IdMap } = require("medusa-test-utils")
const { simpleDiscountFactory } = require("../../factories")

jest.setTimeout(30000)

const adminReqConfig = {
headers: {
Authorization: "Bearer test_token",
},
}

describe("/admin/collections", () => {
let medusaProcess
let dbConnection
Expand Down Expand Up @@ -334,5 +349,82 @@ describe("/admin/collections", () => {
offset: 0,
})
})

it("returns a list of collections filtered by discount condition id", async () => {
const api = useApi()

const resCollections = await api.get("/admin/collections", adminReqConfig)

const collection1 = resCollections.data.collections[0]
const collection2 = resCollections.data.collections[1]

const buildDiscountData = (code, conditionId, collections) => {
return {
code,
rule: {
type: DiscountRuleType.PERCENTAGE,
value: 10,
allocation: AllocationType.TOTAL,
conditions: [
{
id: conditionId,
type: DiscountConditionType.PRODUCT_COLLECTIONS,
operator: DiscountConditionOperator.IN,
product_collections: collections,
},
],
},
}
}

const discountConditionId = IdMap.getId("discount-condition-type-1")
await simpleDiscountFactory(
dbConnection,
buildDiscountData("code-1", discountConditionId, [collection1.id])
)

const discountConditionId2 = IdMap.getId("discount-condition-type-2")
await simpleDiscountFactory(
dbConnection,
buildDiscountData("code-2", discountConditionId2, [collection2.id])
)

let res = await api.get(
`/admin/collections?discount_condition_id=${discountConditionId}`,
adminReqConfig
)

expect(res.status).toEqual(200)
expect(res.data.collections).toHaveLength(1)
expect(res.data.collections).toEqual(
expect.arrayContaining([
expect.objectContaining({ id: collection1.id }),
])
)

res = await api.get(
`/admin/collections?discount_condition_id=${discountConditionId2}`,
adminReqConfig
)

expect(res.status).toEqual(200)
expect(res.data.collections).toHaveLength(1)
expect(res.data.collections).toEqual(
expect.arrayContaining([
expect.objectContaining({ id: collection2.id }),
])
)

res = await api.get(`/admin/collections`, adminReqConfig)

expect(res.status).toEqual(200)
expect(res.data.collections).toHaveLength(3)
expect(res.data.collections).toEqual(
expect.arrayContaining([
expect.objectContaining({ id: collection1.id }),
expect.objectContaining({ id: collection2.id }),
])
)
})
})
})
101 changes: 90 additions & 11 deletions integration-tests/api/__tests__/admin/product-tag.js
Original file line number Diff line number Diff line change
@@ -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
Expand All @@ -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 () => {
Expand All @@ -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)
})
Expand All @@ -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)
})
Expand All @@ -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 }),
])
)
})
})
})
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,10 @@ Object {
Object {
"created_at": Any<String>,
"deleted_at": null,
"handle": "test-collection",
"id": "test-collection",
"handle": "test-collection2",
"id": "test-collection2",
"metadata": null,
"title": "Test collection",
"title": "Test collection 2",
"updated_at": Any<String>,
},
Object {
Expand All @@ -24,10 +24,10 @@ Object {
Object {
"created_at": Any<String>,
"deleted_at": null,
"handle": "test-collection2",
"id": "test-collection2",
"handle": "test-collection",
"id": "test-collection",
"metadata": null,
"title": "Test collection 2",
"title": "Test collection",
"updated_at": Any<String>,
},
],
Expand Down
4 changes: 2 additions & 2 deletions integration-tests/api/__tests__/store/collections.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ describe("/store/collections", () => {
expect(response.data).toMatchSnapshot({
collections: [
{
id: "test-collection",
id: "test-collection2",
created_at: expect.any(String),
updated_at: expect.any(String),
},
Expand All @@ -76,7 +76,7 @@ describe("/store/collections", () => {
updated_at: expect.any(String),
},
{
id: "test-collection2",
id: "test-collection",
created_at: expect.any(String),
updated_at: expect.any(String),
},
Expand Down
Loading

0 comments on commit 5764ada

Please sign in to comment.