mirror of https://github.com/vector-im/riot-web
				
				
				
			
		
			
				
	
	
		
			103 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
| /*
 | |
| Copyright 2019 New Vector 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.
 | |
| */
 | |
| 
 | |
| import React from 'react';
 | |
| import ReactDOM from 'react-dom';
 | |
| import ReactTestUtils from 'react-dom/test-utils';
 | |
| import sdk from '../../../skinned-sdk';
 | |
| import SdkConfig from '../../../../src/SdkConfig';
 | |
| import {mkServerConfig} from "../../../test-utils";
 | |
| 
 | |
| const Registration = sdk.getComponent(
 | |
|     'structures.auth.Registration',
 | |
| );
 | |
| 
 | |
| describe('Registration', function() {
 | |
|     let parentDiv;
 | |
| 
 | |
|     beforeEach(function() {
 | |
|         parentDiv = document.createElement('div');
 | |
|         document.body.appendChild(parentDiv);
 | |
|     });
 | |
| 
 | |
|     afterEach(function() {
 | |
|         ReactDOM.unmountComponentAtNode(parentDiv);
 | |
|         parentDiv.remove();
 | |
|     });
 | |
| 
 | |
|     function render() {
 | |
|         return ReactDOM.render(<Registration
 | |
|             serverConfig={mkServerConfig("https://matrix.org", "https://vector.im")}
 | |
|             makeRegistrationUrl={() => {}}
 | |
|             onLoggedIn={() => {}}
 | |
|             onLoginClick={() => {}}
 | |
|             onServerConfigChange={() => {}}
 | |
|         />, parentDiv);
 | |
|     }
 | |
| 
 | |
|     it('should show server picker', function() {
 | |
|         const root = render();
 | |
|         const selector = ReactTestUtils.findRenderedDOMComponentWithClass(root, "mx_ServerPicker");
 | |
|         expect(selector).toBeTruthy();
 | |
|     });
 | |
| 
 | |
|     it('should show form when custom URLs disabled', function() {
 | |
|         jest.spyOn(SdkConfig, "get").mockReturnValue({
 | |
|             disable_custom_urls: true,
 | |
|         });
 | |
| 
 | |
|         const root = render();
 | |
| 
 | |
|         // Set non-empty flows & matrixClient to get past the loading spinner
 | |
|         root.setState({
 | |
|             flows: [{
 | |
|                 stages: [],
 | |
|             }],
 | |
|             matrixClient: {},
 | |
|             busy: false,
 | |
|         });
 | |
| 
 | |
|         const form = ReactTestUtils.findRenderedComponentWithType(
 | |
|             root,
 | |
|             sdk.getComponent('auth.RegistrationForm'),
 | |
|         );
 | |
|         expect(form).toBeTruthy();
 | |
|     });
 | |
| 
 | |
|     it("should show SSO options if those are available", () => {
 | |
|         jest.spyOn(SdkConfig, "get").mockReturnValue({
 | |
|             disable_custom_urls: true,
 | |
|         });
 | |
| 
 | |
|         const root = render();
 | |
| 
 | |
|         // Set non-empty flows & matrixClient to get past the loading spinner
 | |
|         root.setState({
 | |
|             flows: [{
 | |
|                 stages: [],
 | |
|             }],
 | |
|             ssoFlow: {
 | |
|                 type: "m.login.sso",
 | |
|             },
 | |
|             matrixClient: {},
 | |
|             busy: false,
 | |
|         });
 | |
| 
 | |
|         const ssoButton = ReactTestUtils.findRenderedDOMComponentWithClass(root, "mx_SSOButton");
 | |
|         expect(ssoButton).toBeTruthy();
 | |
|     });
 | |
| });
 |