new wrapper for medusa integration tests. for now it is only applied to the modules directory, but it could be used in the api integration tests or any other integrations that requires a db and a server up and running. It is not perfect, but I wanted to have something working and centralised before improving it, also avoiding too many conflicts with other prs
216 lines
6.0 KiB
TypeScript
216 lines
6.0 KiB
TypeScript
import { ModuleRegistrationName } from "@medusajs/modules-sdk"
|
|
import { IRegionModuleService } from "@medusajs/types"
|
|
import { createAdminUser } from "../../../helpers/create-admin-user"
|
|
import { medusaIntegrationTestRunner } from "medusa-test-utils"
|
|
|
|
jest.setTimeout(50000)
|
|
|
|
const env = { MEDUSA_FF_MEDUSA_V2: true }
|
|
const adminHeaders = {
|
|
headers: { "x-medusa-access-token": "test_token" },
|
|
}
|
|
|
|
medusaIntegrationTestRunner({
|
|
env,
|
|
testSuite: ({ dbConnection, getContainer, api }) => {
|
|
describe("Regions - Admin", () => {
|
|
let appContainer
|
|
let service: IRegionModuleService
|
|
|
|
beforeAll(async () => {
|
|
appContainer = getContainer()
|
|
service = appContainer.resolve(ModuleRegistrationName.REGION)
|
|
})
|
|
|
|
beforeEach(async () => {
|
|
await createAdminUser(dbConnection, adminHeaders, appContainer)
|
|
})
|
|
|
|
afterEach(async () => {
|
|
// TODO: Once teardown doesn't skip constraint checks and cascades, we can remove this
|
|
const existingRegions = await service.list({})
|
|
await service.delete(existingRegions.map((r) => r.id))
|
|
})
|
|
|
|
it("should create, update, and delete a region", async () => {
|
|
const created = await api.post(
|
|
`/admin/regions`,
|
|
{
|
|
name: "Test Region",
|
|
currency_code: "usd",
|
|
countries: ["us", "ca"],
|
|
metadata: { foo: "bar" },
|
|
},
|
|
adminHeaders
|
|
)
|
|
|
|
expect(created.status).toEqual(200)
|
|
expect(created.data.region).toEqual(
|
|
expect.objectContaining({
|
|
id: created.data.region.id,
|
|
name: "Test Region",
|
|
currency_code: "usd",
|
|
metadata: { foo: "bar" },
|
|
})
|
|
)
|
|
expect(created.data.region.countries.map((c) => c.iso_2)).toEqual([
|
|
"us",
|
|
"ca",
|
|
])
|
|
|
|
const updated = await api.post(
|
|
`/admin/regions/${created.data.region.id}`,
|
|
{
|
|
name: "United States",
|
|
currency_code: "usd",
|
|
countries: ["us"],
|
|
metadata: { foo: "baz" },
|
|
},
|
|
adminHeaders
|
|
)
|
|
|
|
expect(updated.status).toEqual(200)
|
|
expect(updated.data.region).toEqual(
|
|
expect.objectContaining({
|
|
id: updated.data.region.id,
|
|
name: "United States",
|
|
currency_code: "usd",
|
|
metadata: { foo: "baz" },
|
|
})
|
|
)
|
|
expect(updated.data.region.countries.map((c) => c.iso_2)).toEqual([
|
|
"us",
|
|
])
|
|
|
|
const deleted = await api.delete(
|
|
`/admin/regions/${updated.data.region.id}`,
|
|
adminHeaders
|
|
)
|
|
|
|
expect(deleted.status).toEqual(200)
|
|
expect(deleted.data).toEqual({
|
|
id: updated.data.region.id,
|
|
object: "region",
|
|
deleted: true,
|
|
})
|
|
|
|
const deletedRegion = await service.retrieve(updated.data.region.id, {
|
|
withDeleted: true,
|
|
})
|
|
|
|
// @ts-ignore
|
|
expect(deletedRegion.deleted_at).toBeTruthy()
|
|
})
|
|
|
|
it("should throw on missing required properties in create", async () => {
|
|
const err = await api
|
|
.post(`/admin/regions`, {}, adminHeaders)
|
|
.catch((e) => e)
|
|
|
|
expect(err.response.status).toEqual(400)
|
|
expect(err.response.data.message).toEqual(
|
|
"name must be a string, currency_code must be a string"
|
|
)
|
|
})
|
|
|
|
it("should throw on unknown properties in create", async () => {
|
|
const error = await api
|
|
.post(
|
|
`/admin/regions`,
|
|
{
|
|
foo: "bar",
|
|
currency_code: "usd",
|
|
name: "Test Region",
|
|
},
|
|
adminHeaders
|
|
)
|
|
.catch((e) => e)
|
|
|
|
expect(error.response.status).toEqual(400)
|
|
expect(error.response.data.message).toEqual(
|
|
"property foo should not exist"
|
|
)
|
|
})
|
|
|
|
it("should throw on unknown properties in update", async () => {
|
|
const created = await service.create({
|
|
name: "Test Region",
|
|
currency_code: "usd",
|
|
})
|
|
|
|
const error = await api
|
|
.post(
|
|
`/admin/regions/${created.id}`,
|
|
{
|
|
foo: "bar",
|
|
currency_code: "usd",
|
|
name: "Test Region",
|
|
},
|
|
adminHeaders
|
|
)
|
|
.catch((e) => e)
|
|
|
|
expect(error.response.status).toEqual(400)
|
|
expect(error.response.data.message).toEqual(
|
|
"property foo should not exist"
|
|
)
|
|
})
|
|
|
|
it("should get all regions and count", async () => {
|
|
await service.create([
|
|
{
|
|
name: "Test",
|
|
currency_code: "usd",
|
|
countries: ["jp"],
|
|
metadata: { foo: "bar" },
|
|
},
|
|
])
|
|
|
|
const response = await api.get(`/admin/regions`, adminHeaders)
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.regions).toEqual([
|
|
expect.objectContaining({
|
|
id: expect.any(String),
|
|
name: "Test",
|
|
currency_code: "usd",
|
|
metadata: { foo: "bar" },
|
|
}),
|
|
])
|
|
expect(response.data.regions[0].countries.map((c) => c.iso_2)).toEqual([
|
|
"jp",
|
|
])
|
|
})
|
|
|
|
it("should get a region", async () => {
|
|
const [region] = await service.create([
|
|
{
|
|
name: "Test",
|
|
currency_code: "usd",
|
|
countries: ["jp"],
|
|
metadata: { foo: "bar" },
|
|
},
|
|
])
|
|
|
|
const response = await api.get(
|
|
`/admin/regions/${region.id}`,
|
|
adminHeaders
|
|
)
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.region).toEqual(
|
|
expect.objectContaining({
|
|
id: region.id,
|
|
name: "Test",
|
|
currency_code: "usd",
|
|
metadata: { foo: "bar" },
|
|
})
|
|
)
|
|
expect(response.data.region.countries.map((c) => c.iso_2)).toEqual([
|
|
"jp",
|
|
])
|
|
})
|
|
})
|
|
},
|
|
})
|