* fix babel transform-runtime regenerator required for migrations * add customer group model * add migration for customer group * add customer group model export * add customer group repository * add customer group service * add CustomerGroupRepository to "withTransaction" in CustomerGroupService * remove unnecessary argument to runtime plugin * service export ordering * add create customer group endpoint * add customergroup to route index in admin * add customer group service * add customer groups test * cleanup * add customers batch initial * batch creation of customer groups * integration testing batch creation * integration tests * chaining existing customers creation in repo * remove commented test * update unit tests to reflect change in idempotent behavior * ensure that exceptions are expected * update idempotency behavior * update formatting * update format * Update packages/medusa/src/repositories/customer-group.ts Co-authored-by: Sebastian Rindom <skrindom@gmail.com> * pr feedback * add In import * add seperate model dto * add integration test * error handling in repository * remove unused import * jsdoc * Update packages/medusa/src/api/routes/admin/customer-groups/add-customers-batch.ts Co-authored-by: Sebastian Rindom <skrindom@gmail.com> * Update packages/medusa/src/api/routes/admin/customer-groups/add-customers-batch.ts Co-authored-by: Sebastian Rindom <skrindom@gmail.com> * pr review comments * rename variable * fix: adds atomic phase clean up callback * fix: call error handler in new transaction block too * restore * error handling * fix: error handler in no isolation case * add integration test for missing group on update * final adjustments to test * fix pr feedback * cleanup core for pr * remove console.log * remove customergroupservice test from customers * Apply suggestions from code review Co-authored-by: Sebastian Rindom <skrindom@gmail.com> * add end bracket to customer tests * remove comments * change model decorator * fix integration test merge * onDelete cascade instead of cascade:true * remove verbose flag * fix: dedupe type * add save to customer groups * customer model delete cascade * add await to asyncronous save operations Co-authored-by: Sebastian Rindom <skrindom@gmail.com>
405 lines
10 KiB
JavaScript
405 lines
10 KiB
JavaScript
const path = require("path")
|
|
|
|
const setupServer = require("../../../helpers/setup-server")
|
|
const { useApi } = require("../../../helpers/use-api")
|
|
const { useDb, initDb } = require("../../../helpers/use-db")
|
|
|
|
const customerSeeder = require("../../helpers/customer-seeder")
|
|
const adminSeeder = require("../../helpers/admin-seeder")
|
|
|
|
jest.setTimeout(30000)
|
|
|
|
describe("/admin/customers", () => {
|
|
let medusaProcess
|
|
let dbConnection
|
|
|
|
beforeAll(async () => {
|
|
const cwd = path.resolve(path.join(__dirname, "..", ".."))
|
|
dbConnection = await initDb({ cwd })
|
|
medusaProcess = await setupServer({ cwd })
|
|
})
|
|
|
|
afterAll(async () => {
|
|
const db = useDb()
|
|
await db.shutdown()
|
|
|
|
medusaProcess.kill()
|
|
})
|
|
|
|
describe("GET /admin/customers", () => {
|
|
beforeEach(async () => {
|
|
try {
|
|
await adminSeeder(dbConnection)
|
|
await customerSeeder(dbConnection)
|
|
} catch (err) {
|
|
console.log(err)
|
|
throw err
|
|
}
|
|
})
|
|
|
|
afterEach(async () => {
|
|
const db = useDb()
|
|
await db.teardown()
|
|
})
|
|
|
|
it("lists customers and query count", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api
|
|
.get("/admin/customers", {
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
})
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.count).toEqual(8)
|
|
expect(response.data.customers).toEqual(
|
|
expect.arrayContaining([
|
|
expect.objectContaining({
|
|
id: "test-customer-1",
|
|
}),
|
|
expect.objectContaining({
|
|
id: "test-customer-2",
|
|
}),
|
|
expect.objectContaining({
|
|
id: "test-customer-3",
|
|
}),
|
|
expect.objectContaining({
|
|
id: "test-customer-has_account",
|
|
}),
|
|
])
|
|
)
|
|
})
|
|
|
|
it("lists customers with specific query", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api
|
|
.get("/admin/customers?q=est2@", {
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
})
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.count).toEqual(1)
|
|
expect(response.data.customers).toEqual(
|
|
expect.arrayContaining([
|
|
expect.objectContaining({
|
|
id: "test-customer-2",
|
|
email: "test2@email.com",
|
|
}),
|
|
])
|
|
)
|
|
})
|
|
|
|
it("lists customers with expand query", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api
|
|
.get("/admin/customers?q=test1@email.com&expand=shipping_addresses", {
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
})
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.count).toEqual(1)
|
|
expect(response.data.customers).toEqual(
|
|
expect.arrayContaining([
|
|
expect.objectContaining({
|
|
id: "test-customer-1",
|
|
shipping_addresses: expect.arrayContaining([
|
|
expect.objectContaining({
|
|
id: "test-address",
|
|
first_name: "Lebron",
|
|
last_name: "James",
|
|
}),
|
|
]),
|
|
}),
|
|
])
|
|
)
|
|
})
|
|
})
|
|
|
|
describe("POST /admin/customers", () => {
|
|
beforeEach(async () => {
|
|
try {
|
|
await adminSeeder(dbConnection)
|
|
} catch (err) {
|
|
console.log(err)
|
|
throw err
|
|
}
|
|
})
|
|
|
|
afterEach(async () => {
|
|
const db = useDb()
|
|
await db.teardown()
|
|
})
|
|
|
|
it("Correctly creates customer", async () => {
|
|
const api = useApi()
|
|
const response = await api
|
|
.post(
|
|
"/admin/customers",
|
|
{
|
|
first_name: "newf",
|
|
last_name: "newl",
|
|
email: "new@email.com",
|
|
password: "newpassword",
|
|
metadata: { foo: "bar" },
|
|
},
|
|
{
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
}
|
|
)
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(201)
|
|
expect(response.data.customer).toEqual(
|
|
expect.objectContaining({
|
|
first_name: "newf",
|
|
last_name: "newl",
|
|
email: "new@email.com",
|
|
metadata: { foo: "bar" },
|
|
})
|
|
)
|
|
})
|
|
})
|
|
|
|
describe("POST /admin/customers/:id", () => {
|
|
beforeEach(async () => {
|
|
try {
|
|
await adminSeeder(dbConnection)
|
|
await customerSeeder(dbConnection)
|
|
} catch (err) {
|
|
console.log(err)
|
|
throw err
|
|
}
|
|
})
|
|
|
|
afterEach(async () => {
|
|
const db = useDb()
|
|
await db.teardown()
|
|
})
|
|
|
|
it("Correctly updates customer", async () => {
|
|
const api = useApi()
|
|
const response = await api
|
|
.post(
|
|
"/admin/customers/test-customer-3",
|
|
{
|
|
first_name: "newf",
|
|
last_name: "newl",
|
|
email: "new@email.com",
|
|
metadata: { foo: "bar" },
|
|
},
|
|
{
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
}
|
|
)
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.customer).toEqual(
|
|
expect.objectContaining({
|
|
first_name: "newf",
|
|
last_name: "newl",
|
|
email: "new@email.com",
|
|
metadata: { foo: "bar" },
|
|
})
|
|
)
|
|
})
|
|
|
|
it("fails when adding a customer group which doesn't exist", async () => {
|
|
expect.assertions(3)
|
|
// Try adding a non existing group
|
|
const api = useApi()
|
|
|
|
await api
|
|
.post(
|
|
"/admin/customers/test-customer-3?expand=groups",
|
|
{
|
|
groups: [{ id: "fake-group-0" }],
|
|
},
|
|
{
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
}
|
|
)
|
|
.catch((error) => {
|
|
expect(error.response.status).toEqual(404)
|
|
expect(error.response.data.type).toEqual("not_found")
|
|
expect(error.response.data.message).toEqual(
|
|
"Customer_group with customer_group_id fake-group-0 does not exist."
|
|
)
|
|
})
|
|
})
|
|
|
|
it("Correctly updates customer groups", async () => {
|
|
const api = useApi()
|
|
let response = await api
|
|
.post(
|
|
"/admin/customers/test-customer-3?expand=groups",
|
|
{
|
|
groups: [{ id: "test-group-4" }],
|
|
},
|
|
{
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
}
|
|
)
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.customer.groups).toEqual(
|
|
expect.arrayContaining([
|
|
expect.objectContaining({ id: "test-group-4", name: "test-group-4" }),
|
|
])
|
|
)
|
|
|
|
// Delete all groups
|
|
|
|
response = await api
|
|
.post(
|
|
"/admin/customers/test-customer-3?expand=groups",
|
|
{
|
|
groups: [],
|
|
},
|
|
{
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
}
|
|
)
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.customer.groups.length).toEqual(0)
|
|
|
|
// Adding a group to a customer with already existing groups.
|
|
|
|
response = await api
|
|
.post(
|
|
"/admin/customers/test-customer-5?expand=groups",
|
|
{
|
|
groups: [{ id: "test-group-5" }, { id: "test-group-4" }],
|
|
},
|
|
{
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
}
|
|
)
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.customer.groups.length).toEqual(2)
|
|
expect(response.data.customer.groups).toEqual(
|
|
expect.arrayContaining([
|
|
expect.objectContaining({ id: "test-group-4", name: "test-group-4" }),
|
|
expect.objectContaining({ id: "test-group-5", name: "test-group-5" }),
|
|
])
|
|
)
|
|
})
|
|
})
|
|
|
|
describe("GET /admin/customers/:id", () => {
|
|
beforeEach(async () => {
|
|
try {
|
|
await adminSeeder(dbConnection)
|
|
await customerSeeder(dbConnection)
|
|
} catch (err) {
|
|
console.log(err)
|
|
throw err
|
|
}
|
|
})
|
|
|
|
afterEach(async () => {
|
|
const db = useDb()
|
|
await db.teardown()
|
|
})
|
|
|
|
it("fetches a customer", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api
|
|
.get("/admin/customers/test-customer-1", {
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
})
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.customer).toMatchSnapshot({
|
|
id: expect.any(String),
|
|
shipping_addresses: [
|
|
{
|
|
id: "test-address",
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
},
|
|
],
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
})
|
|
})
|
|
|
|
it("fetches a customer with expand query", async () => {
|
|
const api = useApi()
|
|
|
|
const response = await api
|
|
.get("/admin/customers/test-customer-1?expand=billing_address,groups", {
|
|
headers: {
|
|
Authorization: "Bearer test_token",
|
|
},
|
|
})
|
|
.catch((err) => {
|
|
console.log(err)
|
|
})
|
|
|
|
expect(response.status).toEqual(200)
|
|
expect(response.data.customer).toMatchSnapshot({
|
|
id: "test-customer-1",
|
|
billing_address: {
|
|
id: "test-address",
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
},
|
|
groups: [],
|
|
created_at: expect.any(String),
|
|
updated_at: expect.any(String),
|
|
})
|
|
})
|
|
})
|
|
})
|