Skip to content

Commit

Permalink
Allow updates of CompositeMenuNode properties (eclipse-theia#12948)
Browse files Browse the repository at this point in the history
- refactor updateOptions function to allow updates
- add a unit test cases for updateOptions

Fixes eclipse-theia#12948
  • Loading branch information
ndoschek committed Feb 27, 2024
1 parent 9348727 commit ce4e6bc
Show file tree
Hide file tree
Showing 2 changed files with 74 additions and 5 deletions.
69 changes: 69 additions & 0 deletions packages/core/src/common/menu/composite-menu-node.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
// *****************************************************************************
// Copyright (C) 2024 EclipseSource and others.
//
// This program and the accompanying materials are made available under the
// terms of the Eclipse Public License v. 2.0 which is available at
// http://www.eclipse.org/legal/epl-2.0.
//
// This Source Code may also be made available under the following Secondary
// Licenses when the conditions for such availability set forth in the Eclipse
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
// with the GNU Classpath Exception which is available at
// https://www.gnu.org/software/classpath/license.html.
//
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
// *****************************************************************************
import * as chai from 'chai';
import { CompositeMenuNode } from './composite-menu-node';
import { CompoundMenuNodeRole } from './menu-types';

const expect = chai.expect;

describe('composite-menu-node', () => {
describe('updateOptions', () => {
it('should update undefined node properties', () => {
const node = new CompositeMenuNode('test-id');
node.updateOptions({ label: 'node-label', icon: 'icon', order: 'a', role: CompoundMenuNodeRole.Flat, when: 'node-condition' });
expect(node.label).to.equal('node-label');
expect(node.icon).to.equal('icon');
expect(node.order).to.equal('a');
expect(node.role).to.equal(CompoundMenuNodeRole.Flat);
expect(node.when).to.equal('node-condition');
});
it('should update existing node properties', () => {
const node = new CompositeMenuNode('test-id', 'test-label', { icon: 'test-icon', order: 'a1', role: CompoundMenuNodeRole.Submenu, when: 'test-condition' });
node.updateOptions({ label: 'NEW-label', icon: 'NEW-icon', order: 'a2', role: CompoundMenuNodeRole.Flat, when: 'NEW-condition' });
expect(node.label).to.equal('NEW-label');
expect(node.icon).to.equal('NEW-icon');
expect(node.order).to.equal('a2');
expect(node.role).to.equal(CompoundMenuNodeRole.Flat);
expect(node.when).to.equal('NEW-condition');
});
it('should update only the icon without affecting other properties', () => {
const node = new CompositeMenuNode('test-id', 'test-label', { icon: 'test-icon', order: 'a' });
node.updateOptions({ icon: 'NEW-icon' });
expect(node.label).to.equal('test-label');
expect(node.icon).to.equal('NEW-icon');
expect(node.order).to.equal('a');
});
it('should not allow to unset properties', () => {
const node = new CompositeMenuNode('test-id', 'test-label', { icon: 'test-icon', order: 'a' });
node.updateOptions({ icon: undefined });
expect(node.label).to.equal('test-label');
expect(node.icon).to.equal('test-icon');
expect(node.order).to.equal('a');
});
it('should allow to set empty strings in properties', () => {
const node = new CompositeMenuNode('test-id', 'test-label');
node.updateOptions({ label: '' });
expect(node.label).to.equal('');
});
it('should not cause side effects when updating a property to its existing value', () => {
const node = new CompositeMenuNode('test-id', 'test-label', { icon: 'test-icon', order: 'a' });
node.updateOptions({ icon: 'test-icon' });
expect(node.label).to.equal('test-label');
expect(node.icon).to.equal('test-icon');
expect(node.order).to.equal('a');
});
});
});
10 changes: 5 additions & 5 deletions packages/core/src/common/menu/composite-menu-node.ts
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,11 @@ export class CompositeMenuNode implements MutableCompoundMenuNode {

updateOptions(options?: SubMenuOptions): void {
if (options) {
this.iconClass ??= options.icon ?? options.iconClass;
this.label ??= options.label;
this.order ??= options.order;
this._role ??= options.role;
this._when ??= options.when;
this.iconClass = options.icon ?? options.iconClass ?? this.iconClass;
this.label = options.label ?? this.label;
this.order = options.order ?? this.order;
this._role = options.role ?? this._role;
this._when = options.when ?? this._when;
}
}

Expand Down

0 comments on commit ce4e6bc

Please sign in to comment.