Convert enzyme to rtl: BasicMessageComposer (#9839)

This commit is contained in:
alunturner 2022-12-29 20:52:51 +00:00 committed by GitHub
parent adab82edae
commit b034ada6fd
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 131 additions and 78 deletions

View file

@ -15,8 +15,8 @@ limitations under the License.
*/
import React from "react";
// eslint-disable-next-line deprecate/import
import { mount, ReactWrapper } from "enzyme";
import { render, screen } from "@testing-library/react";
import userEvent from "@testing-library/user-event";
import { MatrixClient, Room } from "matrix-js-sdk/src/matrix";
import BasicMessageComposer from "../../../../src/components/views/rooms/BasicMessageComposer";
@ -35,30 +35,40 @@ describe("BasicMessageComposer", () => {
it("should allow a user to paste a URL without it being mangled", () => {
const model = new EditorModel([], pc, renderer);
const client: MatrixClient = MatrixClientPeg.get();
const wrapper = render(model);
const roomId = "!1234567890:domain";
const userId = client.getSafeUserId();
wrapper.find(".mx_BasicMessageComposer_input").simulate("paste", {
clipboardData: {
getData: (type) => {
if (type === "text/plain") {
return "https://element.io";
}
},
},
});
const room = new Room(roomId, client, userId);
const testUrl = "https://element.io";
const mockDataTransfer = generateMockDataTransferForString(testUrl);
render(<BasicMessageComposer model={model} room={room} />);
userEvent.paste(mockDataTransfer);
expect(model.parts).toHaveLength(1);
expect(model.parts[0].text).toBe("https://element.io");
expect(model.parts[0].text).toBe(testUrl);
expect(screen.getByText(testUrl)).toBeInTheDocument();
});
});
function render(model: EditorModel): ReactWrapper {
const client: MatrixClient = MatrixClientPeg.get();
const roomId = "!1234567890:domain";
const userId = client.getUserId();
const room = new Room(roomId, client, userId);
return mount(<BasicMessageComposer model={model} room={room} />);
function generateMockDataTransferForString(string: string): DataTransfer {
return {
getData: (type) => {
if (type === "text/plain") {
return string;
}
return "";
},
dropEffect: "link",
effectAllowed: "link",
files: {} as FileList,
items: {} as DataTransferItemList,
types: [],
clearData: () => {},
setData: () => {},
setDragImage: () => {},
};
}