Merge pull request #22858 from vector-im/justjanne/task/22846-remove-old-room-directory
Disable tests relying on old room directorypull/22879/head
						commit
						787d4c4135
					
				|  | @ -1,229 +0,0 @@ | |||
| /* | ||||
| Copyright 2016 OpenMarket Ltd | ||||
| 
 | ||||
| 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. | ||||
| */ | ||||
| 
 | ||||
| /* joining.js: tests for the various paths when joining a room */ | ||||
| 
 | ||||
| import PlatformPeg from 'matrix-react-sdk/src/PlatformPeg'; | ||||
| import WebPlatform from '../../src/vector/platform/WebPlatform'; | ||||
| import * as jssdk from "matrix-js-sdk/src/matrix"; | ||||
| import "../jest-mocks"; | ||||
| import React from "react"; | ||||
| import ReactDOM from "react-dom"; | ||||
| import ReactTestUtils from "react-dom/test-utils"; | ||||
| import {makeType} from "matrix-react-sdk/src/utils/TypeUtils"; | ||||
| import {sleep} from "../test-utils"; | ||||
| import MockHttpBackend from "matrix-mock-request"; | ||||
| import "fake-indexeddb/auto"; | ||||
| import { RoomView as RoomViewClass } from 'matrix-react-sdk/src/components/structures/RoomView'; | ||||
| import MatrixChat from "matrix-react-sdk/src/components/structures/MatrixChat"; | ||||
| import RoomDirectory from "matrix-react-sdk/src/components/structures/RoomDirectory"; | ||||
| import RoomPreviewBar from "matrix-react-sdk/src/components/views/rooms/RoomPreviewBar"; | ||||
| import { ValidatedServerConfig } from 'matrix-react-sdk/src/utils/ValidatedServerConfig'; | ||||
| 
 | ||||
| const HS_URL='http://localhost'; | ||||
| const IS_URL='http://localhost'; | ||||
| const USER_ID='@me:localhost'; | ||||
| const ACCESS_TOKEN='access_token'; | ||||
| 
 | ||||
