Basic tests for PollCreateDialog (#7193)
Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>pull/21833/head
							parent
							
								
									392c4ad8d9
								
							
						
					
					
						commit
						d7f3d2791a
					
				|  | @ -89,7 +89,7 @@ export default class PollCreateDialog extends ScrollableBaseModal<IProps, IState | |||
|         this.setState({ options: newOptions }, () => { | ||||
|             // Scroll the button into view after the state update to ensure we don't experience
 | ||||
|             // a pop-in effect, and to avoid the button getting cut off due to a mid-scroll render.
 | ||||
|             this.addOptionRef.current?.scrollIntoView(); | ||||
|             this.addOptionRef.current?.scrollIntoView?.(); | ||||
|         }); | ||||
|     }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,109 @@ | |||
| /* | ||||
| Copyright 2021 The Matrix.org Foundation C.I.C. | ||||
| 
 | ||||
| Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| you may not use this file except in compliance with the License. | ||||
| You may obtain a copy of the License at | ||||
| 
 | ||||
|     http://www.apache.org/licenses/LICENSE-2.0
 | ||||
| 
 | ||||
| Unless required by applicable law or agreed to in writing, software | ||||
| distributed under the License is distributed on an "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| See the License for the specific language governing permissions and | ||||
| limitations under the License. | ||||
| */ | ||||
| 
 | ||||
| // skinned-sdk should be the first import in most tests
 | ||||
| import '../../../skinned-sdk'; | ||||
| import React from "react"; | ||||
| import { mount, ReactWrapper } from "enzyme"; | ||||
| import * as TestUtils from "../../../test-utils"; | ||||
| import { MatrixClientPeg } from "../../../../src/MatrixClientPeg"; | ||||
| import { Room } from "matrix-js-sdk/src/models/room"; | ||||
| import _PollCreateDialog from "../../../../src/components/views/elements/PollCreateDialog"; | ||||
| const PollCreateDialog = TestUtils.wrapInMatrixClientContext(_PollCreateDialog); | ||||
| 
 | ||||
| // Fake date to give a predictable snapshot
 | ||||
| const realDateNow = Date.now; | ||||
| const realDateToISOString = Date.prototype.toISOString; | ||||
| Date.now = jest.fn(() => 2345678901234); | ||||
| // eslint-disable-next-line no-extend-native
 | ||||
| Date.prototype.toISOString = jest.fn(() => "2021-11-23T14:35:14.240Z"); | ||||
| afterAll(() => { | ||||
|     Date.now = realDateNow; | ||||
|     // eslint-disable-next-line no-extend-native
 | ||||
|     Date.prototype.toISOString = realDateToISOString; | ||||
| }); | ||||
| 
 | ||||
| describe("PollCreateDialog", () => { | ||||
|     it("doesn't allow submitting until there are options", () => { | ||||
|         const dialog = mount( | ||||
|             <PollCreateDialog room={createRoom()} onFinished={jest.fn()} />, | ||||
|         ); | ||||
|         expect(submitIsDisabled(dialog)).toBe(true); | ||||
|     }); | ||||
| 
 | ||||
|     it("does allow submitting when there are options and a question", () => { | ||||
|         // Given a dialog with no info in (which I am unable to submit)
 | ||||
|         const dialog = mount( | ||||
|             <PollCreateDialog room={createRoom()} onFinished={jest.fn()} />, | ||||
|         ); | ||||
|         expect(submitIsDisabled(dialog)).toBe(true); | ||||
| 
 | ||||
|         // When I set some values in the boxes
 | ||||
|         changeValue(dialog, "Question or topic", "Q"); | ||||
|         changeValue(dialog, "Option 1", "A1"); | ||||
|         changeValue(dialog, "Option 2", "A2"); | ||||
| 
 | ||||
|         // Then I am able to submit
 | ||||
|         expect(submitIsDisabled(dialog)).toBe(false); | ||||
|     }); | ||||
| 
 | ||||
|     it("renders a blank poll", () => { | ||||
|         const dialog = mount( | ||||
|             <PollCreateDialog room={createRoom()} onFinished={jest.fn()} />, | ||||
|         ); | ||||
|         expect(dialog).toMatchSnapshot(); | ||||
|     }); | ||||
| 
 | ||||
|     it("renders a question and some options", () => { | ||||
|         const dialog = mount( | ||||
|             <PollCreateDialog room={createRoom()} onFinished={jest.fn()} />, | ||||
|         ); | ||||
|         expect(submitIsDisabled(dialog)).toBe(true); | ||||
| 
 | ||||
|         // When I set some values in the boxes
 | ||||
|         changeValue( | ||||
|             dialog, | ||||
|             "Question or topic", | ||||
|             "How many turnips is the optimal number?", | ||||
|         ); | ||||
|         changeValue(dialog, "Option 1", "As many as my neighbour"); | ||||
|         changeValue(dialog, "Option 2", "The question is meaningless"); | ||||
|         dialog.find("div.mx_PollCreateDialog_addOption").simulate("click"); | ||||
|         changeValue(dialog, "Option 3", "Mu"); | ||||
|         expect(dialog).toMatchSnapshot(); | ||||
|     }); | ||||
| }); | ||||
| 
 | ||||
| function createRoom(): Room { | ||||
|     return new Room( | ||||
|         "roomid", | ||||
|         MatrixClientPeg.get(), | ||||
|         "@name:example.com", | ||||
|         {}, | ||||
|     ); | ||||
| } | ||||
| 
 | ||||
| function changeValue(wrapper: ReactWrapper, labelText: string, value: string) { | ||||
|     wrapper.find(`input[label="${labelText}"]`).simulate( | ||||
|         "change", | ||||
|         { target: { value: value } }, | ||||
|     ); | ||||
| } | ||||
| 
 | ||||
| function submitIsDisabled(wrapper: ReactWrapper) { | ||||
|     return wrapper.find('button[type="submit"]').prop("aria-disabled") === true; | ||||
| } | ||||
| 
 | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	 Andy Balaam
						Andy Balaam