-
Notifications
You must be signed in to change notification settings - Fork 481
Expand file tree
/
Copy pathMenuButtonsPermalinks.test.tsx
More file actions
119 lines (103 loc) · 3.32 KB
/
Copy pathMenuButtonsPermalinks.test.tsx
File metadata and controls
119 lines (103 loc) · 3.32 KB
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
import { Provider } from 'react-redux';
import {
render,
screen,
act,
} from 'firefox-profiler/test/fixtures/testing-library';
import { MenuButtons } from '../../components/app/MenuButtons';
import { storeWithProfile } from '../fixtures/stores';
import { stateFromLocation } from '../../app-logic/url-handling';
import { ensureExists } from '../../utils/types';
import { fireFullClick } from '../fixtures/utils';
describe('<Permalink>', function () {
function setup(
search = '',
injectedUrlShortener?: (url: string) => Promise<string>
) {
jest.useFakeTimers();
const store = storeWithProfile();
const shortUrl = 'http://example.com/fake-short-url';
const shortUrlPromise = Promise.resolve(shortUrl);
if (!injectedUrlShortener) {
injectedUrlShortener = () => shortUrlPromise;
}
store.dispatch({
type: 'UPDATE_URL_STATE',
newUrlState: stateFromLocation({
pathname: '/public/fakehash',
search,
hash: '',
}),
});
const originalState = store.getState();
const renderResult = render(
<Provider store={store}>
<MenuButtons injectedUrlShortener={injectedUrlShortener} />
</Provider>
);
const getPermalinkButton = () => screen.getByText('Permalink');
const queryInput = () => screen.queryByTestId('MenuButtonsPermalink-input');
const clickAndRunTimers = (where: HTMLElement) => {
fireFullClick(where);
act(() => {
jest.runAllTimers();
});
};
return {
...store,
...renderResult,
getPermalinkButton,
clickAndRunTimers,
shortUrl,
shortUrlPromise,
queryInput,
originalState,
};
}
it('can render the permalink button', function () {
const { getPermalinkButton, queryInput } = setup();
getPermalinkButton();
expect(queryInput()).toBeFalsy();
});
it('can click the permalink button', async function () {
const {
getPermalinkButton,
queryInput,
shortUrl,
shortUrlPromise,
clickAndRunTimers,
} = setup();
clickAndRunTimers(getPermalinkButton());
await act(() => shortUrlPromise);
const input = ensureExists(
queryInput(),
'Unable to find the permalink input text field'
);
expect(input).toHaveValue(shortUrl);
});
it('opens the permalink panel when isNewlyPublished changes to true', async function () {
const { dispatch, queryInput, shortUrl, shortUrlPromise } = setup();
// Initially the panel should not be open
expect(queryInput()).toBeFalsy();
// Simulate a profile being published/re-uploaded by dispatching PROFILE_PUBLISHED
act(() => {
dispatch({
type: 'PROFILE_PUBLISHED',
hash: 'newhash',
profileName: 'test',
prePublishedState: null,
});
});
// Wait for the async operations to complete
await act(() => shortUrlPromise);
// The input should now be visible, indicating the panel opened automatically
const input = ensureExists(
queryInput(),
'Expected the permalink panel to open automatically after publishing'
);
expect(input).toHaveValue(shortUrl);
});
});