| describe('joining a room', function() { | ||||
|     describe('over federation', function() { | ||||
|         let parentDiv; | ||||
|         let httpBackend; | ||||
|         let matrixChat; | ||||
| 
 | ||||
|         beforeEach(function() { | ||||
|             httpBackend = new MockHttpBackend(); | ||||
|             jssdk.request(httpBackend.requestFn); | ||||
|             parentDiv = document.createElement('div'); | ||||
| 
 | ||||
|             // uncomment this to actually add the div to the UI, to help with
 | ||||
|             // debugging (but slow things down)
 | ||||
|             // document.body.appendChild(parentDiv);
 | ||||
|         }); | ||||
| 
 | ||||
|         afterEach(function() { | ||||
|             if (parentDiv) { | ||||
|                 ReactDOM.unmountComponentAtNode(parentDiv); | ||||
|                 parentDiv.remove(); | ||||
|                 parentDiv = null; | ||||
|             } | ||||
|         }); | ||||
| 
 | ||||
|         // TODO: Re-enable test
 | ||||
|         // The test is currently disabled because the room directory now resides in a dialog,
 | ||||
|         // which is not accessible from the MatrixChat component anymore. Convincing react that
 | ||||
|         // the dialog does exist and is under a different tree is incredibly difficult though,
 | ||||
|         // so for now the test has been disabled. We should revisit this test when someone has
 | ||||
|         // the time to kill to figure this out. Problem area is highlighted within the test.
 | ||||
|         xit('should not get stuck at a spinner', function() { | ||||
|             const ROOM_ALIAS = '#alias:localhost'; | ||||
|             const ROOM_ID = '!id:localhost'; | ||||
| 
 | ||||
|             httpBackend.when('GET', '/pushrules').respond(200, {}); | ||||
|             httpBackend.when('POST', '/filter').respond(200, { filter_id: 'fid' }); | ||||
| 
 | ||||
|             // note that we deliberately do *not* set an expectation for a
 | ||||
|             // presence update - setting one makes the first httpBackend.flush
 | ||||
|             // return before the first /sync arrives.
 | ||||
| 
 | ||||
|             // start with a logged-in client
 | ||||
|             localStorage.setItem("mx_hs_url", HS_URL ); | ||||
|             localStorage.setItem("mx_is_url", IS_URL ); | ||||
|             localStorage.setItem("mx_access_token", ACCESS_TOKEN ); | ||||
|             localStorage.setItem("mx_user_id", USER_ID); | ||||
| 
 | ||||
|             PlatformPeg.set(new WebPlatform()); | ||||
| 
 | ||||
|             const config = { | ||||
|                 validated_server_config: makeType(ValidatedServerConfig, { | ||||
|                     hsUrl: HS_URL, | ||||
|                     hsName: "TEST_ENVIRONMENT", | ||||
|                     hsNameIsDifferent: false, // yes, we lie
 | ||||
|                     isUrl: IS_URL, | ||||
|                 }), | ||||
|             }; | ||||
| 
 | ||||
|             const mc = ( | ||||
|                 <MatrixChat | ||||
|                     config={config} | ||||
|                     serverConfig={config.validated_server_config} | ||||
|                     makeRegistrationUrl={()=>{throw new Error("unimplemented");}} | ||||
|                     initialScreenAfterLogin={{ | ||||
|                         screen: 'directory', | ||||
|                     }} | ||||
|                 /> | ||||
|             ); | ||||
|             matrixChat = ReactDOM.render(mc, parentDiv); | ||||
| 
 | ||||
|             let roomView; | ||||
| 
 | ||||
|             // wait for /sync to happen. This may take some time, as the client
 | ||||
|             // has to initialise indexeddb.
 | ||||
|             console.log("waiting for /sync"); | ||||
|             httpBackend.when('GET', '/sync') | ||||
|                 .respond(200, {}); | ||||
| 
 | ||||
|             return httpBackend.flushAllExpected({ | ||||
|                 timeout: 1000, | ||||
|             }).then(() => { | ||||
|                 // wait for the directory requests
 | ||||
|                 httpBackend.when('POST', '/publicRooms').respond(200, {chunk: []}); | ||||
|                 httpBackend.when('GET', '/thirdparty/protocols').respond(200, {}); | ||||
|                 return httpBackend.flushAllExpected(); | ||||
|             }).then(() => { | ||||
|                 console.log(`${Date.now()} App made requests for directory view; switching to a room.`); | ||||
| 
 | ||||
|                 // TODO: Make this look in the right spot for the directory dialog.
 | ||||
|                 // See the comment block at the top of the test for a bit more information. The short
 | ||||
|                 // story here is that the RoomDirectory does not exist under matrixChat anymore, or even
 | ||||
|                 // the parentDiv we have access to. Asking React to find the RoomDirectory as a child of
 | ||||
|                 // the document results in it complaining that you didn't give it a component tree to
 | ||||
|                 // search in. When you do get a reference to the component tree based off the document
 | ||||
|                 // root and ask it to search, it races and can't find the component in time. To top it
 | ||||
|                 // all off, MatrixReactTestUtils can't find the element in time either even with a very
 | ||||
|                 // high number of attempts. Assuming we can get a reference to the RoomDirectory in a
 | ||||
|                 // dialog, the rest of the test should be fine.
 | ||||
|                 const roomDir = ReactTestUtils.findRenderedComponentWithType( | ||||
|                     matrixChat, RoomDirectory, | ||||
|                 ); | ||||
| 
 | ||||
|                 // enter an alias in the input, and simulate enter
 | ||||
|                 const input = ReactTestUtils.findRenderedDOMComponentWithTag( | ||||
|                     roomDir, 'input') as HTMLInputElement; | ||||
|                 input.value = ROOM_ALIAS; | ||||
|                 ReactTestUtils.Simulate.change(input); | ||||
|                 ReactTestUtils.Simulate.keyUp(input, {key: 'Enter'}); | ||||
| 
 | ||||
|                 // that should create a roomview which will start a peek; wait
 | ||||
|                 // for the peek.
 | ||||
|                 httpBackend.when('GET', '/directory/room/'+encodeURIComponent(ROOM_ALIAS)).respond(200, { room_id: ROOM_ID }); | ||||
|                 httpBackend.when('GET', '/rooms/'+encodeURIComponent(ROOM_ID)+"/initialSync") | ||||
|                     .respond(401, {errcode: 'M_GUEST_ACCESS_FORBIDDEN'}); | ||||
| 
 | ||||
|                 return httpBackend.flushAllExpected(); | ||||
|             }).then(() => { | ||||
|                 console.log(`${Date.now()} App made room preview request`); | ||||
| 
 | ||||
|                 // we should now have a roomview
 | ||||
|                 roomView = ReactTestUtils.findRenderedComponentWithType( | ||||
|                     matrixChat, RoomViewClass); | ||||
| 
 | ||||
|                 // the preview bar may take a tick to be displayed
 | ||||
|                 return sleep(1); | ||||
|             }).then(() => { | ||||
|                 const previewBar = ReactTestUtils.findRenderedComponentWithType( | ||||
|                     roomView, RoomPreviewBar); | ||||
| 
 | ||||
|                 const joinLink = ReactTestUtils.findRenderedDOMComponentWithTag( | ||||
|                     previewBar, 'a'); | ||||
| 
 | ||||
|                 ReactTestUtils.Simulate.click(joinLink); | ||||
| 
 | ||||
|                 httpBackend.when('POST', '/join/'+encodeURIComponent(ROOM_ALIAS)) | ||||
|                     .respond(200, {room_id: ROOM_ID}); | ||||
|             }).then(() => { | ||||
|                 // wait for the join request to be made
 | ||||
|                 return sleep(1); | ||||
|             }).then(() => { | ||||
|                 // and again, because the state update has to go to the store and
 | ||||
|                 // then one dispatch within the store, then to the view
 | ||||
|                 // XXX: This is *super flaky*: a better way would be to declare
 | ||||
|                 // that we expect a certain state transition to happen, then wait
 | ||||
|                 // for that transition to occur.
 | ||||
|                 return sleep(1); | ||||
|             }).then(() => { | ||||
|                 // the roomview should now be loading
 | ||||
|                 expect(roomView.state.room).toBe(null); | ||||
|                 expect(roomView.state.joining).toBe(true); | ||||
| 
 | ||||
|                 // there should be a spinner
 | ||||
|                 ReactTestUtils.findRenderedDOMComponentWithClass( | ||||
|                     roomView, "mx_Spinner"); | ||||
| 
 | ||||
|                 // flush it through
 | ||||
|                 return httpBackend.flush('/join/'+encodeURIComponent(ROOM_ALIAS)); | ||||
|             }).then(() => { | ||||
|                 httpBackend.verifyNoOutstandingExpectation(); | ||||
| 
 | ||||
|                 return sleep(1); | ||||
|             }).then(() => { | ||||
|                 // NB. we don't expect the 'joining' flag to reset at any point:
 | ||||
|                 // it will stay set and we observe whether we have Room object for
 | ||||
|                 // the room and whether our member event shows we're joined.
 | ||||
| 
 | ||||
|                 // now send the room down the /sync pipe
 | ||||
|                 httpBackend.when('GET', '/sync'). | ||||
|                     respond(200, { | ||||
|                         rooms: { | ||||
|                             join: { | ||||
|                                 [ROOM_ID]: { | ||||
|                                     state: {}, | ||||
|                                     timeline: { | ||||
|                                         events: [], | ||||
|                                         limited: true, | ||||
|                                     }, | ||||
|                                 }, | ||||
|                             }, | ||||
|                         }, | ||||
|                     }); | ||||
|                 return httpBackend.flush(); | ||||
|             }).then(() => { | ||||
|                 // now the room should have loaded
 | ||||
|                 expect(roomView.state.room).toBeTruthy(); | ||||
|             }); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
		Loading…
	
		Reference in New Issue
	
	 Janne Mareike Koschinski
						Janne Mareike Koschinski