// 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/riot-web/issues/13111) 'im.vector.modular.widgets': 50, }, }, ); done(); }); }); });