chore: Move admin region tests (#7582)
This commit is contained in:
@@ -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)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
274
integration-tests/http/__tests__/region/admin/region.spec.ts
Normal file
274
integration-tests/http/__tests__/region/admin/region.spec.ts
Normal 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)
|
||||||
|
// })
|
||||||
|
// })
|
||||||
|
// })
|
||||||
|
},
|
||||||
|
})
|
||||||
@@ -2,6 +2,7 @@ import {
|
|||||||
deleteRegionsWorkflow,
|
deleteRegionsWorkflow,
|
||||||
updateRegionsWorkflow,
|
updateRegionsWorkflow,
|
||||||
} from "@medusajs/core-flows"
|
} from "@medusajs/core-flows"
|
||||||
|
import { MedusaError } from "@medusajs/utils"
|
||||||
import {
|
import {
|
||||||
AuthenticatedMedusaRequest,
|
AuthenticatedMedusaRequest,
|
||||||
MedusaResponse,
|
MedusaResponse,
|
||||||
@@ -18,6 +19,14 @@ export const GET = async (
|
|||||||
req.scope,
|
req.scope,
|
||||||
req.remoteQueryConfig.fields
|
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 })
|
res.status(200).json({ region })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import {
|
|||||||
} from "@medusajs/types"
|
} from "@medusajs/types"
|
||||||
import {
|
import {
|
||||||
arrayDifference,
|
arrayDifference,
|
||||||
|
getDuplicates,
|
||||||
InjectManager,
|
InjectManager,
|
||||||
InjectTransactionManager,
|
InjectTransactionManager,
|
||||||
isString,
|
isString,
|
||||||
@@ -22,7 +23,6 @@ import {
|
|||||||
ModulesSdkUtils,
|
ModulesSdkUtils,
|
||||||
promiseAll,
|
promiseAll,
|
||||||
removeUndefined,
|
removeUndefined,
|
||||||
getDuplicates,
|
|
||||||
} from "@medusajs/utils"
|
} from "@medusajs/utils"
|
||||||
|
|
||||||
import { Country, Region } from "@models"
|
import { Country, Region } from "@models"
|
||||||
|
|||||||
Reference in New Issue
Block a user