diff --git a/test/components/views/rooms/RoomSettings-test.js b/test/components/views/rooms/RoomSettings-test.js deleted file mode 100644 index f05262d102..0000000000 --- a/test/components/views/rooms/RoomSettings-test.js +++ /dev/null @@ -1,188 +0,0 @@ -// TODO: Rewrite room settings tests for dialog support -import React from 'react'; -import ReactDOM from 'react-dom'; - -import * as testUtils from '../../../test-utils'; -import sdk from '../../../skinned-sdk'; -import { MatrixClientPeg } from '../../../../src/MatrixClientPeg'; -import SettingsStore from '../../../../src/settings/SettingsStore'; - -describe.skip('RoomSettings', () => { - const WrappedRoomSettings = testUtils.wrapInMatrixClientContext(sdk.getComponent('views.rooms.RoomSettings')); - - let parentDiv = null; - let client = null; - let roomSettings = null; - const room = testUtils.mkStubRoom('!DdJkzRliezrwpNebLk:matrix.org'); - - function expectSentStateEvent(roomId, eventType, expectedEventContent) { - let found = false; - for (const call of client.sendStateEvent.mock.calls) { - const [ - actualRoomId, - actualEventType, - actualEventContent, - ] = call.slice(0, 3); - - if (roomId === actualRoomId && actualEventType === eventType) { - expect(actualEventContent).toEqual(expectedEventContent); - found = true; - break; - } - } - expect(found).toBe(true); - } - - beforeEach(function(done) { - testUtils.stubClient(); - client = MatrixClientPeg.get(); - client.credentials = { userId: '@me:domain.com' }; - - client.setRoomName = jest.fn().mockReturnValue(Promise.resolve()); - client.setRoomTopic = jest.fn().mockReturnValue(Promise.resolve()); - client.setRoomDirectoryVisibility = jest.fn().mockReturnValue(Promise.resolve()); - - // Covers any room state event (e.g. name, avatar, topic) - client.sendStateEvent = jest.fn().mockReturnValue(Promise.resolve()); - - // Covers room tagging - client.setRoomTag = jest.fn().mockReturnValue(Promise.resolve()); - client.deleteRoomTag = jest.fn().mockReturnValue(Promise.resolve()); - - // Covers any setting in the SettingsStore - // (including local client settings not stored via matrix) - SettingsStore.setValue = jest.fn().mockReturnValue(Promise.resolve()); - - parentDiv = document.createElement('div'); - document.body.appendChild(parentDiv); - - const gatherWrappedRef = (r) => {roomSettings = r;}; - - // get use wrappedRef because we're using wrapInMatrixClientContext - ReactDOM.render( - , - parentDiv, - done, - ); - }); - - afterEach((done) => { - if (parentDiv) { - ReactDOM.unmountComponentAtNode(parentDiv); - parentDiv.remove(); - parentDiv = null; - } - done(); - }); - - it('should not set when no setting is changed', (done) => { - roomSettings.save().then(() => { - expect(client.sendStateEvent).not.toHaveBeenCalled(); - expect(client.setRoomTag).not.toHaveBeenCalled(); - expect(client.deleteRoomTag).not.toHaveBeenCalled(); - done(); - }); - }); - - // XXX: Apparently we do call SettingsStore.setValue - xit('should not settings via the SettingsStore when no setting is changed', (done) => { - roomSettings.save().then(() => { - expect(SettingsStore.setValue).not.toHaveBeenCalled(); - done(); - }); - }); - - it('should set room name when it has changed', (done) => { - const name = "My Room Name"; - roomSettings.setName(name); - - roomSettings.save().then(() => { - expect(client.setRoomName.mock.calls[0].slice(0, 2)) - .toEqual(['!DdJkzRliezrwpNebLk:matrix.org', name]); - - done(); - }); - }); - - it('should set room topic when it has changed', (done) => { - const topic = "this is a topic"; - roomSettings.setTopic(topic); - - roomSettings.save().then(() => { - expect(client.setRoomTopic.mock.calls[0].slice(0, 2)) - .toEqual(['!DdJkzRliezrwpNebLk:matrix.org', topic]); - - done(); - }); - }); - - it('should set history visibility when it has changed', (done) => { - const historyVisibility = "translucent"; - roomSettings.setState({ - history_visibility: historyVisibility, - }); - - roomSettings.save().then(() => { - expectSentStateEvent( - "!DdJkzRliezrwpNebLk:matrix.org", - "m.room.history_visibility", { history_visibility: historyVisibility }, - ); - done(); - }); - }); - - // XXX: Can't test this because we `getRoomDirectoryVisibility` in `componentDidMount` - xit('should set room directory publicity when set to true', (done) => { - const isRoomPublished = true; - roomSettings.setState({ - isRoomPublished, - }, () => { - roomSettings.save().then(() => { - expect(client.setRoomDirectoryVisibility.calls[0].arguments.slice(0, 2)) - .toEqual("!DdJkzRliezrwpNebLk:matrix.org", isRoomPublished ? "public" : "private"); - done(); - }); - }); - }); - - it('should set power levels when changed', (done) => { - roomSettings.onPowerLevelsChanged(42, "invite"); - - roomSettings.save().then(() => { - expectSentStateEvent( - "!DdJkzRliezrwpNebLk:matrix.org", - "m.room.power_levels", { invite: 42 }, - ); - done(); - }); - }); - - it('should set event power levels when changed', (done) => { - roomSettings.onPowerLevelsChanged(42, "event_levels_m.room.message"); - - roomSettings.save().then(() => { - // We expect all state events to be set to the state_default (50) - // See powerLevelDescriptors in RoomSettings - expectSentStateEvent( - "!DdJkzRliezrwpNebLk:matrix.org", - "m.room.power_levels", { - events: { - 'm.room.message': 42, - 'm.room.avatar': 50, - 'm.room.name': 50, - 'm.room.canonical_alias': 50, - 'm.room.history_visibility': 50, - 'm.room.power_levels': 50, - 'm.room.topic': 50, - // TODO: Enable support for m.widget event type (https://github.com/vector-im/element-web/issues/13111) - 'im.vector.modular.widgets': 50, - }, - }, - ); - done(); - }); - }); -});