diff --git a/README.md b/README.md index 4745a63..8ffbafd 100644 --- a/README.md +++ b/README.md @@ -975,6 +975,7 @@ test('should require name and description', () => { expect(setNotesCallback.mock.calls.length).toBe(0); }); ``` +- **When `...` is on a line by itself in a code example it means that I hav not provided all of the code from that file. Please be careful to copy each section that is separated by `...`'s and use them in the appropriate part of your files.** - This test checks to see if the jest [mock function](https://jestjs.io/docs/mock-functions) was called. In this test the note's name and description are blank so a new note should not be created and added to the list of notes. - We have a failing test. @@ -1757,4 +1758,69 @@ async function deleteNoteCallback( id ) { [Code for this section](https://github.com/pairing4good/tdd-amplify-react/commit/c17100754bf3a9edfebfeb8219b87766fb1cde00) + + +
+ Note List Component Testing + +## Note List Component Testing +Since we started at the top of the testing pyramid we need to make sure, once we are on green, that we work our way down to lower level tests too. + +- Add a test to `NoteList.test.js` to verify the deletion behavior of the `NoteList` component. +```js +import { render, screen, fireEvent } from '@testing-library/react'; +import NoteList from '../NoteList'; + +const deleteNoteCallback = jest.fn(); + +const defaultProps = { + notes: [], + deleteNoteCallback: deleteNoteCallback + }; + +const setup = (props = {}) => { + const setupProps = { ...defaultProps, ...props}; + return render(); +}; + +test('should display nothing when no notes are provided', () => { + setup(); +... +}); + +test('should display one note when one notes is provided', () => { + const note = {name: 'test name', description: 'test description'} + setup({notes: [note]}); +... +}); + +test('should display one note when one notes is provided', () => { + const firstNote = {name: 'test name 1', description: 'test description 1'} + const secondNote = {name: 'test name 1', description: 'test description 1'} + setup({notes: [firstNote, secondNote]}); +... +}); + +test('should delete note when clicked', () => { + const note = { + id: 1, + name: 'test name 1', + description: 'test description 1' + } + const notes = [ note ] + setup({notes: notes}); + const button = screen.getByTestId('test-button-0'); + + fireEvent.click(button) + + expect(deleteNoteCallback.mock.calls.length).toBe(1); + expect(deleteNoteCallback.mock.calls[0][0]).toStrictEqual(1); +}); +``` +- I added a mock function for the `deleteNoteCallback` and a `setup` function that has properties that can be overridden for specific test cases. This is a pattern that is often used in this style of tests. + +- Run all of the tests +- Green +- Commit +
\ No newline at end of file diff --git a/src/test/NoteList.test.js b/src/test/NoteList.test.js index f19aaf2..2614885 100644 --- a/src/test/NoteList.test.js +++ b/src/test/NoteList.test.js @@ -1,8 +1,20 @@ -import { render, screen, getByTestId } from '@testing-library/react'; +import { render, screen, fireEvent } from '@testing-library/react'; import NoteList from '../NoteList'; +const deleteNoteCallback = jest.fn(); + +const defaultProps = { + notes: [], + deleteNoteCallback: deleteNoteCallback + }; + +const setup = (props = {}) => { + const setupProps = { ...defaultProps, ...props}; + return render(); +}; + test('should display nothing when no notes are provided', () => { - render() + setup(); const firstNoteName = screen.queryByTestId('test-name-0'); expect(firstNoteName).toBeNull() @@ -10,7 +22,7 @@ test('should display nothing when no notes are provided', () => { test('should display one note when one notes is provided', () => { const note = {name: 'test name', description: 'test description'} - render() + setup({notes: [note]}); const firstNoteName = screen.queryByTestId('test-name-0'); expect(firstNoteName).toHaveTextContent("test name"); @@ -22,7 +34,7 @@ test('should display one note when one notes is provided', () => { test('should display one note when one notes is provided', () => { const firstNote = {name: 'test name 1', description: 'test description 1'} const secondNote = {name: 'test name 1', description: 'test description 1'} - render() + setup({notes: [firstNote, secondNote]}); const firstNoteName = screen.queryByTestId('test-name-0'); expect(firstNoteName).toHaveTextContent("test name"); @@ -38,6 +50,22 @@ test('should display one note when one notes is provided', () => { expect(secondNoteDescription).toHaveTextContent("test description"); }); +test('should delete note when clicked', () => { + const note = { + id: 1, + name: 'test name 1', + description: 'test description 1' + } + const notes = [ note ] + setup({notes: notes}); + const button = screen.getByTestId('test-button-0'); + + fireEvent.click(button) + + expect(deleteNoteCallback.mock.calls.length).toBe(1); + expect(deleteNoteCallback.mock.calls[0][0]).toStrictEqual(1); +}); + test('should throw an exception the note array is undefined', () => { expect(() => {render()}).toThrowError(); }); \ No newline at end of file