mirror of
https://github.com/angular/angular
synced 2026-05-24 09:28:37 +00:00
155 lines
4.9 KiB
JavaScript
155 lines
4.9 KiB
JavaScript
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.dev/license
|
|
*/
|
|
|
|
describe('node selection', () => {
|
|
beforeEach(() => {
|
|
cy.visit('/');
|
|
});
|
|
|
|
describe('logic after change detection', () => {
|
|
it('should deselect node if it is no longer on the page', () => {
|
|
cy.get('.tree-wrapper')
|
|
.get('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.should('not.have.class', 'selected');
|
|
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.first()
|
|
.click({force: true});
|
|
|
|
cy.get('.tree-wrapper')
|
|
.get('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.should('have.class', 'selected');
|
|
|
|
cy.enterIframe('#sample-app').then((getBody) => {
|
|
getBody().find('a:contains("About")').click();
|
|
});
|
|
|
|
cy.get('.tree-wrapper')
|
|
.get('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.should('not.exist');
|
|
});
|
|
|
|
it('should reselect the previously selected node if it is still present', () => {
|
|
cy.get('.tree-wrapper').get('ng-tree-node.selected').should('not.exist');
|
|
|
|
cy.enterIframe('#sample-app').then((getBody) => {
|
|
getBody().find('input.new-todo').type('Buy cookies{enter}');
|
|
});
|
|
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.last()
|
|
.click({force: true});
|
|
|
|
cy.enterIframe('#sample-app').then((getBody) => {
|
|
getBody().find('app-todo:contains("Buy milk")').find('.destroy').click();
|
|
});
|
|
|
|
cy.get('.tree-wrapper').find('ng-tree-node.selected').its('length').should('eq', 1);
|
|
});
|
|
|
|
it('should select nodes with same name', () => {
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.first()
|
|
.click({force: true});
|
|
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("app-todo[TooltipDirective]")')
|
|
.last()
|
|
.click({force: true});
|
|
|
|
cy.get('ng-property-view').first().find('mat-tree-node:contains("todo")').click();
|
|
|
|
cy.get('ng-property-view')
|
|
.first()
|
|
.find('mat-tree-node:contains("Build something fun!")')
|
|
.its('length')
|
|
.should('eq', 1);
|
|
});
|
|
});
|
|
|
|
describe('breadcrumb logic', () => {
|
|
it('should overflow when breadcrumb list is long enough', () => {
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("base-case")')
|
|
.last()
|
|
.click({force: true})
|
|
.then(() => {
|
|
cy.get('ng-breadcrumbs')
|
|
.find('.breadcrumbs')
|
|
.then((breadcrumbsContainer) => {
|
|
const hasOverflowX = () =>
|
|
breadcrumbsContainer[0].scrollWidth > breadcrumbsContainer[0].clientWidth;
|
|
expect(hasOverflowX()).to.be.true;
|
|
});
|
|
});
|
|
});
|
|
|
|
it('should scroll right when right scroll button is clicked', () => {
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("base-case")')
|
|
.last()
|
|
.click({force: true})
|
|
.then(() => {
|
|
cy.get('ng-breadcrumbs')
|
|
.find('.breadcrumbs')
|
|
.then((el) => {
|
|
el[0].style.scrollBehavior = 'auto';
|
|
})
|
|
.then((breadcrumbsContainer) => {
|
|
const scrollLeft = () => breadcrumbsContainer[0].scrollLeft;
|
|
expect(scrollLeft()).to.eql(0);
|
|
|
|
cy.get('ng-breadcrumbs')
|
|
.find('.scroll-button')
|
|
.last()
|
|
.click({force: true})
|
|
.then(() => {
|
|
expect(scrollLeft()).to.be.greaterThan(0);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
it('should scroll left when left scroll button is clicked', () => {
|
|
cy.get('.tree-wrapper')
|
|
.find('ng-tree-node:contains("base-case")')
|
|
.last()
|
|
.click({force: true})
|
|
.then(() => {
|
|
cy.get('ng-breadcrumbs')
|
|
.find('.breadcrumbs')
|
|
.then((el) => {
|
|
el[0].style.scrollBehavior = 'auto';
|
|
})
|
|
.then((breadcrumbsContainer) => {
|
|
const scrollLeft = () => breadcrumbsContainer[0].scrollLeft;
|
|
expect(scrollLeft()).to.eql(0);
|
|
|
|
cy.get('ng-breadcrumbs')
|
|
.find('.scroll-button')
|
|
.last()
|
|
.click({force: true})
|
|
.then(() => {
|
|
expect(scrollLeft()).to.be.greaterThan(0);
|
|
|
|
cy.get('ng-breadcrumbs')
|
|
.find('.scroll-button')
|
|
.first()
|
|
.click({force: true})
|
|
.then(() => {
|
|
expect(scrollLeft()).to.eql(0);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|