chore: Move admin region tests (#7582)

This commit is contained in:
Oli Juhl
2024-06-03 14:25:43 +02:00
committed by GitHub
parent b299aec620
commit 0c0c510a37
4 changed files with 284 additions and 483 deletions

View File

@@ -1,482 +0,0 @@
const path = require("path")
const { Region } = require("@medusajs/medusa")
const setupServer = require("../../../environment-helpers/setup-server")
const startServerWithEnvironment =
require("../../../environment-helpers/start-server-with-environment").default
const { useApi } = require("../../../environment-helpers/use-api")
const { initDb, useDb } = require("../../../environment-helpers/use-db")
const adminSeeder = require("../../../helpers/admin-seeder")
const { simpleRegionFactory } = require("../../../factories")
const adminReqConfig = {
headers: {
"x-medusa-access-token": "test_token",
},
}
jest.setTimeout(30000)
describe("/admin/regions", () => {
let medusaProcess
let dbConnection
const cwd = path.resolve(path.join(__dirname, "..", ".."))
beforeAll(async () => {
dbConnection = await initDb({ cwd })
medusaProcess = await setupServer({ cwd })
})
afterAll(async () => {
const db = useDb()
await db.shutdown()
medusaProcess.kill()
})
describe("Remove region from country on delete", () => {
beforeEach(async () => {
await adminSeeder(dbConnection)
const manager = dbConnection.manager
await manager.insert(Region, {
id: "test-region",
name: "Test Region",
currency_code: "usd",
tax_rate: 0,
})
await manager.query(
`UPDATE "country" SET region_id='test-region' WHERE iso_2 = 'us'`
)
})
afterEach(async () => {
const db = useDb()
await db.teardown()
})
it("should successfully creates a region with countries from a previously deleted region", async () => {
const api = useApi()
const response = await api
.delete(`/admin/regions/test-region`, adminReqConfig)
.catch((err) => {
console.log(err)
})
expect(response.status).toEqual(200)
expect(response.data).toMatchSnapshot({
id: "test-region",
object: "region",
deleted: true,
})
const newReg = await api.post(
`/admin/regions`,
{
name: "World",
currency_code: "usd",
tax_rate: 0,
payment_providers: ["test-pay"],
fulfillment_providers: ["test-ful"],
countries: ["us"],
},
adminReqConfig
)
expect(newReg.status).toEqual(200)
expect(newReg.data.region).toMatchSnapshot({
id: expect.any(String),
name: "World",
currency_code: "usd",
countries: [
{
region_id: expect.any(String),
},
],
tax_rate: 0,
fulfillment_providers: [
{
id: "test-ful",
is_installed: true,
},
],
created_at: expect.any(String),
updated_at: expect.any(String),
})
})
})
describe("GET /admin/regions", () => {
beforeEach(async () => {
const manager = dbConnection.manager
await adminSeeder(dbConnection)
await manager.insert(Region, {
id: "test-region",
name: "Test Region",
currency_code: "usd",
tax_rate: 0,
})
await manager.insert(Region, {
id: "test-region-deleted",
name: "Test Region",
currency_code: "usd",
tax_rate: 0,
deleted_at: new Date(),
})
await manager.insert(Region, {
id: "test-region-updated",
name: "Test Region updated",
currency_code: "usd",
tax_rate: 0,
updated_at: new Date(),
})
await manager.insert(Region, {
id: "test-region-updated-1",
name: "Test Region updated 1",
currency_code: "usd",
tax_rate: 0,
updated_at: new Date("10/10/2000"),
})
await manager.insert(Region, {
id: "us-region",
name: "United States",
currency_code: "usd",
tax_rate: 0,
updated_at: new Date("10/10/2000"),
})
await manager.insert(Region, {
id: "uk-region",
name: "United Kingdom",
currency_code: "gbp",
tax_rate: 0,
updated_at: new Date("10/10/2000"),
})
})
afterEach(async () => {
const db = useDb()
await db.teardown()
})
it("should list the regions with expand currency relation", async () => {
const api = useApi()
const response = await api.get(
"/admin/regions?limit=1&offset=1&expand=currency",
adminReqConfig
)
expect(response.status).toEqual(200)
expect(response.data.regions[0].currency).toEqual(
expect.objectContaining({
code: "usd",
})
)
})
it("should list the regions with q and order params", async () => {
const api = useApi()
const response = await api.get(
"/admin/regions?q=united&order=currency_code",
adminReqConfig
)
expect(response.status).toEqual(200)
expect(response.data.regions).toEqual([
expect.objectContaining({
name: "United Kingdom",
currency_code: "gbp",
}),
expect.objectContaining({
name: "United States",
currency_code: "usd",
}),
])
})
it("should only return non-deleted regions", async () => {
const api = useApi()
const response = await api
.get(`/admin/regions`, adminReqConfig)
.catch((err) => {
console.log(err)
})
expect(response.data.regions).toHaveLength(5)
expect(response.data.regions).toEqual(
expect.arrayContaining([
expect.objectContaining({
id: "test-region-updated-1",
}),
expect.objectContaining({
id: "test-region",
}),
expect.objectContaining({
id: "test-region-updated",
}),
])
)
expect(response.status).toEqual(200)
})
it("should return count of total regions", async () => {
const api = useApi()
const response = await api.get(`/admin/regions?limit=2`, adminReqConfig)
expect(response.data.regions).toHaveLength(2)
expect(response.data.count).toEqual(5)
expect(response.status).toEqual(200)
})
it("should filter correctly on update", async () => {
const api = useApi()
const response = await api
.get(`/admin/regions?updated_at[gt]=10-10-2005`, adminReqConfig)
.catch((err) => {
console.log(err)
})
expect(response.data.regions).toHaveLength(2)
expect(response.data.regions).toEqual(
expect.arrayContaining([
expect.objectContaining({
id: "test-region",
}),
expect.objectContaining({
id: "test-region-updated",
}),
])
)
expect(response.status).toEqual(200)
})
})
describe("GET /admin/regions/:id", () => {
beforeEach(async () => {
const manager = dbConnection.manager
await adminSeeder(dbConnection)
await manager.insert(Region, {
id: "region-id",
name: "Test Region",
currency_code: "usd",
tax_rate: 0,
})
})
afterEach(async () => {
const db = useDb()
await db.teardown()
})
it("should retrieve the region from ID", async () => {
const api = useApi()
const response = await api.get(
`/admin/regions/region-id?expand=currency`,
adminReqConfig
)
expect(response.status).toEqual(200)
expect(response.data.region).toEqual(
expect.objectContaining({
id: "region-id",
currency: expect.objectContaining({
code: "usd",
}),
})
)
})
it("should throw an error when region ID is invalid", async () => {
const api = useApi()
const error = await api
.get(`/admin/regions/invalid-region-id`, adminReqConfig)
.catch((e) => e)
expect(error.response.status).toEqual(404)
expect(error.response.data).toEqual({
type: "not_found",
message: "Region with invalid-region-id was not found",
})
})
})
describe("DELETE /admin/regions/:id", () => {
beforeEach(async () => {
await adminSeeder(dbConnection)
const manager = dbConnection.manager
await manager.insert(Region, {
id: "test-region",
name: "Test Region",
currency_code: "usd",
tax_rate: 0,
})
await manager.query(
`UPDATE "country" SET region_id='test-region' WHERE iso_2 = 'us'`
)
})
afterEach(async () => {
const db = useDb()
await db.teardown()
})
it("should successfully deletes a region with a fulfillment provider", async () => {
const api = useApi()
// add fulfillment provider to the region
await api.post(
"/admin/regions/test-region",
{
fulfillment_providers: ["test-ful"],
},
adminReqConfig
)
const response = await api
.delete(`/admin/regions/test-region`, adminReqConfig)
.catch((err) => {
console.log(err)
})
expect(response.data).toEqual({
id: "test-region",
object: "region",
deleted: true,
})
expect(response.status).toEqual(200)
})
it("should fails to create when countries exists in different region", async () => {
const api = useApi()
try {
await api.post(
`/admin/regions`,
{
name: "World",
currency_code: "usd",
tax_rate: 0,
payment_providers: ["test-pay"],
fulfillment_providers: ["test-ful"],
countries: ["us"],
},
adminReqConfig
)
} catch (error) {
expect(error.response.status).toEqual(422)
expect(error.response.data.message).toEqual(
"United States already exists in region test-region"
)
}
})
})
})
describe("[MEDUSA_FF_TAX_INCLUSIVE_PRICING] /admin/regions", () => {
let medusaProcess
let dbConnection
beforeAll(async () => {
const cwd = path.resolve(path.join(__dirname, "..", ".."))
const [process, connection] = await startServerWithEnvironment({
cwd,
env: { MEDUSA_FF_TAX_INCLUSIVE_PRICING: true },
})
dbConnection = connection
medusaProcess = process
})
afterAll(async () => {
const db = useDb()
await db.shutdown()
medusaProcess.kill()
})
describe("POST /admin/regions/:id", () => {
const region1TaxInclusiveId = "region-1-tax-inclusive"
beforeEach(async () => {
try {
await adminSeeder(dbConnection)
await simpleRegionFactory(dbConnection, {
id: region1TaxInclusiveId,
countries: ["fr"],
})
} catch (err) {
console.log(err)
throw err
}
})
afterEach(async () => {
const db = useDb()
await db.teardown()
})
it("should allow to create a region that includes tax", async function () {
const api = useApi()
const payload = {
name: "region-including-taxes",
currency_code: "usd",
tax_rate: 0,
payment_providers: ["test-pay"],
fulfillment_providers: ["test-ful"],
countries: ["us"],
includes_tax: true,
}
const response = await api
.post(`/admin/regions`, payload, adminReqConfig)
.catch((err) => {
console.log(err)
})
expect(response.data.region).toEqual(
expect.objectContaining({
id: expect.any(String),
includes_tax: true,
name: "region-including-taxes",
})
)
})
it("should allow to update a region that includes tax", async function () {
const api = useApi()
let response = await api
.get(`/admin/regions/${region1TaxInclusiveId}`, adminReqConfig)
.catch((err) => {
console.log(err)
})
expect(response.data.region.includes_tax).toBe(false)
response = await api
.post(
`/admin/regions/${region1TaxInclusiveId}`,
{
includes_tax: true,
},
adminReqConfig
)
.catch((err) => {
console.log(err)
})
expect(response.data.region.includes_tax).toBe(true)
})
})
})

View File

@@ -0,0 +1,274 @@
import { medusaIntegrationTestRunner } from "medusa-test-utils"
import {
adminHeaders,
createAdminUser,
} from "../../../../helpers/create-admin-user"
jest.setTimeout(30000)
medusaIntegrationTestRunner({
testSuite: ({ dbConnection, getContainer, api }) => {
beforeAll(() => {})
beforeEach(async () => {
const container = getContainer()
await createAdminUser(dbConnection, adminHeaders, container)
})
describe("GET /admin/regions", () => {
let region1
let region2
beforeEach(async () => {
region1 = (
await api.post(
"/admin/regions",
{
name: "United Kingdom",
currency_code: "gbp",
},
adminHeaders
)
).data.region
region2 = (
await api.post(
"/admin/regions",
{
name: "United States",
currency_code: "usd",
},
adminHeaders
)
).data.region
})
it("should list regions", async () => {
const response = await api.get("/admin/regions", adminHeaders)
expect(response.status).toEqual(200)
expect(response.data.regions).toEqual([
expect.objectContaining({
name: "United Kingdom",
}),
expect.objectContaining({
name: "United States",
}),
])
})
it("should list the regions with q and order params", async () => {
const response = await api.get(
"/admin/regions?q=united&order=-currency_code",
adminHeaders
)
expect(response.status).toEqual(200)
expect(response.data.regions).toEqual([
expect.objectContaining({
name: "United States",
currency_code: "usd",
}),
expect.objectContaining({
name: "United Kingdom",
currency_code: "gbp",
}),
])
})
})
describe("GET /admin/regions/:id", () => {
let region1
beforeEach(async () => {
region1 = (
await api.post(
"/admin/regions",
{
name: "United Kingdom",
currency_code: "gbp",
},
adminHeaders
)
).data.region
})
it("should retrieve the region from ID", async () => {
const response = await api.get(
`/admin/regions/${region1.id}`,
adminHeaders
)
expect(response.status).toEqual(200)
expect(response.data.region).toEqual(
expect.objectContaining({
id: region1.id,
})
)
})
it("should throw an error when region ID is invalid", async () => {
await api
.get(`/admin/regions/invalid-region-id`, adminHeaders)
.catch((e) => {
expect(e.response.status).toEqual(404)
expect(e.response.data.type).toEqual("not_found")
expect(e.response.data.message).toEqual(
`Region with id: invalid-region-id not found`
)
})
})
})
describe("POST /admin/regions", () => {
beforeEach(async () => {
await api.post(
"/admin/regions",
{
name: "United States",
currency_code: "usd",
countries: ["us"],
},
adminHeaders
)
})
it("should create a region", async () => {
const region = (
await api.post(
"/admin/regions",
{
name: "Test",
currency_code: "usd",
},
adminHeaders
)
).data.region
expect(region).toEqual(
expect.objectContaining({
name: "Test",
currency_code: "usd",
})
)
})
it("should fails to create when countries exists in different region", async () => {
try {
await api.post(
`/admin/regions`,
{
name: "World",
currency_code: "usd",
countries: ["us"],
},
adminHeaders
)
} catch (error) {
expect(error.response.status).toEqual(400)
expect(error.response.data.message).toEqual(
`Countries with codes: \"us\" are already assigned to a region`
)
}
})
})
// TODO: Migrate when tax_inclusive_pricing is implemented
// describe("[MEDUSA_FF_TAX_INCLUSIVE_PRICING] /admin/regions", () => {
// let medusaProcess
// let dbConnection
// beforeAll(async () => {
// const cwd = path.resolve(path.join(__dirname, "..", ".."))
// const [process, connection] = await startServerWithEnvironment({
// cwd,
// env: { MEDUSA_FF_TAX_INCLUSIVE_PRICING: true },
// })
// dbConnection = connection
// medusaProcess = process
// })
// afterAll(async () => {
// const db = useDb()
// await db.shutdown()
// medusaProcess.kill()
// })
// describe("POST /admin/regions/:id", () => {
// const region1TaxInclusiveId = "region-1-tax-inclusive"
// beforeEach(async () => {
// try {
// await adminSeeder(dbConnection)
// await simpleRegionFactory(dbConnection, {
// id: region1TaxInclusiveId,
// countries: ["fr"],
// })
// } catch (err) {
// console.log(err)
// throw err
// }
// })
// afterEach(async () => {
// const db = useDb()
// await db.teardown()
// })
// it("should allow to create a region that includes tax", async function () {
// const api = useApi()
// const payload = {
// name: "region-including-taxes",
// currency_code: "usd",
// tax_rate: 0,
// payment_providers: ["test-pay"],
// fulfillment_providers: ["test-ful"],
// countries: ["us"],
// includes_tax: true,
// }
// const response = await api
// .post(`/admin/regions`, payload, adminReqConfig)
// .catch((err) => {
// console.log(err)
// })
// expect(response.data.region).toEqual(
// expect.objectContaining({
// id: expect.any(String),
// includes_tax: true,
// name: "region-including-taxes",
// })
// )
// })
// it("should allow to update a region that includes tax", async function () {
// const api = useApi()
// let response = await api
// .get(`/admin/regions/${region1TaxInclusiveId}`, adminReqConfig)
// .catch((err) => {
// console.log(err)
// })
// expect(response.data.region.includes_tax).toBe(false)
// response = await api
// .post(
// `/admin/regions/${region1TaxInclusiveId}`,
// {
// includes_tax: true,
// },
// adminReqConfig
// )
// .catch((err) => {
// console.log(err)
// })
// expect(response.data.region.includes_tax).toBe(true)
// })
// })
// })
},
})

View File

@@ -2,6 +2,7 @@ import {
deleteRegionsWorkflow,
updateRegionsWorkflow,
} from "@medusajs/core-flows"
import { MedusaError } from "@medusajs/utils"
import {
AuthenticatedMedusaRequest,
MedusaResponse,
@@ -18,6 +19,14 @@ export const GET = async (
req.scope,
req.remoteQueryConfig.fields
)
if (!region) {
throw new MedusaError(
MedusaError.Types.NOT_FOUND,
`Region with id: ${req.params.id} not found`
)
}
res.status(200).json({ region })
}

View File

@@ -14,6 +14,7 @@ import {
} from "@medusajs/types"
import {
arrayDifference,
getDuplicates,
InjectManager,
InjectTransactionManager,
isString,
@@ -22,7 +23,6 @@ import {
ModulesSdkUtils,
promiseAll,
removeUndefined,
getDuplicates,
} from "@medusajs/utils"
import { Country, Region } from "@models"