@labdigital/commercetools-mock 2.17.1 → 2.18.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +4351 -4099
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +266 -413
- package/dist/index.d.ts +266 -413
- package/dist/index.js +4351 -4099
- package/dist/index.js.map +1 -1
- package/package.json +47 -47
- package/src/constants.ts +2 -2
- package/src/ctMock.test.ts +11 -11
- package/src/ctMock.ts +141 -127
- package/src/deprecation.ts +8 -0
- package/src/exceptions.ts +17 -15
- package/src/helpers.ts +32 -32
- package/src/index.test.ts +128 -128
- package/src/index.ts +3 -3
- package/src/lib/expandParser.ts +13 -13
- package/src/lib/haversine.test.ts +9 -9
- package/src/lib/haversine.ts +11 -11
- package/src/lib/masking.ts +11 -11
- package/src/lib/parser.ts +2 -2
- package/src/lib/password.ts +23 -3
- package/src/lib/predicateParser.test.ts +185 -183
- package/src/lib/predicateParser.ts +234 -234
- package/src/lib/projectionSearchFilter.test.ts +103 -101
- package/src/lib/projectionSearchFilter.ts +152 -150
- package/src/lib/proxy.ts +5 -5
- package/src/oauth/errors.ts +4 -4
- package/src/oauth/helpers.ts +6 -6
- package/src/oauth/server.test.ts +86 -86
- package/src/oauth/server.ts +158 -144
- package/src/oauth/store.ts +44 -43
- package/src/priceSelector.test.ts +35 -35
- package/src/priceSelector.ts +30 -30
- package/src/product-projection-search.ts +136 -134
- package/src/projectAPI.test.ts +7 -7
- package/src/projectAPI.ts +24 -22
- package/src/repositories/abstract.ts +168 -116
- package/src/repositories/associate-role.ts +90 -77
- package/src/repositories/attribute-group.ts +51 -40
- package/src/repositories/business-unit.ts +168 -148
- package/src/repositories/cart/actions.ts +489 -0
- package/src/repositories/cart/helpers.ts +30 -0
- package/src/repositories/cart/index.ts +180 -0
- package/src/repositories/cart-discount/actions.ts +148 -0
- package/src/repositories/cart-discount/index.ts +86 -0
- package/src/repositories/category/actions.ts +231 -0
- package/src/repositories/category/index.ts +52 -0
- package/src/repositories/channel.ts +88 -90
- package/src/repositories/custom-object.ts +46 -45
- package/src/repositories/customer/actions.ts +165 -0
- package/src/repositories/customer/index.ts +79 -0
- package/src/repositories/customer-group.ts +66 -55
- package/src/repositories/discount-code/actions.ts +149 -0
- package/src/repositories/discount-code/index.ts +50 -0
- package/src/repositories/errors.ts +10 -10
- package/src/repositories/extension.ts +64 -62
- package/src/repositories/helpers.ts +117 -118
- package/src/repositories/index.ts +80 -79
- package/src/repositories/inventory-entry/actions.ts +84 -0
- package/src/repositories/inventory-entry/index.ts +44 -0
- package/src/repositories/my-customer.ts +114 -0
- package/src/repositories/my-order.ts +8 -8
- package/src/repositories/order/actions.ts +281 -0
- package/src/repositories/{order.test.ts → order/index.test.ts} +77 -77
- package/src/repositories/order/index.ts +260 -0
- package/src/repositories/order-edit.ts +10 -23
- package/src/repositories/payment/actions.ts +305 -0
- package/src/repositories/payment/helpers.ts +17 -0
- package/src/repositories/payment/index.ts +56 -0
- package/src/repositories/product/actions.ts +943 -0
- package/src/repositories/product/helpers.ts +98 -0
- package/src/repositories/product/index.ts +130 -0
- package/src/repositories/product-discount.ts +127 -117
- package/src/repositories/product-projection.ts +56 -62
- package/src/repositories/product-selection.ts +31 -28
- package/src/repositories/product-type.ts +136 -134
- package/src/repositories/project.ts +133 -118
- package/src/repositories/quote-request.ts +7 -19
- package/src/repositories/quote.ts +7 -22
- package/src/repositories/review.ts +13 -26
- package/src/repositories/shipping-method/actions.ts +198 -0
- package/src/repositories/shipping-method/helpers.ts +10 -0
- package/src/repositories/shipping-method/index.ts +138 -0
- package/src/repositories/shopping-list/actions.ts +295 -0
- package/src/repositories/shopping-list/index.ts +122 -0
- package/src/repositories/staged-quote.ts +7 -20
- package/src/repositories/standalone-price.ts +57 -44
- package/src/repositories/state.ts +113 -68
- package/src/repositories/store.ts +106 -94
- package/src/repositories/subscription.ts +46 -22
- package/src/repositories/tax-category/actions.ts +94 -0
- package/src/repositories/tax-category/helpers.ts +8 -0
- package/src/repositories/tax-category/index.ts +25 -0
- package/src/repositories/type/actions.ts +162 -0
- package/src/repositories/type/index.ts +24 -0
- package/src/repositories/zone.ts +62 -58
- package/src/schemas/update-request.ts +12 -0
- package/src/server.ts +9 -9
- package/src/services/abstract.ts +85 -72
- package/src/services/associate-roles.test.ts +27 -27
- package/src/services/associate-roles.ts +7 -7
- package/src/services/attribute-group.ts +7 -7
- package/src/services/business-units.test.ts +28 -28
- package/src/services/business-units.ts +7 -7
- package/src/services/cart-discount.test.ts +199 -199
- package/src/services/cart-discount.ts +7 -7
- package/src/services/cart.test.ts +261 -261
- package/src/services/cart.ts +22 -21
- package/src/services/category.test.ts +121 -121
- package/src/services/category.ts +7 -7
- package/src/services/channel.ts +7 -7
- package/src/services/custom-object.test.ts +130 -130
- package/src/services/custom-object.ts +34 -31
- package/src/services/customer-group.ts +7 -7
- package/src/services/customer.test.ts +205 -205
- package/src/services/customer.ts +23 -36
- package/src/services/discount-code.ts +7 -7
- package/src/services/extension.ts +7 -7
- package/src/services/index.ts +85 -81
- package/src/services/inventory-entry.test.ts +106 -106
- package/src/services/inventory-entry.ts +7 -7
- package/src/services/my-cart.test.ts +56 -56
- package/src/services/my-cart.ts +20 -20
- package/src/services/my-customer.test.ts +155 -104
- package/src/services/my-customer.ts +66 -75
- package/src/services/my-order.ts +16 -16
- package/src/services/my-payment.test.ts +40 -40
- package/src/services/my-payment.ts +7 -7
- package/src/services/my-shopping-list.ts +7 -7
- package/src/services/order.test.ts +243 -243
- package/src/services/order.ts +23 -18
- package/src/services/payment.test.ts +40 -40
- package/src/services/payment.ts +7 -7
- package/src/services/product-discount.ts +7 -7
- package/src/services/product-projection.test.ts +190 -190
- package/src/services/product-projection.ts +34 -32
- package/src/services/product-selection.test.ts +19 -19
- package/src/services/product-selection.ts +7 -7
- package/src/services/product-type.test.ts +38 -38
- package/src/services/product-type.ts +7 -7
- package/src/services/product.test.ts +658 -656
- package/src/services/product.ts +7 -7
- package/src/services/project.test.ts +29 -24
- package/src/services/project.ts +22 -17
- package/src/services/reviews.ts +7 -7
- package/src/services/shipping-method.test.ts +78 -78
- package/src/services/shipping-method.ts +16 -16
- package/src/services/shopping-list.test.ts +170 -170
- package/src/services/shopping-list.ts +7 -7
- package/src/services/standalone-price.test.ts +112 -112
- package/src/services/standalone-price.ts +7 -7
- package/src/services/state.test.ts +30 -30
- package/src/services/state.ts +7 -7
- package/src/services/store.test.ts +40 -40
- package/src/services/store.ts +7 -7
- package/src/services/subscription.ts +7 -7
- package/src/services/tax-category.test.ts +43 -43
- package/src/services/tax-category.ts +7 -7
- package/src/services/type.ts +7 -7
- package/src/services/zone.ts +7 -7
- package/src/shippingCalculator.test.ts +43 -43
- package/src/shippingCalculator.ts +23 -23
- package/src/storage/abstract.ts +36 -34
- package/src/storage/in-memory.ts +237 -233
- package/src/storage/index.ts +2 -2
- package/src/types.ts +91 -91
- package/src/validate.ts +18 -0
- package/src/repositories/cart-discount.ts +0 -219
- package/src/repositories/cart.ts +0 -659
- package/src/repositories/category.ts +0 -256
- package/src/repositories/customer.ts +0 -228
- package/src/repositories/discount-code.ts +0 -181
- package/src/repositories/inventory-entry.ts +0 -109
- package/src/repositories/order.ts +0 -514
- package/src/repositories/payment.ts +0 -342
- package/src/repositories/product.ts +0 -1106
- package/src/repositories/shipping-method.ts +0 -312
- package/src/repositories/shopping-list.ts +0 -392
- package/src/repositories/tax-category.ts +0 -111
- package/src/repositories/type.ts +0 -172
package/src/services/cart.ts
CHANGED
|
@@ -1,43 +1,44 @@
|
|
|
1
|
-
import type { Cart, CartDraft, Order } from
|
|
2
|
-
import type { Request, Response, Router } from
|
|
3
|
-
import type { CartRepository } from
|
|
4
|
-
import { getRepositoryContext } from
|
|
5
|
-
import type { OrderRepository } from
|
|
6
|
-
import AbstractService from
|
|
1
|
+
import type { Cart, CartDraft, Order } from "@commercetools/platform-sdk";
|
|
2
|
+
import type { Request, Response, Router } from "express";
|
|
3
|
+
import type { CartRepository } from "../repositories/cart";
|
|
4
|
+
import { getRepositoryContext } from "../repositories/helpers";
|
|
5
|
+
import type { OrderRepository } from "../repositories/order";
|
|
6
|
+
import AbstractService from "./abstract";
|
|
7
7
|
|
|
8
8
|
export class CartService extends AbstractService {
|
|
9
|
-
public repository: CartRepository
|
|
10
|
-
|
|
9
|
+
public repository: CartRepository;
|
|
10
|
+
|
|
11
|
+
public orderRepository: OrderRepository;
|
|
11
12
|
|
|
12
13
|
constructor(
|
|
13
14
|
parent: Router,
|
|
14
15
|
cartRepository: CartRepository,
|
|
15
|
-
orderRepository: OrderRepository
|
|
16
|
+
orderRepository: OrderRepository,
|
|
16
17
|
) {
|
|
17
|
-
super(parent)
|
|
18
|
-
this.repository = cartRepository
|
|
19
|
-
this.orderRepository = orderRepository
|
|
18
|
+
super(parent);
|
|
19
|
+
this.repository = cartRepository;
|
|
20
|
+
this.orderRepository = orderRepository;
|
|
20
21
|
}
|
|
21
22
|
|
|
22
23
|
getBasePath() {
|
|
23
|
-
return
|
|
24
|
+
return "carts";
|
|
24
25
|
}
|
|
25
26
|
|
|
26
27
|
extraRoutes(parent: Router) {
|
|
27
|
-
parent.post(
|
|
28
|
+
parent.post("/replicate", this.replicate.bind(this));
|
|
28
29
|
}
|
|
29
30
|
|
|
30
31
|
replicate(request: Request, response: Response) {
|
|
31
|
-
const context = getRepositoryContext(request)
|
|
32
|
+
const context = getRepositoryContext(request);
|
|
32
33
|
|
|
33
34
|
// @ts-ignore
|
|
34
35
|
const cartOrOrder: Cart | Order | null =
|
|
35
|
-
request.body.reference.typeId ===
|
|
36
|
+
request.body.reference.typeId === "order"
|
|
36
37
|
? this.orderRepository.get(context, request.body.reference.id)
|
|
37
|
-
: this.repository.get(context, request.body.reference.id)
|
|
38
|
+
: this.repository.get(context, request.body.reference.id);
|
|
38
39
|
|
|
39
40
|
if (!cartOrOrder) {
|
|
40
|
-
return response.status(400).send()
|
|
41
|
+
return response.status(400).send();
|
|
41
42
|
}
|
|
42
43
|
|
|
43
44
|
const cartDraft: CartDraft = {
|
|
@@ -50,10 +51,10 @@ export class CartService extends AbstractService {
|
|
|
50
51
|
variantId: lineItem.variant.id,
|
|
51
52
|
sku: lineItem.variant.sku,
|
|
52
53
|
})),
|
|
53
|
-
}
|
|
54
|
+
};
|
|
54
55
|
|
|
55
|
-
const newCart = this.repository.create(context, cartDraft)
|
|
56
|
+
const newCart = this.repository.create(context, cartDraft);
|
|
56
57
|
|
|
57
|
-
return response.status(200).send(newCart)
|
|
58
|
+
return response.status(200).send(newCart);
|
|
58
59
|
}
|
|
59
60
|
}
|
|
@@ -2,179 +2,179 @@ import type {
|
|
|
2
2
|
Category,
|
|
3
3
|
CategoryAddAssetAction,
|
|
4
4
|
CategoryRemoveAssetAction,
|
|
5
|
-
} from
|
|
6
|
-
import
|
|
7
|
-
import
|
|
8
|
-
import {
|
|
9
|
-
import
|
|
5
|
+
} from "@commercetools/platform-sdk";
|
|
6
|
+
import assert from "assert";
|
|
7
|
+
import supertest from "supertest";
|
|
8
|
+
import { afterEach, beforeEach, describe, expect, test } from "vitest";
|
|
9
|
+
import { CommercetoolsMock } from "../index";
|
|
10
10
|
|
|
11
|
-
describe(
|
|
12
|
-
const ctMock = new CommercetoolsMock()
|
|
13
|
-
let category: Category | undefined
|
|
11
|
+
describe("Categories Query", () => {
|
|
12
|
+
const ctMock = new CommercetoolsMock();
|
|
13
|
+
let category: Category | undefined;
|
|
14
14
|
|
|
15
15
|
beforeEach(async () => {
|
|
16
16
|
const response = await supertest(ctMock.app)
|
|
17
|
-
.post(
|
|
17
|
+
.post("/dummy/categories")
|
|
18
18
|
.send({
|
|
19
19
|
name: {
|
|
20
|
-
en:
|
|
20
|
+
en: "Top hat",
|
|
21
21
|
},
|
|
22
22
|
slug: {
|
|
23
|
-
en:
|
|
23
|
+
en: "top-hat",
|
|
24
24
|
},
|
|
25
|
-
orderHint:
|
|
26
|
-
})
|
|
27
|
-
expect(response.status).toBe(201)
|
|
25
|
+
orderHint: "0.1",
|
|
26
|
+
});
|
|
27
|
+
expect(response.status).toBe(201);
|
|
28
28
|
|
|
29
|
-
category = response.body as Category
|
|
30
|
-
})
|
|
29
|
+
category = response.body as Category;
|
|
30
|
+
});
|
|
31
31
|
|
|
32
32
|
afterEach(() => {
|
|
33
|
-
ctMock.clear()
|
|
34
|
-
})
|
|
33
|
+
ctMock.clear();
|
|
34
|
+
});
|
|
35
35
|
|
|
36
|
-
test(
|
|
36
|
+
test("no filter", async () => {
|
|
37
37
|
const response = await supertest(ctMock.app)
|
|
38
|
-
.get(
|
|
38
|
+
.get("/dummy/categories")
|
|
39
39
|
.query({})
|
|
40
|
-
.send()
|
|
40
|
+
.send();
|
|
41
41
|
|
|
42
|
-
expect(response.status).toBe(200)
|
|
43
|
-
expect(response.body.count).toBe(1)
|
|
42
|
+
expect(response.status).toBe(200);
|
|
43
|
+
expect(response.body.count).toBe(1);
|
|
44
44
|
|
|
45
|
-
category = response.body.results[0] as Category
|
|
45
|
+
category = response.body.results[0] as Category;
|
|
46
46
|
|
|
47
|
-
expect(category.name.en).toBe(
|
|
48
|
-
})
|
|
49
|
-
})
|
|
47
|
+
expect(category.name.en).toBe("Top hat");
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
50
|
|
|
51
|
-
describe(
|
|
52
|
-
const ctMock = new CommercetoolsMock()
|
|
53
|
-
let category: Category | undefined
|
|
51
|
+
describe("categories changeName", () => {
|
|
52
|
+
const ctMock = new CommercetoolsMock();
|
|
53
|
+
let category: Category | undefined;
|
|
54
54
|
|
|
55
55
|
beforeEach(async () => {
|
|
56
56
|
const response = await supertest(ctMock.app)
|
|
57
|
-
.post(
|
|
57
|
+
.post("/dummy/categories")
|
|
58
58
|
.send({
|
|
59
59
|
name: {
|
|
60
|
-
en:
|
|
60
|
+
en: "Top hat",
|
|
61
61
|
},
|
|
62
62
|
slug: {
|
|
63
|
-
en:
|
|
63
|
+
en: "top-hat",
|
|
64
64
|
},
|
|
65
|
-
orderHint:
|
|
66
|
-
})
|
|
67
|
-
expect(response.status).toBe(201)
|
|
68
|
-
category = response.body as Category
|
|
69
|
-
})
|
|
65
|
+
orderHint: "0.1",
|
|
66
|
+
});
|
|
67
|
+
expect(response.status).toBe(201);
|
|
68
|
+
category = response.body as Category;
|
|
69
|
+
});
|
|
70
70
|
|
|
71
|
-
test(
|
|
71
|
+
test("changeName", async () => {
|
|
72
72
|
const changeNameResponse = await supertest(ctMock.app)
|
|
73
73
|
.post(`/dummy/categories/${category?.id}`)
|
|
74
74
|
.send({
|
|
75
75
|
version: 1,
|
|
76
76
|
actions: [
|
|
77
77
|
{
|
|
78
|
-
action:
|
|
78
|
+
action: "changeName",
|
|
79
79
|
name: {
|
|
80
|
-
en:
|
|
80
|
+
en: "Top hat - new name",
|
|
81
81
|
},
|
|
82
82
|
},
|
|
83
83
|
],
|
|
84
|
-
})
|
|
84
|
+
});
|
|
85
85
|
|
|
86
|
-
expect(changeNameResponse.status).toBe(200)
|
|
87
|
-
expect(changeNameResponse.body.name.en).toBe(
|
|
88
|
-
})
|
|
89
|
-
})
|
|
86
|
+
expect(changeNameResponse.status).toBe(200);
|
|
87
|
+
expect(changeNameResponse.body.name.en).toBe("Top hat - new name");
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
90
|
|
|
91
|
-
describe(
|
|
92
|
-
const ctMock = new CommercetoolsMock()
|
|
93
|
-
let category1: Category | undefined
|
|
94
|
-
let category2: Category | undefined
|
|
91
|
+
describe("categories changeParent", () => {
|
|
92
|
+
const ctMock = new CommercetoolsMock();
|
|
93
|
+
let category1: Category | undefined;
|
|
94
|
+
let category2: Category | undefined;
|
|
95
95
|
|
|
96
96
|
beforeEach(async () => {
|
|
97
97
|
const response1 = await supertest(ctMock.app)
|
|
98
|
-
.post(
|
|
98
|
+
.post("/dummy/categories")
|
|
99
99
|
.send({
|
|
100
100
|
name: {
|
|
101
|
-
en:
|
|
101
|
+
en: "Top hat",
|
|
102
102
|
},
|
|
103
103
|
slug: {
|
|
104
|
-
en:
|
|
104
|
+
en: "top-hat",
|
|
105
105
|
},
|
|
106
|
-
orderHint:
|
|
107
|
-
})
|
|
108
|
-
expect(response1.status).toBe(201)
|
|
109
|
-
category1 = response1.body as Category
|
|
106
|
+
orderHint: "0.1",
|
|
107
|
+
});
|
|
108
|
+
expect(response1.status).toBe(201);
|
|
109
|
+
category1 = response1.body as Category;
|
|
110
110
|
|
|
111
111
|
const response2 = await supertest(ctMock.app)
|
|
112
|
-
.post(
|
|
112
|
+
.post("/dummy/categories")
|
|
113
113
|
.send({
|
|
114
114
|
name: {
|
|
115
|
-
en:
|
|
115
|
+
en: "Top hat",
|
|
116
116
|
},
|
|
117
117
|
slug: {
|
|
118
|
-
en:
|
|
118
|
+
en: "top-hat",
|
|
119
119
|
},
|
|
120
|
-
orderHint:
|
|
121
|
-
})
|
|
122
|
-
expect(response2.status).toBe(201)
|
|
123
|
-
category2 = response2.body as Category
|
|
124
|
-
})
|
|
120
|
+
orderHint: "0.1",
|
|
121
|
+
});
|
|
122
|
+
expect(response2.status).toBe(201);
|
|
123
|
+
category2 = response2.body as Category;
|
|
124
|
+
});
|
|
125
125
|
|
|
126
|
-
test(
|
|
126
|
+
test("changeParent", async () => {
|
|
127
127
|
const changeNameResponse = await supertest(ctMock.app)
|
|
128
128
|
.post(`/dummy/categories/${category2?.id}`)
|
|
129
129
|
.send({
|
|
130
130
|
version: 1,
|
|
131
131
|
actions: [
|
|
132
132
|
{
|
|
133
|
-
action:
|
|
133
|
+
action: "changeParent",
|
|
134
134
|
parent: {
|
|
135
|
-
typeId:
|
|
135
|
+
typeId: "category",
|
|
136
136
|
id: category1?.id,
|
|
137
137
|
},
|
|
138
138
|
},
|
|
139
139
|
],
|
|
140
|
-
})
|
|
140
|
+
});
|
|
141
141
|
|
|
142
|
-
expect(changeNameResponse.status).toBe(200)
|
|
142
|
+
expect(changeNameResponse.status).toBe(200);
|
|
143
143
|
expect(changeNameResponse.body.parent).toEqual({
|
|
144
|
-
typeId:
|
|
144
|
+
typeId: "category",
|
|
145
145
|
id: category1?.id,
|
|
146
|
-
})
|
|
147
|
-
})
|
|
148
|
-
})
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
149
|
|
|
150
|
-
describe(
|
|
151
|
-
const ctMock = new CommercetoolsMock()
|
|
152
|
-
let category: Category | undefined
|
|
150
|
+
describe("Categories add asset", () => {
|
|
151
|
+
const ctMock = new CommercetoolsMock();
|
|
152
|
+
let category: Category | undefined;
|
|
153
153
|
|
|
154
154
|
beforeEach(async () => {
|
|
155
155
|
const response = await supertest(ctMock.app)
|
|
156
|
-
.post(
|
|
156
|
+
.post("/dummy/categories")
|
|
157
157
|
.send({
|
|
158
158
|
name: {
|
|
159
|
-
en:
|
|
159
|
+
en: "Top hat",
|
|
160
160
|
},
|
|
161
161
|
slug: {
|
|
162
|
-
en:
|
|
162
|
+
en: "top-hat",
|
|
163
163
|
},
|
|
164
|
-
orderHint:
|
|
164
|
+
orderHint: "0.1",
|
|
165
165
|
assets: [
|
|
166
166
|
{
|
|
167
|
-
key:
|
|
167
|
+
key: "some-key",
|
|
168
168
|
},
|
|
169
169
|
],
|
|
170
|
-
})
|
|
171
|
-
expect(response.status).toBe(201)
|
|
170
|
+
});
|
|
171
|
+
expect(response.status).toBe(201);
|
|
172
172
|
|
|
173
|
-
category = response.body as Category
|
|
174
|
-
})
|
|
173
|
+
category = response.body as Category;
|
|
174
|
+
});
|
|
175
175
|
|
|
176
|
-
test(
|
|
177
|
-
assert(category,
|
|
176
|
+
test("add second asset", async () => {
|
|
177
|
+
assert(category, "category not created");
|
|
178
178
|
|
|
179
179
|
const response = await supertest(ctMock.app)
|
|
180
180
|
.post(`/dummy/categories/${category.id}`)
|
|
@@ -182,52 +182,52 @@ describe('Categories add asset', () => {
|
|
|
182
182
|
version: 1,
|
|
183
183
|
actions: [
|
|
184
184
|
{
|
|
185
|
-
action:
|
|
185
|
+
action: "addAsset",
|
|
186
186
|
asset: {
|
|
187
|
-
key:
|
|
187
|
+
key: "some-other-key",
|
|
188
188
|
},
|
|
189
189
|
} as CategoryAddAssetAction,
|
|
190
190
|
],
|
|
191
|
-
})
|
|
191
|
+
});
|
|
192
192
|
|
|
193
|
-
expect(response.status).toBe(200)
|
|
194
|
-
expect(response.body.assets).toHaveLength(2)
|
|
195
|
-
expect(response.body.assets[0].key).toEqual(
|
|
196
|
-
expect(response.body.assets[1].key).toEqual(
|
|
197
|
-
})
|
|
198
|
-
})
|
|
193
|
+
expect(response.status).toBe(200);
|
|
194
|
+
expect(response.body.assets).toHaveLength(2);
|
|
195
|
+
expect(response.body.assets[0].key).toEqual("some-key");
|
|
196
|
+
expect(response.body.assets[1].key).toEqual("some-other-key");
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
199
|
|
|
200
|
-
describe(
|
|
201
|
-
const ctMock = new CommercetoolsMock()
|
|
202
|
-
let category: Category | undefined
|
|
200
|
+
describe("Categories remove asset", () => {
|
|
201
|
+
const ctMock = new CommercetoolsMock();
|
|
202
|
+
let category: Category | undefined;
|
|
203
203
|
|
|
204
204
|
beforeEach(async () => {
|
|
205
205
|
const response = await supertest(ctMock.app)
|
|
206
|
-
.post(
|
|
206
|
+
.post("/dummy/categories")
|
|
207
207
|
.send({
|
|
208
208
|
name: {
|
|
209
|
-
en:
|
|
209
|
+
en: "Top hat",
|
|
210
210
|
},
|
|
211
211
|
slug: {
|
|
212
|
-
en:
|
|
212
|
+
en: "top-hat",
|
|
213
213
|
},
|
|
214
|
-
orderHint:
|
|
214
|
+
orderHint: "0.1",
|
|
215
215
|
assets: [
|
|
216
216
|
{
|
|
217
|
-
key:
|
|
217
|
+
key: "some-key",
|
|
218
218
|
},
|
|
219
219
|
{
|
|
220
|
-
key:
|
|
220
|
+
key: "some-other-key",
|
|
221
221
|
},
|
|
222
222
|
],
|
|
223
|
-
})
|
|
224
|
-
expect(response.status).toBe(201)
|
|
223
|
+
});
|
|
224
|
+
expect(response.status).toBe(201);
|
|
225
225
|
|
|
226
|
-
category = response.body as Category
|
|
227
|
-
})
|
|
226
|
+
category = response.body as Category;
|
|
227
|
+
});
|
|
228
228
|
|
|
229
|
-
test(
|
|
230
|
-
assert(category,
|
|
229
|
+
test("remove assets by id and key", async () => {
|
|
230
|
+
assert(category, "category not created");
|
|
231
231
|
|
|
232
232
|
const response = await supertest(ctMock.app)
|
|
233
233
|
.post(`/dummy/categories/${category.id}`)
|
|
@@ -235,17 +235,17 @@ describe('Categories remove asset', () => {
|
|
|
235
235
|
version: 1,
|
|
236
236
|
actions: [
|
|
237
237
|
{
|
|
238
|
-
action:
|
|
239
|
-
assetKey: category.assets[1].key,
|
|
238
|
+
action: "removeAsset",
|
|
239
|
+
assetKey: category.assets?.[1].key,
|
|
240
240
|
} as CategoryRemoveAssetAction,
|
|
241
241
|
{
|
|
242
|
-
action:
|
|
243
|
-
assetId: category.assets[0].id,
|
|
242
|
+
action: "removeAsset",
|
|
243
|
+
assetId: category.assets?.[0].id,
|
|
244
244
|
} as CategoryRemoveAssetAction,
|
|
245
245
|
],
|
|
246
|
-
})
|
|
246
|
+
});
|
|
247
247
|
|
|
248
|
-
expect(response.status).toBe(200)
|
|
249
|
-
expect(response.body.assets).toHaveLength(0)
|
|
250
|
-
})
|
|
251
|
-
})
|
|
248
|
+
expect(response.status).toBe(200);
|
|
249
|
+
expect(response.body.assets).toHaveLength(0);
|
|
250
|
+
});
|
|
251
|
+
});
|
package/src/services/category.ts
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { Router } from
|
|
2
|
-
import { CategoryRepository } from
|
|
3
|
-
import AbstractService from
|
|
1
|
+
import { Router } from "express";
|
|
2
|
+
import { CategoryRepository } from "../repositories/category/index";
|
|
3
|
+
import AbstractService from "./abstract";
|
|
4
4
|
|
|
5
5
|
export class CategoryServices extends AbstractService {
|
|
6
|
-
public repository: CategoryRepository
|
|
6
|
+
public repository: CategoryRepository;
|
|
7
7
|
|
|
8
8
|
constructor(parent: Router, repository: CategoryRepository) {
|
|
9
|
-
super(parent)
|
|
10
|
-
this.repository = repository
|
|
9
|
+
super(parent);
|
|
10
|
+
this.repository = repository;
|
|
11
11
|
}
|
|
12
12
|
|
|
13
13
|
getBasePath() {
|
|
14
|
-
return
|
|
14
|
+
return "categories";
|
|
15
15
|
}
|
|
16
16
|
}
|
package/src/services/channel.ts
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { Router } from
|
|
2
|
-
import { ChannelRepository } from
|
|
3
|
-
import AbstractService from
|
|
1
|
+
import { Router } from "express";
|
|
2
|
+
import { ChannelRepository } from "../repositories/channel";
|
|
3
|
+
import AbstractService from "./abstract";
|
|
4
4
|
|
|
5
5
|
export class ChannelService extends AbstractService {
|
|
6
|
-
public repository: ChannelRepository
|
|
6
|
+
public repository: ChannelRepository;
|
|
7
7
|
|
|
8
8
|
constructor(parent: Router, repository: ChannelRepository) {
|
|
9
|
-
super(parent)
|
|
10
|
-
this.repository = repository
|
|
9
|
+
super(parent);
|
|
10
|
+
this.repository = repository;
|
|
11
11
|
}
|
|
12
12
|
|
|
13
13
|
getBasePath() {
|
|
14
|
-
return
|
|
14
|
+
return "channels";
|
|
15
15
|
}
|
|
16
16
|
}
|