mirror of
				https://github.com/Alfresco/alfresco-ng2-components.git
				synced 2025-10-22 15:11:57 +00:00 
			
		
		
		
	* [ADF-2500] The full content of Trashcan is not displayed. fix pagination problem and add tests * refactor code * custom resources services * move custom resources in separate service part 2 * move custom resources in separate service part 3 * move isCustomResources in custom resources * move getCorrispondinNodeIds in custom services * reorganize code * add pagination interface * remove permissions check document list and use the common cs method remove the merge option and move it in the paginator * make infinte scrolling always use the target * restore loading infinite page * fix license header * fix type problems * breadcrumb test service * fix test * export CustomResourcesService * fix test pagination * fix content ndoe test * remove timeout content node selector test * fix after rebase * ripristinate observalbe in search service * fix wrong type return stub document list test * fix search service * fix test document list * move handle error in common method * restore observable in search control * Update search-control.component.spec.ts * fix after rebase * add import switchmap * core import in karma conf * missing commas * fix mocks * fix mock searchquerybody * search test fix
		
			
				
	
	
		
			167 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /*!
 | |
|  * @license
 | |
|  * Copyright 2016 Alfresco Software, 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 { MAT_DIALOG_DATA } from '@angular/material';
 | |
| import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
 | |
| import { EventEmitter } from '@angular/core';
 | |
| import { async, ComponentFixture, TestBed } from '@angular/core/testing';
 | |
| import { ContentNodeSelectorComponent } from './content-node-selector.component';
 | |
| import { ContentNodeSelectorPanelComponent } from './content-node-selector-panel.component';
 | |
| import { ContentNodeSelectorService } from './content-node-selector.service';
 | |
| import { MinimalNodeEntryEntity } from 'alfresco-js-api';
 | |
| import { By } from '@angular/platform-browser';
 | |
| import {
 | |
|         EmptyFolderContentDirective,
 | |
|         DocumentListComponent,
 | |
|         DocumentListService,
 | |
|         CustomResourcesService
 | |
|     } from '../document-list';
 | |
| import { ContentService } from '@alfresco/adf-core';
 | |
| 
 | |
| describe('ContentNodeSelectorDialogComponent', () => {
 | |
| 
 | |
|     let component: ContentNodeSelectorComponent;
 | |
|     let fixture: ComponentFixture<ContentNodeSelectorComponent>;
 | |
|     let data: any;
 | |
| 
 | |
|     function setupTestbed(plusProviders) {
 | |
|         TestBed.configureTestingModule({
 | |
|             imports: [
 | |
|             ],
 | |
|             declarations: [
 | |
|                 ContentNodeSelectorComponent,
 | |
|                 ContentNodeSelectorPanelComponent,
 | |
|                 DocumentListComponent,
 | |
|                 EmptyFolderContentDirective
 | |
|             ],
 | |
|             providers: [
 | |
|                 CustomResourcesService,
 | |
|                 ContentNodeSelectorService,
 | |
|                 ContentNodeSelectorPanelComponent,
 | |
|                 DocumentListService,
 | |
|                 ContentService,
 | |
|                 DocumentListService,
 | |
|                 ContentNodeSelectorService,
 | |
|                 ...plusProviders
 | |
|             ],
 | |
|             schemas: [CUSTOM_ELEMENTS_SCHEMA]
 | |
|         });
 | |
|     }
 | |
| 
 | |
|     afterEach(() => {
 | |
|         fixture.destroy();
 | |
|         TestBed.resetTestingModule();
 | |
|     });
 | |
| 
 | |
|     beforeEach(async(() => {
 | |
|         data = {
 | |
|             title: 'Move along citizen...',
 | |
|             actionName: 'move',
 | |
|             select: new EventEmitter<MinimalNodeEntryEntity>(),
 | |
|             rowFilter: () => {
 | |
|             },
 | |
|             imageResolver: () => 'piccolo',
 | |
|             currentFolderId: 'cat-girl-nuku-nuku'
 | |
|         };
 | |
| 
 | |
|         setupTestbed([{ provide: MAT_DIALOG_DATA, useValue: data }]);
 | |
|         TestBed.compileComponents();
 | |
|     }));
 | |
| 
 | |
|     beforeEach(() => {
 | |
|         fixture = TestBed.createComponent(ContentNodeSelectorComponent);
 | |
|         component = fixture.componentInstance;
 | |
|         fixture.detectChanges();
 | |
|     });
 | |
| 
 | |
|     describe('Data injecting with the "Material dialog way"', () => {
 | |
| 
 | |
|         it('should show the INJECTED title', () => {
 | |
|             const titleElement = fixture.debugElement.query(By.css('[data-automation-id="content-node-selector-title"]'));
 | |
|             expect(titleElement).not.toBeNull();
 | |
|             expect(titleElement.nativeElement.innerText).toBe('Move along citizen...');
 | |
|         });
 | |
| 
 | |
|         it('should have the INJECTED actionName on the name of the choose button', () => {
 | |
|             const actionButton = fixture.debugElement.query(By.css('[data-automation-id="content-node-selector-actions-choose"]'));
 | |
|             expect(actionButton).not.toBeNull();
 | |
|             expect(actionButton.nativeElement.innerText).toBe('NODE_SELECTOR.MOVE');
 | |
|         });
 | |
| 
 | |
|         it('should pass through the injected currentFolderId to the documentlist', () => {
 | |
|             let documentList = fixture.debugElement.query(By.directive(DocumentListComponent));
 | |
|             expect(documentList).not.toBeNull('Document list should be shown');
 | |
|             expect(documentList.componentInstance.currentFolderId).toBe('cat-girl-nuku-nuku');
 | |
|         });
 | |
| 
 | |
|         it('should pass through the injected rowFilter to the documentlist', () => {
 | |
|             let documentList = fixture.debugElement.query(By.directive(DocumentListComponent));
 | |
|             expect(documentList).not.toBeNull('Document list should be shown');
 | |
|             expect(documentList.componentInstance.rowFilter).toBe(data.rowFilter);
 | |
|         });
 | |
| 
 | |
|         it('should pass through the injected imageResolver to the documentlist', () => {
 | |
|             let documentList = fixture.debugElement.query(By.directive(DocumentListComponent));
 | |
|             expect(documentList).not.toBeNull('Document list should be shown');
 | |
|             expect(documentList.componentInstance.imageResolver).toBe(data.imageResolver);
 | |
|         });
 | |
| 
 | |
|     });
 | |
| 
 | |
|     describe('Cancel button', () => {
 | |
| 
 | |
|         it('should complete the data stream when user click "CANCEL"', () => {
 | |
|             let cancelButton;
 | |
|             data.select.subscribe(
 | |
|                 () => { },
 | |
|                 () => { },
 | |
|                 () => {
 | |
|                     cancelButton = fixture.debugElement.query(By.css('[data-automation-id="content-node-selector-actions-cancel"]'));
 | |
|                     expect(cancelButton).not.toBeNull();
 | |
|                 });
 | |
| 
 | |
|             cancelButton = fixture.debugElement.query(By.css('[data-automation-id="content-node-selector-actions-cancel"]'));
 | |
|             cancelButton.triggerEventHandler('click', {});
 | |
|         });
 | |
| 
 | |
|         it('should not be shown if dialogRef is NOT injected', () => {
 | |
|             const closeButton = fixture.debugElement.query(By.css('[content-node-selector-actions-cancel]'));
 | |
|             expect(closeButton).toBeNull();
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe('Action button for the chosen node', () => {
 | |
| 
 | |
|         it('should be disabled by default', () => {
 | |
|             fixture.detectChanges();
 | |
| 
 | |
|             let actionButton = fixture.debugElement.query(By.css('[data-automation-id="content-node-selector-actions-choose"]'));
 | |
|             expect(actionButton.nativeElement.disabled).toBeTruthy();
 | |
|         });
 | |
| 
 | |
|         it('should be enabled when a node is chosen', () => {
 | |
|             component.onSelect([{ id: 'fake' }]);
 | |
|             fixture.detectChanges();
 | |
| 
 | |
|             let actionButton = fixture.debugElement.query(By.css('[data-automation-id="content-node-selector-actions-choose"]'));
 | |
|             expect(actionButton.nativeElement.disabled).toBeFalsy();
 | |
|         });
 | |
| 
 | |
|     });
 | |
| 
 | |
| });
 |