/
AddToCart.js
70 lines (60 loc) · 1.9 KB
/
AddToCart.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*/
import '@testing-library/jest-dom/extend-expect';
import {cleanup, render} from '@testing-library/react';
import React from 'react';
import AddToCart from '../../../src/main/resources/META-INF/resources/components/add_to_cart/AddToCart';
describe('AddToCart', () => {
const INITIAL_PROPS = {
channel: {
currencyCode: 'USD',
id: 12345,
},
cpInstance: {
skuId: 12345,
},
};
describe('by display settings', () => {
beforeEach(() => {
jest.resetAllMocks();
window.Liferay.Language.get = jest.fn();
});
afterEach(() => {
cleanup();
});
it('renders a Button with the appropriate settings wrapped with its quantity selector elements', () => {
const props = {
...INITIAL_PROPS,
settings: {
withQuantity: {
allowedQuantities: [],
maxQuantity: 10,
minQuantity: 1,
},
},
};
const {container} = render(<AddToCart {...props} />);
const WrapperWithQuantityContainer = container.querySelector(
'.add-to-cart-wrapper'
);
const QuantitySelectorInputElement = container.querySelector(
'input'
);
const AddToCartButtonElement = container.querySelector('button');
expect(WrapperWithQuantityContainer).toBeInTheDocument();
expect(QuantitySelectorInputElement).toBeInTheDocument();
expect(AddToCartButtonElement).toBeInTheDocument();
});
});
});