diff --git a/test/getLabel.test.tsx b/test/getLabel.test.tsx new file mode 100644 index 0000000..1a49dee --- /dev/null +++ b/test/getLabel.test.tsx @@ -0,0 +1,86 @@ +import { cleanup, render, fireEvent } from '@testing-library/react'; +import { ReactMultiEmail } from '../react-multi-email'; +import React from 'react'; + +afterEach(cleanup); + +describe('ReactMultEmail getLabel TEST', () => { + it('getLabel is called on entering new valid email', async () => { + const getLabel = jest.fn(); + + const { getByRole } = render(); + const input = getByRole('textbox'); + + fireEvent.change(input, { target: { value: 'test@example.com' } }); + fireEvent.keyUp(input, { key: 'Enter', code: 'Enter' }); + + expect(getLabel).toHaveBeenCalledTimes(1); + }); + it('the elements returned by getLabel have the right index and email', async () => { + const { getByRole } = render( + { + return ( +
+
+ {email} +
+ removeEmail(index)}>× +
+ ); + }} + />, + ); + const input = getByRole('textbox'); + + fireEvent.change(input, { target: { value: 'test1@example.com' } }); + fireEvent.keyUp(input, { key: 'Enter', code: 'Enter' }); + fireEvent.change(input, { target: { value: 'test2@example.com' } }); + fireEvent.keyUp(input, { key: 'Enter', code: 'Enter' }); + + const indexElement0: HTMLDivElement | null = document.querySelector('#index0'); + const indexElement1: HTMLDivElement | null = document.querySelector('#index1'); + const emailElement0: HTMLDivElement | null = document.querySelector('#email0'); + const emailElement1: HTMLDivElement | null = document.querySelector('#email1'); + expect(indexElement0?.dataset.index).toEqual('0'); + expect(indexElement1?.dataset.index).toEqual('1'); + expect(emailElement0?.dataset.email).toEqual('test1@example.com'); + expect(emailElement1?.dataset.email).toEqual('test2@example.com'); + }); + it('removeEmail is called on clicking element', async () => { + const { getByRole } = render( + { + return ( +
+
{email}
+ removeEmail(index)}> + × + +
+ ); + }} + />, + ); + const input = getByRole('textbox'); + + fireEvent.change(input, { target: { value: 'test1@example.com' } }); + fireEvent.keyUp(input, { key: 'Enter', code: 'Enter' }); + fireEvent.change(input, { target: { value: 'test2@example.com' } }); + fireEvent.keyUp(input, { key: 'Enter', code: 'Enter' }); + fireEvent.change(input, { target: { value: 'test3@example.com' } }); + fireEvent.keyUp(input, { key: 'Enter', code: 'Enter' }); + + const removeEmail0: HTMLSpanElement | null = document.querySelector('#removeEmail0'); + if (removeEmail0) { + fireEvent.click(removeEmail0); + } + expect(document.querySelectorAll('.data-label')?.length).toEqual(2); + + const removeEmail1: HTMLSpanElement | null = document.querySelector('#removeEmail0'); + if (removeEmail1) { + fireEvent.click(removeEmail1); + } + expect(document.querySelectorAll('.data-label')?.length).toEqual(1); + }); +});