Skip to content

Commit f8061b6

Browse files
author
Luke Bowerman
authored
test(Breakpoint): Add basic coverage (#1902)
1 parent 8cfba89 commit f8061b6

File tree

1 file changed

+80
-0
lines changed

1 file changed

+80
-0
lines changed
Lines changed: 80 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,80 @@
1+
/*
2+
3+
MIT License
4+
5+
Copyright (c) 2020 Looker Data Sciences, Inc.
6+
7+
Permission is hereby granted, free of charge, to any person obtaining a copy
8+
of this software and associated documentation files (the "Software"), to deal
9+
in the Software without restriction, including without limitation the rights
10+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11+
copies of the Software, and to permit persons to whom the Software is
12+
furnished to do so, subject to the following conditions:
13+
14+
The above copyright notice and this permission notice shall be included in all
15+
copies or substantial portions of the Software.
16+
17+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23+
SOFTWARE.
24+
25+
*/
26+
27+
import React from 'react'
28+
import { renderWithTheme } from '@looker/components-test-utils'
29+
import { screen } from '@testing-library/react'
30+
import { Breakpoint } from './Breakpoint'
31+
32+
/**
33+
* IMPORTANT NOTE:
34+
* Breakpoint behavior is determined by viewport size (by design, really, that's a good thing).
35+
*
36+
* Within our test-suite the viewport size is configured in `jest.setup.js`.
37+
* Specifically: document.body.clientHeight & document.body.width
38+
*/
39+
40+
describe('Breakpoint', () => {
41+
test('all', () => {
42+
renderWithTheme(
43+
<Breakpoint show={['mobile', 'xl']}>
44+
<p>This is a thing</p>
45+
</Breakpoint>
46+
)
47+
const element = screen.queryByText('This is a thing')
48+
expect(element).toBeInTheDocument()
49+
})
50+
51+
test('mobile', () => {
52+
renderWithTheme(
53+
<Breakpoint show="mobile">
54+
<p>This is a thing</p>
55+
</Breakpoint>
56+
)
57+
const element = screen.queryByText('This is a thing')
58+
expect(element).not.toBeInTheDocument()
59+
})
60+
61+
test('tablet up', () => {
62+
renderWithTheme(
63+
<Breakpoint show={['tablet', undefined]}>
64+
<p>This is a thing</p>
65+
</Breakpoint>
66+
)
67+
const element = screen.queryByText('This is a thing')
68+
expect(element).toBeInTheDocument()
69+
})
70+
71+
test('up to tablet', () => {
72+
renderWithTheme(
73+
<Breakpoint show={[undefined, 'tablet']}>
74+
<p>This is a thing</p>
75+
</Breakpoint>
76+
)
77+
const element = screen.queryByText('This is a thing')
78+
expect(element).not.toBeInTheDocument()
79+
})
80+
})

0 commit comments

Comments
 (0)