2021-03-18 09:52:36 +00:00
|
|
|
import { expect } from 'chai'
|
2022-01-10 15:46:46 +00:00
|
|
|
import { screen, waitFor, cleanup } from '@testing-library/react'
|
2021-03-18 09:52:36 +00:00
|
|
|
import sinon from 'sinon'
|
|
|
|
|
2022-01-10 15:46:46 +00:00
|
|
|
import renderWithContext from '../../helpers/render-with-context'
|
2021-03-18 09:52:36 +00:00
|
|
|
|
|
|
|
import FileTreeCreateNameInput from '../../../../../../frontend/js/features/file-tree/components/file-tree-create/file-tree-create-name-input'
|
|
|
|
import FileTreeCreateNameProvider from '../../../../../../frontend/js/features/file-tree/contexts/file-tree-create-name'
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
describe('<FileTreeCreateNameInput/>', function () {
|
2021-03-18 09:52:36 +00:00
|
|
|
const sandbox = sinon.createSandbox()
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
beforeEach(function () {
|
2021-03-18 09:52:36 +00:00
|
|
|
sandbox.spy(window, 'requestAnimationFrame')
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
afterEach(function () {
|
2021-03-18 09:52:36 +00:00
|
|
|
sandbox.restore()
|
|
|
|
cleanup()
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('renders an empty input', async function () {
|
2022-01-10 15:46:46 +00:00
|
|
|
renderWithContext(
|
|
|
|
<FileTreeCreateNameProvider>
|
|
|
|
<FileTreeCreateNameInput />
|
|
|
|
</FileTreeCreateNameProvider>
|
2021-03-18 09:52:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
await screen.getByLabelText('File Name')
|
|
|
|
await screen.getByPlaceholderText('File Name')
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('renders a custom label and placeholder', async function () {
|
2022-01-10 15:46:46 +00:00
|
|
|
renderWithContext(
|
|
|
|
<FileTreeCreateNameProvider>
|
|
|
|
<FileTreeCreateNameInput
|
|
|
|
label="File name in this project"
|
|
|
|
placeholder="Enter a file name…"
|
|
|
|
/>
|
|
|
|
</FileTreeCreateNameProvider>
|
2021-03-18 09:52:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
await screen.getByLabelText('File name in this project')
|
|
|
|
await screen.getByPlaceholderText('Enter a file name…')
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('uses an initial name', async function () {
|
2022-01-10 15:46:46 +00:00
|
|
|
renderWithContext(
|
|
|
|
<FileTreeCreateNameProvider initialName="test.tex">
|
|
|
|
<FileTreeCreateNameInput />
|
|
|
|
</FileTreeCreateNameProvider>
|
2021-03-18 09:52:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const input = await screen.getByLabelText('File Name')
|
|
|
|
expect(input.value).to.equal('test.tex')
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('focuses the name', async function () {
|
2022-01-10 15:46:46 +00:00
|
|
|
renderWithContext(
|
|
|
|
<FileTreeCreateNameProvider initialName="test.tex">
|
|
|
|
<FileTreeCreateNameInput focusName />
|
|
|
|
</FileTreeCreateNameProvider>
|
2021-03-18 09:52:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const input = await screen.getByLabelText('File Name')
|
|
|
|
expect(input.value).to.equal('test.tex')
|
|
|
|
|
|
|
|
await waitFor(
|
|
|
|
() => expect(window.requestAnimationFrame).to.have.been.calledOnce
|
|
|
|
)
|
|
|
|
|
|
|
|
// https://github.com/jsdom/jsdom/issues/2995
|
|
|
|
// "window.getSelection doesn't work with selection of <input> element"
|
|
|
|
// const selection = window.getSelection().toString()
|
|
|
|
// expect(selection).to.equal('test')
|
|
|
|
|
|
|
|
// wait for the selection to update
|
|
|
|
await new Promise(resolve => window.setTimeout(resolve, 100))
|
|
|
|
|
|
|
|
expect(input.selectionStart).to.equal(0)
|
|
|
|
expect(input.selectionEnd).to.equal(4)
|
|
|
|
})
|
|
|
|
})
|