Merge pull request #572 from medusajs/fix/tests

fix: failing integration tests
This commit is contained in:
Sebastian Rindom
2021-10-15 19:54:39 +02:00
committed by GitHub
5 changed files with 76 additions and 12 deletions

View File

@@ -19,12 +19,12 @@ Object {
"mid_code": null,
"options": Array [
Object {
"created_at": "2021-10-13T08:02:41.668Z",
"created_at": Any<String>,
"deleted_at": null,
"id": "test-variant-option",
"metadata": null,
"option_id": "test-option",
"updated_at": "2021-10-13T08:02:41.668Z",
"updated_at": Any<String>,
"value": "Default variant",
"variant_id": "test-variant",
},
@@ -75,12 +75,12 @@ Object {
"mid_code": null,
"options": Array [
Object {
"created_at": "2021-10-13T08:02:41.493Z",
"created_at": Any<String>,
"deleted_at": null,
"id": "test-variant-option",
"metadata": null,
"option_id": "test-option",
"updated_at": "2021-10-13T08:02:41.493Z",
"updated_at": Any<String>,
"value": "Default variant",
"variant_id": "test-variant",
},

View File

@@ -221,5 +221,47 @@ describe("/store/customers", () => {
})
)
})
it("unsets customer billing address", async () => {
const api = useApi()
const authResponse = await api.post("/store/auth", {
email: "john@deere.com",
password: "test",
})
const customerId = authResponse.data.customer.id
const [authCookie] = authResponse.headers["set-cookie"][0].split(";")
const check = await api.post(
`/store/customers/me`,
{
billing_address: "addr_test",
},
{
headers: {
Cookie: authCookie,
},
}
)
expect(check.status).toEqual(200)
expect(check.data.customer.billing_address_id).toEqual("addr_test")
const response = await api.post(
`/store/customers/me`,
{
billing_address: null,
},
{
headers: {
Cookie: authCookie,
},
}
)
expect(response.status).toEqual(200)
expect(response.data.customer.billing_address_id).toEqual(null)
})
})
})

View File

@@ -65,6 +65,12 @@ describe("/store/variants", () => {
updated_at: expect.any(String),
weight: null,
width: null,
options: [
{
created_at: expect.any(String),
updated_at: expect.any(String),
},
],
prices: [
{
created_at: expect.any(String),
@@ -113,6 +119,12 @@ describe("/store/variants", () => {
updated_at: expect.any(String),
weight: null,
width: null,
options: [
{
created_at: expect.any(String),
updated_at: expect.any(String),
},
],
prices: [
{
created_at: expect.any(String),

View File

@@ -50,7 +50,7 @@ export default async (req, res) => {
const id = req.user.customer_id
const schema = Validator.object().keys({
billing_address: Validator.address().optional(),
billing_address: Validator.address().optional().allow(null),
first_name: Validator.string().optional(),
last_name: Validator.string().optional(),
password: Validator.string().optional(),
@@ -66,9 +66,9 @@ export default async (req, res) => {
try {
const customerService = req.scope.resolve("customerService")
let customer = await customerService.update(id, value)
await customerService.update(id, value)
customer = await customerService.retrieve(customer.id, {
const customer = await customerService.retrieve(id, {
relations: defaultRelations,
select: defaultFields,
})

View File

@@ -224,7 +224,6 @@ class CustomerService extends BaseService {
const query = this.buildQuery_({ id: validatedId }, config)
const customer = await customerRepo.findOne(query)
if (!customer) {
throw new MedusaError(
MedusaError.Types.NOT_FOUND,
@@ -286,7 +285,7 @@ class CustomerService extends BaseService {
/**
* Hashes a password
* @param {string} password - the value to hash
* @return {string} hashed password
* @return {Promise<string>} hashed password
*/
async hashPassword_(password) {
const buf = await Scrypt.kdf(password, { logN: 1, r: 1, p: 1 })
@@ -371,7 +370,14 @@ class CustomerService extends BaseService {
const customer = await this.retrieve(customerId)
const { email, password, metadata, ...rest } = update
const {
email,
password,
metadata,
billing_address,
billing_address_id,
...rest
} = update
if (metadata) {
customer.metadata = this.setMetadata_(customer, metadata)
@@ -382,7 +388,7 @@ class CustomerService extends BaseService {
}
if ("billing_address_id" in update || "billing_address" in update) {
const address = update.billing_address_id || update.billing_address
const address = billing_address_id || billing_address
await this.updateBillingAddress_(customer, address, addrRepo)
}
@@ -411,6 +417,11 @@ class CustomerService extends BaseService {
* @return {Promise} the result of the update operation
*/
async updateBillingAddress_(customer, addressOrId, addrRepo) {
if (addressOrId === null) {
customer.billing_address_id = null
return
}
if (typeof addressOrId === `string`) {
addressOrId = await addrRepo.findOne({
where: { id: addressOrId },
@@ -421,7 +432,6 @@ class CustomerService extends BaseService {
if (addressOrId.id) {
customer.billing_address_id = addressOrId.id
customer.billing_address = addressOrId
} else {
if (customer.billing_address_id) {
const addr = await addrRepo.findOne({