file.spec.ts 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright (c) Jupyter Development Team.
  2. // Distributed under the terms of the Modified BSD License.
  3. import { WidgetTracker } from '@jupyterlab/apputils';
  4. import { FileMenu, IFileMenu } from '@jupyterlab/mainmenu';
  5. import { CommandRegistry } from '@lumino/commands';
  6. import { Widget } from '@lumino/widgets';
  7. import { delegateExecute } from './util';
  8. class Wodget extends Widget {
  9. state: string;
  10. }
  11. describe('@jupyterlab/mainmenu', () => {
  12. describe('FileMenu', () => {
  13. let commands: CommandRegistry;
  14. let menu: FileMenu;
  15. let tracker: WidgetTracker<Wodget>;
  16. let wodget: Wodget;
  17. beforeAll(() => {
  18. commands = new CommandRegistry();
  19. });
  20. beforeEach(() => {
  21. wodget = new Wodget();
  22. menu = new FileMenu({ commands });
  23. tracker = new WidgetTracker<Wodget>({ namespace: 'wodget' });
  24. void tracker.add(wodget);
  25. });
  26. afterEach(() => {
  27. menu.dispose();
  28. tracker.dispose();
  29. wodget.dispose();
  30. });
  31. describe('#constructor()', () => {
  32. it('should construct a new file menu', () => {
  33. expect(menu).toBeInstanceOf(FileMenu);
  34. // For localization this is now defined when on the mainmenu-extension.
  35. expect(menu.title.label).toBe('');
  36. });
  37. });
  38. describe('#newMenu', () => {
  39. it('should be a submenu for `New...` commands', () => {
  40. // For localization this is now defined when on the mainmenu-extension.
  41. expect(menu.newMenu.title.label).toBe('');
  42. });
  43. });
  44. describe('#cleaners', () => {
  45. it('should allow setting of an ICloseAndCleaner', () => {
  46. const cleaner: IFileMenu.ICloseAndCleaner<Wodget> = {
  47. tracker,
  48. closeAndCleanupLabel: (n: number) => 'closeAndCleanupLabel',
  49. closeAndCleanup: widget => {
  50. widget.state = 'clean';
  51. return Promise.resolve(void 0);
  52. }
  53. };
  54. menu.closeAndCleaners.add(cleaner);
  55. void delegateExecute(wodget, menu.closeAndCleaners, 'closeAndCleanup');
  56. expect(wodget.state).toBe('clean');
  57. });
  58. });
  59. describe('#consoleCreators', () => {
  60. it('should allow setting of an IConsoleCreator', () => {
  61. const creator: IFileMenu.IConsoleCreator<Wodget> = {
  62. tracker,
  63. createConsoleLabel: (n: number) => 'createConsoleLabel',
  64. createConsole: widget => {
  65. widget.state = 'create';
  66. return Promise.resolve(void 0);
  67. }
  68. };
  69. menu.consoleCreators.add(creator);
  70. void delegateExecute(wodget, menu.consoleCreators, 'createConsole');
  71. expect(wodget.state).toBe('create');
  72. });
  73. });
  74. });
  75. });