mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-26 08:25:02 +00:00 
			
		
		
		
	 10aab5c7a7
			
		
	
	
		10aab5c7a7
		
			
		
	
	
	
	
		
			
			* Catchup frontend for internal development changes * Revert accidental change to test file
		
			
				
	
	
		
			113 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { module, test } from 'qunit';
 | |
| import { setupRenderingTest } from 'ember-qunit';
 | |
| import { render, findAll, fillIn, click, find, triggerKeyEvent } from '@ember/test-helpers';
 | |
| import { noop } from 'lodash';
 | |
| import hbs from 'htmlbars-inline-precompile';
 | |
| import { baseModalClass } from '@datahub/shared/components/change-management/add-change-log-modal';
 | |
| import { IAddChangeLogModalProps } from '@datahub/shared/types/change-management/change-log';
 | |
| import { TestContext } from 'ember-test-helpers';
 | |
| 
 | |
| const modalClassSelector = `.${baseModalClass}__modal`;
 | |
| const subjectClassSelector = `.${baseModalClass}__text-input-subject`;
 | |
| const contentClassSelector = `.${baseModalClass}__text-input-content`;
 | |
| 
 | |
| module('Integration | Component | change-management/add-change-log-modal', function(hooks): void {
 | |
|   setupRenderingTest(hooks);
 | |
| 
 | |
|   hooks.beforeEach(function(this: TestContext, assert): void {
 | |
|     this.setProperties({
 | |
|       onSave(value: IAddChangeLogModalProps): void {
 | |
|         assert.ok(value, 'A value was given to the save action');
 | |
|         assert.equal(Object.keys(value).length, 5, '5 Edited props were passed to the action');
 | |
|       },
 | |
|       onCloseModal: noop,
 | |
|       followers: ['Ciri', 'Dandelion', 'Yennefer', 'Triss']
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   test('it renders as expected with the right defaults', async function(assert): Promise<void> {
 | |
|     await render(hbs`
 | |
|       <ChangeManagement::AddChangeLogModal
 | |
|         @onCloseModal={{action this.onCloseModal}}
 | |
|         @onSave={{action this.onSave}}
 | |
|       />
 | |
|     `);
 | |
| 
 | |
|     assert.dom(modalClassSelector).exists();
 | |
|     assert.dom(subjectClassSelector).hasText('');
 | |
|     assert.dom(contentClassSelector).hasText('');
 | |
|   });
 | |
| 
 | |
|   test('Saving to log happens as intended', async function(assert): Promise<void> {
 | |
|     await render(hbs`
 | |
|       <ChangeManagement::AddChangeLogModal
 | |
|         @onCloseModal={{action this.onCloseModal}}
 | |
|         @onSave={{action this.onSave}}
 | |
|       />s
 | |
|     `);
 | |
| 
 | |
|     await fillIn(subjectClassSelector, 'Toss a coin to your witcher!');
 | |
|     await fillIn(
 | |
|       contentClassSelector,
 | |
|       'Hereby the common folks of Velen are summoned to heed their presence to the great Geralt of Rivia!'
 | |
|     );
 | |
|     const actions = findAll(`.${baseModalClass}__action`);
 | |
|     assert.dom(actions[1]).hasText('Continue to send email', 'button text is rendered as expected');
 | |
|   });
 | |
| 
 | |
|   test('Preview mode displays as expected', async function(assert): Promise<void> {
 | |
|     await render(hbs`
 | |
|       <ChangeManagement::AddChangeLogModal
 | |
|         @onCloseModal={{action this.onCloseModal}}
 | |
|         @onSave={{action this.onSave}}
 | |
|         @recipients={{this.followers}}
 | |
|       />
 | |
|     `);
 | |
| 
 | |
|     await fillIn(subjectClassSelector, 'Toss a coin to your witcher!');
 | |
|     await fillIn(
 | |
|       contentClassSelector,
 | |
|       'Hereby the common folks of Velen are summoned to heed their presence to the great Geralt of Rivia!'
 | |
|     );
 | |
| 
 | |
|     const actions = findAll(`.${baseModalClass}__action`);
 | |
|     assert.dom(actions[1]).hasText('Continue to send email', 'button text is rendered as expected');
 | |
|     await click(actions[1]);
 | |
|     // Focus pill
 | |
|     await click('.nacho-pill-input:nth-child(1)');
 | |
|     const nachoPillInputs = findAll('.nacho-pill-input__input');
 | |
|     // Fill input with data
 | |
|     await fillIn(findAll('.ember-power-select-search-input')[0], 'testGroup1');
 | |
|     // Hit tab / enter
 | |
|     await triggerKeyEvent(nachoPillInputs[0], 'keyup', 13);
 | |
| 
 | |
|     // Add a new individual recipient
 | |
|     await click(findAll('.nacho-pill-input')[1]);
 | |
|     await fillIn(findAll('.ember-power-select-search-input')[0], 'testIndividualLDAP1');
 | |
|     await triggerKeyEvent(findAll('.ember-power-select-search-input')[0], 'keyup', 13);
 | |
| 
 | |
|     assert
 | |
|       .dom(find(`.${baseModalClass}__content`))
 | |
|       .includesText(
 | |
|         'Sending Email to 4 individuals',
 | |
|         'User is able to enter input for searching and Title text is displayed correctly'
 | |
|       );
 | |
| 
 | |
|     assert
 | |
|       .dom(find(`.${baseModalClass}__content`))
 | |
|       .includesText('All Owners of the dataset', 'Owners are included in prompt');
 | |
|     assert
 | |
|       .dom(find(`.${baseModalClass}__content`))
 | |
|       .includesText(
 | |
|         'Group email distribution list (0)',
 | |
|         'Distribution lists are included in prompt with the right count'
 | |
|       );
 | |
|     assert
 | |
|       .dom(find(`.${baseModalClass}__content`))
 | |
|       .includesText(
 | |
|         'Individual email recipients (0)',
 | |
|         'Individual recipients are included in prompt with the right count'
 | |
|       );
 | |
|   });
 | |
| });
 |