From fce98a1c4708fbaa7b4025d671e0bc04408c4518 Mon Sep 17 00:00:00 2001 From: Tristan F Date: Tue, 2 Jan 2024 10:24:22 -0500 Subject: [PATCH] refactor: migrate to ESM (#7331) * refactor: move package.json to type: module this is where the fun begins * chore: move webpack common and prod to esm * chore: move webpack to esm, eslint to explicit cjs * refactor: migrate all files to esm * style: lint * refactor: begin moving karma to cjs, use dynamic esm import * refactor: move index-test to cjs * refactor: begin moving e2e to ESM this was manual. I'm committing this because I'm about to try the `cjstoesm` tool * refactor: move all to esm * fix: make all e2e tests use .js imports * refactor: begin moving exports to esm * refactor: use URL transforms instead of __dirname * fix: use libraryExport: default to properly handle openmct * fix: export all playwright configs as modules * refactor: move all instances of __dirname to import.meta.url * refactor: lint, drop unnecessary URL call * fix: use correct URL path on helper/addNoneditableObject.js * fix: more incorrect URL resolve issues * fix: parse json after reading it --- .eslintrc.js => .eslintrc.cjs | 0 .webpack/webpack.common.js | 28 ++-- .webpack/webpack.coverage.js | 6 +- .webpack/webpack.dev.js | 16 +-- .webpack/webpack.prod.js | 13 +- e2e/{.eslintrc.js => .eslintrc.cjs} | 0 e2e/README.md | 2 +- e2e/appActions.js | 19 ++- e2e/avpFixtures.js | 16 +-- e2e/baseFixtures.js | 20 ++- e2e/helper/faultUtils.js | 44 +++--- e2e/helper/notebookUtils.js | 21 +-- e2e/helper/planningUtils.js | 2 +- e2e/helper/plotTagsUtils.js | 4 +- e2e/playwright-ci.config.js | 5 +- e2e/playwright-local.config.js | 5 +- e2e/playwright-performance-dev.config.js | 3 +- e2e/playwright-performance-prod.config.js | 3 +- e2e/playwright-visual-a11y.config.js | 2 +- e2e/playwright-watch.config.js | 5 +- e2e/pluginFixtures.js | 20 +-- e2e/tests/framework/appActions.e2e.spec.js | 6 +- e2e/tests/framework/baseFixtures.e2e.spec.js | 2 +- .../framework/exampleTemplate.e2e.spec.js | 4 +- .../generateLocalStorageData.e2e.spec.js | 38 +++--- .../framework/pluginFixtures.e2e.spec.js | 2 +- e2e/tests/functional/branding.e2e.spec.js | 2 +- .../functional/clearDataAction.e2e.spec.js | 4 +- e2e/tests/functional/couchdb.e2e.spec.js | 2 +- .../example/eventGenerator.e2e.spec.js | 4 +- .../sineWaveLimitProvider.e2e.spec.js | 2 +- e2e/tests/functional/forms.e2e.spec.js | 15 +- e2e/tests/functional/menu.e2e.spec.js | 8 +- .../functional/moveAndLinkObjects.e2e.spec.js | 4 +- e2e/tests/functional/notification.e2e.spec.js | 4 +- .../planning/ganttChart.e2e.spec.js | 25 +++- .../functional/planning/plan.e2e.spec.js | 26 +++- .../functional/planning/timelist.e2e.spec.js | 4 +- .../functional/planning/timestrip.e2e.spec.js | 6 +- .../plugins/clocks/clock.e2e.spec.js | 2 +- .../plugins/clocks/remoteClock.e2e.spec.js | 2 +- .../conditionSet/conditionSet.e2e.spec.js | 18 ++- .../displayLayout/displayLayout.e2e.spec.js | 27 ++-- .../faultManagement.e2e.spec.js | 4 +- .../flexibleLayout/flexibleLayout.e2e.spec.js | 17 ++- .../plugins/gauge/gauge.e2e.spec.js | 9 +- .../imagery/exampleImagery.e2e.spec.js | 6 +- .../exportAsJson.e2e.spec.js | 2 +- .../importAsJson.e2e.spec.js | 2 +- .../numericData.e2e.spec.js | 12 +- .../functional/plugins/lad/lad.e2e.spec.js | 10 +- .../plugins/notebook/notebook.e2e.spec.js | 13 +- .../notebook/notebookSnapshots.e2e.spec.js | 15 +- .../notebook/notebookWithCouchDB.e2e.spec.js | 6 +- .../notebook/restrictedNotebook.e2e.spec.js | 10 +- .../plugins/notebook/tags.e2e.spec.js | 12 +- .../operatorStatus/operatorStatus.e2e.spec.js | 10 +- .../plugins/plot/autoscale.e2e.spec.js | 4 +- .../plugins/plot/logPlot.e2e.spec.js | 4 +- .../plugins/plot/missingPlotObj.e2e.spec.js | 2 +- .../plugins/plot/overlayPlot.e2e.spec.js | 6 +- .../plugins/plot/plotRendering.e2e.spec.js | 4 +- .../plugins/plot/scatterPlot.e2e.spec.js | 7 +- .../plugins/plot/stackedPlot.e2e.spec.js | 4 +- .../plugins/plot/tagging.e2e.spec.js | 14 +- .../functional/plugins/tabs/tabs.e2e.spec.js | 4 +- .../telemetryTable/telemetryTable.e2e.spec.js | 7 +- .../timeConductor/timeConductor.e2e.spec.js | 8 +- .../plugins/timer/timer.e2e.spec.js | 12 +- .../functional/recentObjects.e2e.spec.js | 6 +- e2e/tests/functional/renaming.e2e.spec.js | 7 +- e2e/tests/functional/search.e2e.spec.js | 7 +- e2e/tests/functional/smoke.e2e.spec.js | 2 +- e2e/tests/functional/tooltips.e2e.spec.js | 4 +- e2e/tests/functional/tree.e2e.spec.js | 7 +- .../contract/imagery.contract.perf.spec.js | 2 +- .../contract/notebook.contract.perf.spec.js | 2 +- .../memory/navigation.memory.perf.spec.js | 10 +- e2e/tests/performance/tabs.e2e.spec.js | 4 +- e2e/tests/performance/tagging.perf.spec.js | 10 +- e2e/tests/visual-a11y/a11y.visual.spec.js | 4 +- .../components/about.visual.spec.js | 7 +- .../components/inspector.visual.spec.js | 7 +- .../components/tree.visual.spec.js | 12 +- .../controlledClock.visual.spec.js | 7 +- .../visual-a11y/defaultPlugins.visual.spec.js | 9 +- .../visual-a11y/displayLayout.visual.spec.js | 9 +- .../faultManagement.visual.spec.js | 11 +- e2e/tests/visual-a11y/ladTable.visual.spec.js | 9 +- e2e/tests/visual-a11y/notebook.visual.spec.js | 14 +- .../visual-a11y/notification.visual.spec.js | 9 +- e2e/tests/visual-a11y/planning.visual.spec.js | 20 +-- e2e/tests/visual-a11y/search.visual.spec.js | 8 +- example/dataVisualization/plugin.js | 2 +- example/eventGenerator/plugin.js | 4 +- example/eventGenerator/pluginSpec.js | 2 +- example/exampleUser/ExampleUserProvider.js | 2 +- example/exampleUser/plugin.js | 2 +- example/exampleUser/pluginSpec.js | 4 +- example/faultManagement/exampleFaultSource.js | 2 +- example/faultManagement/pluginSpec.js | 2 +- example/generator/GeneratorProvider.js | 2 +- example/generator/plugin.js | 10 +- index-test.js => index-test.cjs | 0 karma.conf.js => karma.conf.cjs | 10 +- openmct.js | 5 +- package.json | 5 +- src/MCT.js | 70 +++++----- src/MCTSpec.js | 2 +- src/api/EditorSpec.js | 2 +- src/api/actions/ActionCollectionSpec.js | 4 +- src/api/actions/ActionsAPI.js | 2 +- src/api/actions/ActionsAPISpec.js | 6 +- src/api/annotation/AnnotationAPISpec.js | 4 +- src/api/api.js | 32 ++--- src/api/composition/CompositionAPI.js | 4 +- src/api/composition/CompositionAPISpec.js | 4 +- src/api/composition/CompositionProvider.js | 2 +- .../composition/DefaultCompositionProvider.js | 4 +- .../faultmanagement/FaultManagementAPISpec.js | 2 +- src/api/forms/FormsAPI.js | 2 +- src/api/forms/FormsAPISpec.js | 2 +- .../components/controls/CheckBoxField.vue | 2 +- .../components/controls/ToggleSwitchField.vue | 2 +- src/api/indicators/IndicatorAPI.js | 2 +- src/api/indicators/IndicatorAPISpec.js | 4 +- src/api/menu/MenuAPISpec.js | 6 +- src/api/menu/components/MenuComponent.vue | 2 +- src/api/menu/components/SuperMenu.vue | 2 +- src/api/menu/mixins/popupMenuMixin.js | 2 +- src/api/notifications/NotificationAPISpec.js | 2 +- src/api/objects/ObjectAPI.js | 14 +- src/api/objects/ObjectAPISearchSpec.js | 2 +- src/api/objects/ObjectAPISpec.js | 2 +- src/api/objects/RootRegistry.js | 2 +- src/api/objects/TransactionSpec.js | 2 +- .../objects/test/RootObjectProviderSpec.js | 2 +- src/api/objects/test/RootRegistrySpec.js | 2 +- src/api/overlays/Dialog.js | 2 +- src/api/overlays/OverlayAPI.js | 8 +- src/api/overlays/ProgressDialog.js | 2 +- src/api/overlays/Selection.js | 2 +- src/api/status/StatusAPISpec.js | 2 +- src/api/telemetry/TelemetryAPI.js | 12 +- src/api/telemetry/TelemetryAPISpec.js | 4 +- src/api/telemetry/TelemetryCollection.js | 4 +- src/api/telemetry/TelemetryCollectionSpec.js | 2 +- src/api/time/GlobalTimeContext.js | 2 +- src/api/time/IndependentTimeContext.js | 4 +- src/api/time/TimeAPI.js | 2 +- src/api/time/TimeAPISpec.js | 2 +- src/api/time/TimeContext.js | 2 +- src/api/time/independentTimeAPISpec.js | 2 +- src/api/tooltips/ToolTipAPI.js | 2 +- src/api/types/TypeRegistry.js | 2 +- src/api/types/TypeRegistrySpec.js | 2 +- src/api/user/ActiveRoleSynchronizer.js | 2 +- src/api/user/StatusUserProvider.js | 2 +- src/api/user/StoragePersistance.js | 2 +- src/api/user/UserAPI.js | 8 +- src/api/user/UserAPISpec.js | 6 +- src/api/user/UserStatusAPISpec.js | 2 +- src/exporters/ImageExporterSpec.js | 4 +- src/plugins/CouchDBSearchFolder/pluginSpec.js | 2 +- src/plugins/DeviceClassifier/plugin.js | 4 +- .../DeviceClassifier/src/DeviceClassifier.js | 2 +- .../src/DeviceClassifierSpec.js | 4 +- .../src/DeviceMatchersSpec.js | 2 +- src/plugins/ISOTimeFormat/plugin.js | 2 +- .../LADTable/LADTableSetViewProvider.js | 2 +- src/plugins/LADTable/LADTableView.js | 2 +- src/plugins/LADTable/LADTableViewProvider.js | 2 +- src/plugins/LADTable/LadTableSetView.js | 2 +- src/plugins/LADTable/components/LadRow.vue | 4 +- .../components/LadTableConfiguration.vue | 2 +- src/plugins/LADTable/plugin.js | 10 +- .../URLIndicatorPlugin/URLIndicatorPlugin.js | 2 +- .../URLIndicatorPlugin/URLIndicatorSpec.js | 2 +- .../URLTimeSettingsSynchronizer.js | 6 +- .../autoflow/AutoflowTabularController.js | 2 +- src/plugins/autoflow/AutoflowTabularPlugin.js | 2 +- .../autoflow/AutoflowTabularPluginSpec.js | 6 +- src/plugins/autoflow/AutoflowTabularView.js | 6 +- .../charts/bar/BarGraphCompositionPolicy.js | 2 +- .../charts/bar/BarGraphViewProvider.js | 2 +- .../BarGraphInspectorViewProvider.js | 2 +- src/plugins/charts/bar/plugin.js | 8 +- src/plugins/charts/bar/pluginSpec.js | 4 +- .../scatter/ScatterPlotCompositionPolicy.js | 2 +- .../scatter/inspector/PlotOptionsBrowse.vue | 4 +- .../scatter/inspector/PlotOptionsEdit.vue | 4 +- .../ScatterPlotInspectorViewProvider.js | 2 +- src/plugins/charts/scatter/plugin.js | 6 +- src/plugins/charts/scatter/pluginSpec.js | 4 +- src/plugins/clearData/plugin.js | 2 +- src/plugins/clock/plugin.js | 2 +- src/plugins/clock/pluginSpec.js | 2 +- src/plugins/condition/Condition.js | 10 +- src/plugins/condition/ConditionManager.js | 4 +- src/plugins/condition/ConditionManagerSpec.js | 2 +- .../ConditionSetCompositionPolicySpec.js | 2 +- .../ConditionSetTelemetryProvider.js | 2 +- src/plugins/condition/ConditionSpec.js | 6 +- .../components/ConditionCollection.vue | 2 +- .../condition/components/CriterionItem.vue | 4 +- .../criterion/AllTelemetryCriterion.js | 6 +- .../condition/criterion/TelemetryCriterion.js | 6 +- .../criterion/TelemetryCriterionSpec.js | 2 +- src/plugins/condition/plugin.js | 6 +- src/plugins/condition/pluginSpec.js | 10 +- src/plugins/condition/utils/evaluator.js | 2 +- src/plugins/condition/utils/evaluatorSpec.js | 4 +- src/plugins/condition/utils/operations.js | 2 +- src/plugins/condition/utils/operationsSpec.js | 2 +- src/plugins/condition/utils/styleUtils.js | 2 +- src/plugins/condition/utils/timeSpec.js | 2 +- .../components/ConditionWidget.vue | 2 +- src/plugins/conditionWidget/pluginSpec.js | 2 +- .../CustomStringFormatterSpec.js | 2 +- .../displayLayout/components/BoxView.vue | 2 +- .../displayLayout/components/EditMarquee.vue | 2 +- .../displayLayout/components/EllipseView.vue | 2 +- .../displayLayout/components/ImageView.vue | 2 +- .../displayLayout/components/LayoutFrame.vue | 4 +- .../displayLayout/components/LineView.vue | 2 +- .../components/TelemetryView.vue | 4 +- .../displayLayout/components/TextView.vue | 2 +- src/plugins/displayLayout/plugin.js | 2 +- src/plugins/displayLayout/pluginSpec.js | 2 +- src/plugins/duplicate/DuplicateAction.js | 2 +- src/plugins/duplicate/plugin.js | 2 +- src/plugins/exportAsJSONAction/plugin.js | 2 +- .../FaultManagementInspectorViewProvider.js | 2 +- .../FaultManagementListHeader.vue | 2 +- .../FaultManagementListView.vue | 2 +- .../FaultManagementObjectProvider.js | 2 +- .../faultManagement/FaultManagementPlugin.js | 8 +- .../faultManagement/FaultManagementSearch.vue | 2 +- .../faultManagement/FaultManagementView.vue | 2 +- .../FaultManagementViewProvider.js | 2 +- src/plugins/faultManagement/pluginSpec.js | 4 +- src/plugins/filters/plugin.js | 2 +- .../components/FlexibleLayout.vue | 4 +- src/plugins/flexibleLayout/plugin.js | 6 +- src/plugins/flexibleLayout/pluginSpec.js | 2 +- .../folderView/components/GridItem.vue | 6 +- .../folderView/components/GridView.vue | 2 +- .../folderView/components/ListItem.vue | 6 +- .../folderView/components/ListView.vue | 2 +- src/plugins/folderView/plugin.js | 4 +- src/plugins/formActions/CreateAction.js | 4 +- src/plugins/formActions/CreateActionSpec.js | 2 +- .../formActions/EditPropertiesAction.js | 4 +- src/plugins/formActions/plugin.js | 2 +- src/plugins/gauge/GaugePlugin.js | 4 +- .../gauge/components/GaugeComponent.vue | 4 +- src/plugins/goToOriginalAction/plugin.js | 2 +- src/plugins/hyperlink/plugin.js | 2 +- src/plugins/hyperlink/pluginSpec.js | 2 +- src/plugins/imagery/ImageryViewProvider.js | 2 +- .../imagery/components/AnnotationsCanvas.vue | 2 +- .../components/Compass/CompassComponent.vue | 2 +- .../imagery/components/Compass/CompassHud.vue | 2 +- .../components/Compass/CompassRose.vue | 2 +- .../imagery/components/ImageryTimeView.vue | 2 +- .../imagery/components/ImageryView.vue | 8 +- src/plugins/imagery/mixins/imageryData.js | 2 +- src/plugins/imagery/plugin.js | 4 +- src/plugins/importFromJSONAction/plugin.js | 2 +- .../NumericDataInspectorView.vue | 2 +- .../inspectorDataVisualization/plugin.js | 2 +- .../annotations/tags/TagEditor.vue | 2 +- .../annotations/tags/TagSelection.vue | 2 +- .../elements/PlotElementsPool.vue | 2 +- src/plugins/inspectorViews/plugin.js | 10 +- .../inspectorViews/styles/FontStyleEditor.vue | 2 +- .../styles/StylesInspectorViewProvider.js | 2 +- src/plugins/interceptors/plugin.js | 2 +- src/plugins/interceptors/pluginSpec.js | 2 +- src/plugins/latestDataClock/LADClock.js | 2 +- src/plugins/latestDataClock/plugin.js | 2 +- src/plugins/linkAction/plugin.js | 2 +- .../LocalStorageObjectProvider.js | 2 +- src/plugins/localStorage/plugin.js | 2 +- src/plugins/localTimeSystem/plugin.js | 4 +- src/plugins/move/plugin.js | 2 +- src/plugins/myItems/myItemsInterceptor.js | 2 +- src/plugins/myItems/plugin.js | 4 +- src/plugins/myItems/pluginSpec.js | 2 +- src/plugins/newFolderAction/plugin.js | 2 +- src/plugins/notebook/NotebookType.js | 2 +- .../notebook/actions/CopyToNotebookAction.js | 4 +- .../actions/ExportNotebookAsTextAction.js | 2 +- .../notebook/components/NotebookComponent.vue | 10 +- .../notebook/components/NotebookEmbed.vue | 12 +- .../notebook/components/NotebookEntry.vue | 4 +- .../components/NotebookMenuSwitcher.vue | 8 +- .../components/NotebookSnapshotContainer.vue | 6 +- .../components/NotebookSnapshotIndicator.vue | 4 +- .../notebook/components/PageCollection.vue | 4 +- .../notebook/components/PageComponent.vue | 4 +- .../notebook/components/SectionCollection.vue | 4 +- .../notebook/components/SectionComponent.vue | 4 +- .../monkeyPatchObjectAPIForNotebooks.js | 6 +- src/plugins/notebook/plugin.js | 14 +- src/plugins/notebook/pluginSpec.js | 2 +- src/plugins/notebook/snapshot-container.js | 2 +- src/plugins/notebook/snapshot.js | 10 +- .../notebook/utils/notebook-entries.js | 4 +- .../notebook/utils/notebook-entriesSpec.js | 2 +- .../notebook/utils/notebook-migration.js | 4 +- .../notebook/utils/notebook-snapshot-menu.js | 2 +- .../notebook/utils/notebook-storageSpec.js | 2 +- .../notebook/utils/painterroInstance.js | 2 +- .../openInNewTabAction/openInNewTabAction.js | 2 +- src/plugins/openInNewTabAction/plugin.js | 2 +- .../operatorStatus/OperatorStatusIndicator.js | 2 +- src/plugins/operatorStatus/plugin.js | 4 +- .../pollQuestion/PollQuestionIndicator.js | 2 +- .../persistence/couch/CouchObjectProvider.js | 6 +- src/plugins/persistence/couch/plugin.js | 6 +- src/plugins/persistence/couch/pluginSpec.js | 2 +- src/plugins/plan/components/PlanView.vue | 4 +- .../components/PlanViewConfiguration.vue | 2 +- src/plugins/plan/plugin.js | 10 +- src/plugins/plan/pluginSpec.js | 2 +- src/plugins/plot/MctPlot.vue | 10 +- src/plugins/plot/MctTicks.vue | 6 +- src/plugins/plot/PlotView.vue | 4 +- src/plugins/plot/axis/XAxis.vue | 4 +- src/plugins/plot/axis/YAxis.vue | 4 +- src/plugins/plot/chart/LimitLabel.vue | 2 +- src/plugins/plot/chart/LimitLine.vue | 2 +- .../plot/chart/MCTChartAlarmLineSet.js | 2 +- .../plot/chart/MCTChartAlarmPointSet.js | 2 +- src/plugins/plot/chart/MCTChartLineLinear.js | 2 +- .../plot/chart/MCTChartLineStepAfter.js | 2 +- src/plugins/plot/chart/MCTChartPointSet.js | 2 +- .../plot/chart/MCTChartSeriesElement.js | 2 +- src/plugins/plot/chart/MctChart.vue | 18 +-- src/plugins/plot/configuration/Collection.js | 2 +- src/plugins/plot/configuration/LegendModel.js | 2 +- src/plugins/plot/configuration/Model.js | 2 +- .../configuration/PlotConfigurationModel.js | 10 +- src/plugins/plot/configuration/PlotSeries.js | 8 +- .../plot/configuration/SeriesCollection.js | 4 +- src/plugins/plot/configuration/XAxisModel.js | 2 +- src/plugins/plot/configuration/YAxisModel.js | 4 +- src/plugins/plot/draw/Draw2D.js | 4 +- src/plugins/plot/draw/DrawLoader.js | 4 +- src/plugins/plot/draw/DrawWebGL.js | 4 +- .../plot/inspector/PlotOptionsBrowse.vue | 4 +- .../plot/inspector/PlotOptionsEdit.vue | 4 +- .../plot/inspector/forms/LegendForm.vue | 2 +- .../plot/inspector/forms/SeriesForm.vue | 4 +- .../plot/inspector/forms/YAxisForm.vue | 6 +- src/plugins/plot/legend/PlotLegend.vue | 4 +- .../plot/legend/PlotLegendItemCollapsed.vue | 6 +- .../plot/legend/PlotLegendItemExpanded.vue | 4 +- src/plugins/plot/overlayPlot/pluginSpec.js | 4 +- src/plugins/plot/plugin.js | 18 +-- src/plugins/plot/pluginSpec.js | 6 +- src/plugins/plot/stackedPlot/StackedPlot.vue | 8 +- .../plot/stackedPlot/StackedPlotItem.vue | 2 +- src/plugins/plot/stackedPlot/pluginSpec.js | 6 +- src/plugins/plot/tickUtils.js | 2 +- src/plugins/plugins.js | 128 +++++++++--------- src/plugins/remoteClock/RemoteClock.js | 4 +- src/plugins/remoteClock/plugin.js | 2 +- src/plugins/remove/plugin.js | 2 +- .../StaticModelProviderSpec.js | 2 +- src/plugins/staticRootPlugin/plugin.js | 2 +- src/plugins/summaryWidget/plugin.js | 8 +- src/plugins/summaryWidget/src/Condition.js | 10 +- .../summaryWidget/src/ConditionManager.js | 2 +- src/plugins/summaryWidget/src/Rule.js | 10 +- .../summaryWidget/src/SummaryWidget.js | 12 +- src/plugins/summaryWidget/src/TestDataItem.js | 8 +- .../summaryWidget/src/TestDataManager.js | 6 +- src/plugins/summaryWidget/src/WidgetDnD.js | 2 +- .../summaryWidget/src/input/ColorPalette.js | 2 +- .../summaryWidget/src/input/IconPalette.js | 2 +- .../summaryWidget/src/input/KeySelect.js | 2 +- .../summaryWidget/src/input/ObjectSelect.js | 2 +- .../src/input/OperationSelect.js | 4 +- .../summaryWidget/src/input/Palette.js | 4 +- src/plugins/summaryWidget/src/input/Select.js | 4 +- .../src/telemetry/EvaluatorPool.js | 2 +- .../src/telemetry/EvaluatorPoolSpec.js | 2 +- .../src/telemetry/SummaryWidgetCondition.js | 2 +- .../telemetry/SummaryWidgetConditionSpec.js | 2 +- .../src/telemetry/SummaryWidgetEvaluator.js | 4 +- .../src/telemetry/SummaryWidgetRule.js | 2 +- .../src/telemetry/SummaryWidgetRuleSpec.js | 2 +- .../SummaryWidgetTelemetryProvider.js | 2 +- .../SummaryWidgetTelemetryProviderSpec.js | 2 +- .../src/views/SummaryWidgetViewProvider.js | 4 +- .../test/ConditionEvaluatorSpec.js | 2 +- .../test/ConditionManagerSpec.js | 2 +- .../summaryWidget/test/ConditionSpec.js | 2 +- src/plugins/summaryWidget/test/RuleSpec.js | 2 +- .../summaryWidget/test/SummaryWidgetSpec.js | 2 +- .../test/SummaryWidgetViewPolicySpec.js | 2 +- .../summaryWidget/test/TestDataItemSpec.js | 2 +- .../summaryWidget/test/TestDataManagerSpec.js | 2 +- .../test/input/ColorPaletteSpec.js | 2 +- .../test/input/IconPaletteSpec.js | 2 +- .../summaryWidget/test/input/KeySelectSpec.js | 2 +- .../test/input/ObjectSelectSpec.js | 2 +- .../test/input/OperationSelectSpec.js | 2 +- .../summaryWidget/test/input/PaletteSpec.js | 2 +- .../summaryWidget/test/input/SelectSpec.js | 2 +- src/plugins/tabs/components/TabsComponent.vue | 2 +- src/plugins/tabs/plugin.js | 2 +- src/plugins/tabs/pluginSpec.js | 2 +- src/plugins/telemetryMean/plugin.js | 2 +- .../src/MeanTelemetryProvider.js | 2 +- .../src/MeanTelemetryProviderSpec.js | 4 +- .../TableConfigurationViewProvider.js | 2 +- src/plugins/telemetryTable/TelemetryTable.js | 14 +- .../TelemetryTableNameColumn.js | 2 +- .../telemetryTable/TelemetryTableView.js | 2 +- .../TelemetryTableViewProvider.js | 2 +- .../telemetryTable/components/TableCell.vue | 2 +- .../components/TableConfiguration.vue | 4 +- src/plugins/telemetryTable/plugin.js | 8 +- src/plugins/themes/espresso.js | 2 +- src/plugins/themes/snow.js | 2 +- src/plugins/timeConductor/ConductorAxis.vue | 2 +- src/plugins/timeConductor/ConductorClock.vue | 4 +- .../timeConductor/ConductorComponent.vue | 4 +- .../timeConductor/ConductorHistory.vue | 2 +- .../timeConductor/ConductorInputsFixed.vue | 2 +- .../timeConductor/ConductorInputsRealtime.vue | 2 +- src/plugins/timeConductor/ConductorMode.vue | 2 +- src/plugins/timeConductor/ConductorPopUp.vue | 2 +- .../timeConductor/ConductorTimeSystem.vue | 2 +- src/plugins/timeConductor/DatePicker.vue | 2 +- .../independent/IndependentClock.vue | 6 +- .../independent/IndependentMode.vue | 4 +- .../independent/IndependentTimeConductor.vue | 4 +- src/plugins/timeConductor/mode-mixin.js | 2 +- src/plugins/timeConductor/plugin.js | 2 +- src/plugins/timeConductor/pluginSpec.js | 6 +- src/plugins/timeline/TimelineViewLayout.vue | 2 +- src/plugins/timeline/plugin.js | 6 +- src/plugins/timeline/pluginSpec.js | 2 +- src/plugins/timelist/TimelistComponent.vue | 8 +- src/plugins/timelist/TimelistViewProvider.js | 2 +- .../TimeListInspectorViewProvider.js | 2 +- .../inspector/TimelistPropertiesView.vue | 2 +- src/plugins/timelist/plugin.js | 6 +- src/plugins/timelist/pluginSpec.js | 6 +- .../timer/components/TimerComponent.vue | 2 +- src/plugins/timer/plugin.js | 10 +- src/plugins/timer/pluginSpec.js | 2 +- .../components/UserIndicator.vue | 2 +- src/plugins/userIndicator/pluginSpec.js | 2 +- src/plugins/utcTimeSystem/LocalClock.js | 2 +- src/plugins/utcTimeSystem/plugin.js | 8 +- src/plugins/utcTimeSystem/pluginSpec.js | 2 +- src/plugins/webPage/pluginSpec.js | 2 +- src/tools/urlSpec.js | 4 +- src/ui/color/ColorPalette.js | 4 +- src/ui/color/ColorSwatch.vue | 2 +- src/ui/components/ContextMenuDropDown.vue | 2 +- src/ui/components/ObjectFrame.vue | 2 +- src/ui/components/ObjectLabel.vue | 6 +- src/ui/components/ObjectView.vue | 2 +- src/ui/components/swim-lane/SwimLane.vue | 2 +- src/ui/inspector/InspectorStylesSpec.js | 4 +- src/ui/layout/BrowseBar.vue | 2 +- src/ui/layout/RecentObjectsListItem.vue | 4 +- .../layout/search/AnnotationSearchResult.vue | 4 +- src/ui/layout/search/GrandSearchSpec.js | 4 +- src/ui/layout/search/ObjectSearchResult.vue | 6 +- src/ui/mixins/object-link.js | 2 +- src/ui/preview/ViewHistoricalDataAction.js | 2 +- src/ui/preview/plugin.js | 2 +- .../toolbar/components/ToolbarColorPicker.vue | 2 +- src/ui/toolbar/components/ToolbarMenu.vue | 2 +- .../toolbar/components/ToolbarSelectMenu.vue | 2 +- src/utils/agent/AgentSpec.js | 2 +- src/utils/rafSpec.js | 2 +- src/utils/useEventBus.js | 2 +- 485 files changed, 1220 insertions(+), 1190 deletions(-) rename .eslintrc.js => .eslintrc.cjs (100%) rename e2e/{.eslintrc.js => .eslintrc.cjs} (100%) rename index-test.js => index-test.cjs (100%) rename karma.conf.js => karma.conf.cjs (92%) diff --git a/.eslintrc.js b/.eslintrc.cjs similarity index 100% rename from .eslintrc.js rename to .eslintrc.cjs diff --git a/.webpack/webpack.common.js b/.webpack/webpack.common.js index c7192823bb..cf729868ef 100644 --- a/.webpack/webpack.common.js +++ b/.webpack/webpack.common.js @@ -1,5 +1,3 @@ -/* global __dirname module */ - /* This is the OpenMCT common webpack file. It is imported by the other three webpack configurations: - webpack.prod.js - the production configuration for OpenMCT (default) @@ -8,27 +6,30 @@ This is the OpenMCT common webpack file. It is imported by the other three webpa There are separate npm scripts to use these configurations, though simply running `npm install` will use the default production configuration. */ -const path = require('path'); -const packageDefinition = require('../package.json'); -const CopyWebpackPlugin = require('copy-webpack-plugin'); -const webpack = require('webpack'); -const MiniCssExtractPlugin = require('mini-css-extract-plugin'); +import path from 'node:path'; +import CopyWebpackPlugin from 'copy-webpack-plugin'; +import webpack from 'webpack'; +import MiniCssExtractPlugin from 'mini-css-extract-plugin'; +import fs from 'node:fs'; +import { execSync } from 'node:child_process'; +import { fileURLToPath } from 'node:url'; -const { VueLoaderPlugin } = require('vue-loader'); +import { VueLoaderPlugin } from 'vue-loader'; let gitRevision = 'error-retrieving-revision'; let gitBranch = 'error-retrieving-branch'; +const packageDefinition = JSON.parse(fs.readFileSync(new URL('../package.json', import.meta.url))); + try { - gitRevision = require('child_process').execSync('git rev-parse HEAD').toString().trim(); - gitBranch = require('child_process') - .execSync('git rev-parse --abbrev-ref HEAD') + gitRevision = execSync('git rev-parse HEAD').toString().trim(); + gitBranch = execSync('git rev-parse --abbrev-ref HEAD') .toString() .trim(); } catch (err) { console.warn(err); } -const projectRootDir = path.resolve(__dirname, '..'); +const projectRootDir = fileURLToPath(new URL('../', import.meta.url)); /** @type {import('webpack').Configuration} */ const config = { @@ -56,6 +57,7 @@ const config = { filename: '[name].js', path: path.resolve(projectRootDir, 'dist'), library: 'openmct', + libraryExport: 'default', libraryTarget: 'umd', publicPath: '', hashFunction: 'xxhash64', @@ -183,4 +185,4 @@ const config = { } }; -module.exports = config; +export default config; diff --git a/.webpack/webpack.coverage.js b/.webpack/webpack.coverage.js index 5cfb1c059d..14d11fe7bc 100644 --- a/.webpack/webpack.coverage.js +++ b/.webpack/webpack.coverage.js @@ -1,12 +1,10 @@ -/* global module */ - /* This file extends the webpack.dev.js config to add babel istanbul coverage. OpenMCT Continuous Integration servers use this configuration to add code coverage information to pull requests. */ -const config = require('./webpack.dev'); +import config from './webpack.dev.js'; // eslint-disable-next-line no-undef const CI = process.env.CI === 'true'; @@ -34,4 +32,4 @@ config.module.rules.push({ } }); -module.exports = config; +export default config; diff --git a/.webpack/webpack.dev.js b/.webpack/webpack.dev.js index 95c5dc5271..3d18812e97 100644 --- a/.webpack/webpack.dev.js +++ b/.webpack/webpack.dev.js @@ -1,18 +1,16 @@ -/* global __dirname module */ - /* This configuration should be used for development purposes. It contains full source map, a devServer (which be invoked using by `npm start`), and a non-minified Vue.js distribution. If OpenMCT is to be used for a production server, use webpack.prod.js instead. */ -const path = require('path'); -const webpack = require('webpack'); -const { merge } = require('webpack-merge'); +import path from 'path'; +import webpack from 'webpack'; +import { merge } from 'webpack-merge'; +import { fileURLToPath } from 'node:url'; -const common = require('./webpack.common'); -const projectRootDir = path.resolve(__dirname, '..'); +import common from './webpack.common.js'; -module.exports = merge(common, { +export default merge(common, { mode: 'development', watchOptions: { // Since we use require.context, webpack is watching the entire directory. @@ -42,7 +40,7 @@ module.exports = merge(common, { }, watchFiles: ['**/*.css'], static: { - directory: path.join(__dirname, '..', '/dist'), + directory: fileURLToPath(new URL('../dist', import.meta.url)), publicPath: '/dist', watch: false } diff --git a/.webpack/webpack.prod.js b/.webpack/webpack.prod.js index 73d7fad260..9224625a12 100644 --- a/.webpack/webpack.prod.js +++ b/.webpack/webpack.prod.js @@ -1,17 +1,14 @@ -/* global __dirname module */ - /* This configuration should be used for production installs. It is the default webpack configuration. */ -const path = require('path'); -const webpack = require('webpack'); -const { merge } = require('webpack-merge'); -const common = require('./webpack.common'); -const projectRootDir = path.resolve(__dirname, '..'); +import webpack from 'webpack'; +import { merge } from 'webpack-merge'; -module.exports = merge(common, { +import common from './webpack.common.js'; + +export default merge(common, { mode: 'production', plugins: [ new webpack.DefinePlugin({ diff --git a/e2e/.eslintrc.js b/e2e/.eslintrc.cjs similarity index 100% rename from e2e/.eslintrc.js rename to e2e/.eslintrc.cjs diff --git a/e2e/README.md b/e2e/README.md index e7f53ca7a5..bd56c6448f 100644 --- a/e2e/README.md +++ b/e2e/README.md @@ -480,7 +480,7 @@ The following contains a list of tips and tricks which don't exactly fit into a It is possible to override the browser's clock in order to control time-based elements. Since this can cause unwanted behavior (i.e. Tree not rendering), only use this sparingly. To do this, use the `overrideClock` fixture as such: ```js -const { test, expect } = require('../../pluginFixtures.js'); +import { test, expect } from '../../pluginFixtures.js'; test.describe('foo test suite', () => { diff --git a/e2e/appActions.js b/e2e/appActions.js index f2940208c5..f1dd43349f 100644 --- a/e2e/appActions.js +++ b/e2e/appActions.js @@ -54,9 +54,9 @@ * @property {import('../src/api/notifications/NotificationAPI').NotificationOptions} [notificationOptions] additional options */ -const Buffer = require('buffer').Buffer; -const genUuid = require('uuid').v4; -const { expect } = require('@playwright/test'); +import { expect } from '@playwright/test'; +import { Buffer } from 'buffer'; +import { v4 as genUuid } from 'uuid'; /** * This common function creates a domain object with the default options. It is the preferred way of creating objects @@ -644,8 +644,7 @@ async function renameObjectFromContextMenu(page, url, newName) { await page.click('[aria-label="Save"]'); } -// eslint-disable-next-line no-undef -module.exports = { +export { createDomainObjectWithDefaults, createExampleTelemetryObject, createNotification, @@ -653,16 +652,16 @@ module.exports = { expandEntireTree, expandTreePaneItemByName, getCanvasPixels, - getHashUrlToDomainObject, getFocusedObjectUuid, + getHashUrlToDomainObject, navigateToObjectWithFixedTimeBounds, openObjectTreeContextMenu, + renameObjectFromContextMenu, + setEndOffset, setFixedTimeMode, + setIndependentTimeConductorBounds, setRealTimeMode, setStartOffset, - setEndOffset, setTimeConductorBounds, - setIndependentTimeConductorBounds, - waitForPlotsToRender, - renameObjectFromContextMenu + waitForPlotsToRender }; diff --git a/e2e/avpFixtures.js b/e2e/avpFixtures.js index fb99b94347..96f018cc7e 100644 --- a/e2e/avpFixtures.js +++ b/e2e/avpFixtures.js @@ -33,10 +33,11 @@ * existing ones. */ -const fs = require('fs'); -const path = require('path'); -const { test, expect } = require('./pluginFixtures'); -const AxeBuilder = require('@axe-core/playwright').default; +import AxeBuilder from '@axe-core/playwright'; +import fs from 'fs'; +import path from 'path'; + +import { expect, test } from './pluginFixtures.js'; // Constants for repeated values const TEST_RESULTS_DIR = './test-results'; @@ -56,7 +57,7 @@ const TEST_RESULTS_DIR = './test-results'; * otherwise returns null. */ /* eslint-disable no-undef */ -exports.scanForA11yViolations = async function (page, testCaseName, options = {}) { +export async function scanForA11yViolations(page, testCaseName, options = {}) { const builder = new AxeBuilder({ page }); builder.withTags(['wcag2aa']); // https://github.com/dequelabs/axe-core/blob/develop/doc/rule-descriptions.md @@ -91,7 +92,6 @@ exports.scanForA11yViolations = async function (page, testCaseName, options = {} console.log('No accessibility violations found, no report generated.'); return null; } -}; +} -exports.expect = expect; -exports.test = test; +export { expect, test }; diff --git a/e2e/baseFixtures.js b/e2e/baseFixtures.js index d35a8152dc..7727de3c83 100644 --- a/e2e/baseFixtures.js +++ b/e2e/baseFixtures.js @@ -28,12 +28,12 @@ * GitHub issues. */ -const base = require('@playwright/test'); -const { expect, request } = base; -const fs = require('fs'); -const path = require('path'); -const { v4: uuid } = require('uuid'); -const sinon = require('sinon'); +import { expect, request, test } from '@playwright/test'; +import fs from 'fs'; +import path from 'path'; +import sinon from 'sinon'; +import { fileURLToPath } from 'url'; +import { v4 as uuid } from 'uuid'; /** * Takes a `ConsoleMessage` and returns a formatted string. Used to enable console log error detection. @@ -68,7 +68,7 @@ function waitForAnimations(locator) { */ const istanbulCLIOutput = path.join(process.cwd(), '.nyc_output'); -exports.test = base.test.extend({ +const extendedTest = test.extend({ /** * This allows the test to manipulate the browser clock. This is useful for Visual and Snapshot tests which need * the Time Indicator Clock to be in a specific state. @@ -97,7 +97,7 @@ exports.test = base.test.extend({ async ({ context, clockOptions }, use) => { if (clockOptions !== undefined) { await context.addInitScript({ - path: path.join(__dirname, '../', './node_modules/sinon/pkg/sinon.js') + path: fileURLToPath(new URL('../node_modules/sinon/pkg/sinon.js', import.meta.url)) }); await context.addInitScript((options) => { window.__clock = sinon.useFakeTimers(options); @@ -201,6 +201,4 @@ exports.test = base.test.extend({ } }); -exports.expect = expect; -exports.request = request; -exports.waitForAnimations = waitForAnimations; +export { expect, request, extendedTest as test, waitForAnimations }; diff --git a/e2e/helper/faultUtils.js b/e2e/helper/faultUtils.js index b5cd150478..ae09353f17 100644 --- a/e2e/helper/faultUtils.js +++ b/e2e/helper/faultUtils.js @@ -19,14 +19,15 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ -const path = require('path'); +import { fileURLToPath } from 'url'; /** * @param {import('@playwright/test').Page} page */ async function navigateToFaultManagementWithExample(page) { - await page.addInitScript({ path: path.join(__dirname, './', 'addInitExampleFaultProvider.js') }); + await page.addInitScript({ + path: fileURLToPath(new URL('./addInitExampleFaultProvider.js', import.meta.url)) + }); await navigateToFaultItemInTree(page); } @@ -36,7 +37,7 @@ async function navigateToFaultManagementWithExample(page) { */ async function navigateToFaultManagementWithStaticExample(page) { await page.addInitScript({ - path: path.join(__dirname, './', 'addInitExampleFaultProviderStatic.js') + path: fileURLToPath(new URL('./addInitExampleFaultProviderStatic.js', import.meta.url)) }); await navigateToFaultItemInTree(page); @@ -46,7 +47,9 @@ async function navigateToFaultManagementWithStaticExample(page) { * @param {import('@playwright/test').Page} page */ async function navigateToFaultManagementWithoutExample(page) { - await page.addInitScript({ path: path.join(__dirname, './', 'addInitFaultManagementPlugin.js') }); + await page.addInitScript({ + path: fileURLToPath(new URL('./addInitFaultManagementPlugin.js', import.meta.url)) + }); await navigateToFaultItemInTree(page); } @@ -265,29 +268,28 @@ async function openFaultRowMenu(page, rowNumber) { .click(); } -// eslint-disable-next-line no-undef -module.exports = { - navigateToFaultManagementWithExample, - navigateToFaultManagementWithStaticExample, - navigateToFaultManagementWithoutExample, - navigateToFaultItemInTree, +export { acknowledgeFault, - shelveMultipleFaults, acknowledgeMultipleFaults, - shelveFault, changeViewTo, - sortFaultsBy, - enterSearchTerm, clearSearch, - selectFaultItem, - getHighestSeverity, - getLowestSeverity, - getFaultResultCount, + enterSearchTerm, getFault, getFaultByName, getFaultName, - getFaultSeverity, getFaultNamespace, + getFaultResultCount, + getFaultSeverity, getFaultTriggerTime, - openFaultRowMenu + getHighestSeverity, + getLowestSeverity, + navigateToFaultItemInTree, + navigateToFaultManagementWithExample, + navigateToFaultManagementWithoutExample, + navigateToFaultManagementWithStaticExample, + openFaultRowMenu, + selectFaultItem, + shelveFault, + shelveMultipleFaults, + sortFaultsBy }; diff --git a/e2e/helper/notebookUtils.js b/e2e/helper/notebookUtils.js index 75571f8966..6bd12e3d7d 100644 --- a/e2e/helper/notebookUtils.js +++ b/e2e/helper/notebookUtils.js @@ -20,11 +20,11 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { createDomainObjectWithDefaults } = require('../appActions'); +import { createDomainObjectWithDefaults } from '../appActions.js'; const NOTEBOOK_DROP_AREA = '.c-notebook__drag-area'; const CUSTOM_NAME = 'CUSTOM_NAME'; -const path = require('path'); +import { fileURLToPath } from 'url'; /** * @param {import('@playwright/test').Page} page @@ -69,7 +69,9 @@ async function commitEntry(page) { */ async function startAndAddRestrictedNotebookObject(page) { // eslint-disable-next-line no-undef - await page.addInitScript({ path: path.join(__dirname, 'addInitRestrictedNotebook.js') }); + await page.addInitScript({ + path: fileURLToPath(new URL('./addInitRestrictedNotebook.js', import.meta.url)) + }); await page.goto('./', { waitUntil: 'domcontentloaded' }); return createDomainObjectWithDefaults(page, { @@ -138,12 +140,11 @@ async function createNotebookEntryAndTags(page, iterations = 1) { return notebook; } -// eslint-disable-next-line no-undef -module.exports = { - enterTextEntry, - dragAndDropEmbed, - startAndAddRestrictedNotebookObject, - lockPage, +export { + createNotebookAndEntry, createNotebookEntryAndTags, - createNotebookAndEntry + dragAndDropEmbed, + enterTextEntry, + lockPage, + startAndAddRestrictedNotebookObject }; diff --git a/e2e/helper/planningUtils.js b/e2e/helper/planningUtils.js index ce725df63a..e7ad8799a4 100644 --- a/e2e/helper/planningUtils.js +++ b/e2e/helper/planningUtils.js @@ -20,7 +20,7 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import { expect } from '../pluginFixtures'; +import { expect } from '../pluginFixtures.js'; /** * Asserts that the number of activities in the plan view matches the number of diff --git a/e2e/helper/plotTagsUtils.js b/e2e/helper/plotTagsUtils.js index 0d84815eff..1de3fb355a 100644 --- a/e2e/helper/plotTagsUtils.js +++ b/e2e/helper/plotTagsUtils.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import { expect } from '../pluginFixtures'; -const { waitForPlotsToRender } = require('../appActions'); +import { waitForPlotsToRender } from '../appActions.js'; +import { expect } from '../pluginFixtures.js'; /** * Given a canvas and a set of points, tags the points on the canvas. diff --git a/e2e/playwright-ci.config.js b/e2e/playwright-ci.config.js index 56708efe63..87e5510af5 100644 --- a/e2e/playwright-ci.config.js +++ b/e2e/playwright-ci.config.js @@ -1,9 +1,8 @@ -/* eslint-disable no-undef */ // playwright.config.js // @ts-check // eslint-disable-next-line no-unused-vars -const { devices } = require('@playwright/test'); +import { devices } from '@playwright/test'; const MAX_FAILURES = 5; const NUM_WORKERS = 2; @@ -81,4 +80,4 @@ const config = { ] }; -module.exports = config; +export default config; diff --git a/e2e/playwright-local.config.js b/e2e/playwright-local.config.js index f3020ca0e3..c90dd17496 100644 --- a/e2e/playwright-local.config.js +++ b/e2e/playwright-local.config.js @@ -1,9 +1,8 @@ -/* eslint-disable no-undef */ // playwright.config.js // @ts-check // eslint-disable-next-line no-unused-vars -const { devices } = require('@playwright/test'); +import { devices } from '@playwright/test'; /** @type {import('@playwright/test').PlaywrightTestConfig} */ const config = { @@ -104,4 +103,4 @@ const config = { ] }; -module.exports = config; +export default config; diff --git a/e2e/playwright-performance-dev.config.js b/e2e/playwright-performance-dev.config.js index f437b11a97..a10c350e80 100644 --- a/e2e/playwright-performance-dev.config.js +++ b/e2e/playwright-performance-dev.config.js @@ -1,4 +1,3 @@ -/* eslint-disable no-undef */ // playwright.config.js // @ts-check @@ -40,4 +39,4 @@ const config = { ] }; -module.exports = config; +export default config; diff --git a/e2e/playwright-performance-prod.config.js b/e2e/playwright-performance-prod.config.js index c9326356d9..92976fb48e 100644 --- a/e2e/playwright-performance-prod.config.js +++ b/e2e/playwright-performance-prod.config.js @@ -1,4 +1,3 @@ -/* eslint-disable no-undef */ // playwright.config.js // @ts-check @@ -57,4 +56,4 @@ const config = { ] }; -module.exports = config; +export default config; diff --git a/e2e/playwright-visual-a11y.config.js b/e2e/playwright-visual-a11y.config.js index baa1230c17..e0f6810f98 100644 --- a/e2e/playwright-visual-a11y.config.js +++ b/e2e/playwright-visual-a11y.config.js @@ -51,4 +51,4 @@ const config = { ] }; -module.exports = config; +export default config; diff --git a/e2e/playwright-watch.config.js b/e2e/playwright-watch.config.js index d219d02ff1..4700f8486e 100644 --- a/e2e/playwright-watch.config.js +++ b/e2e/playwright-watch.config.js @@ -1,9 +1,8 @@ -/* eslint-disable no-undef */ // playwright.config.js // @ts-check // eslint-disable-next-line no-unused-vars -const { devices } = require('@playwright/test'); +import { devices } from '@playwright/test'; const MAX_FAILURES = 5; const NUM_WORKERS = 2; @@ -51,4 +50,4 @@ const config = { ] }; -module.exports = config; +export default config; diff --git a/e2e/pluginFixtures.js b/e2e/pluginFixtures.js index 3fbb882af0..ab5978641a 100644 --- a/e2e/pluginFixtures.js +++ b/e2e/pluginFixtures.js @@ -26,9 +26,10 @@ * and appActions. These fixtures should be generalized across all plugins. */ -const { test, expect, request } = require('./baseFixtures'); -// const { createDomainObjectWithDefaults } = require('./appActions'); -const path = require('path'); +// import { createDomainObjectWithDefaults } from './appActions.js'; +import { fileURLToPath } from 'url'; + +import { expect, request, test } from './baseFixtures.js'; /** * @typedef {Object} ObjectCreateOptions @@ -117,7 +118,7 @@ const theme = 'espresso'; */ const myItemsFolderName = 'My Items'; -exports.test = test.extend({ +const extendedTest = test.extend({ // This should follow in the Project's configuration. Can be set to 'snow' in playwright config.js theme: [theme, { option: true }], // eslint-disable-next-line no-shadow @@ -125,7 +126,9 @@ exports.test = test.extend({ // eslint-disable-next-line playwright/no-conditional-in-test if (theme === 'snow') { //inject snow theme - await page.addInitScript({ path: path.join(__dirname, './helper', './useSnowTheme.js') }); + await page.addInitScript({ + path: fileURLToPath(new URL('./helper/useSnowTheme.js', import.meta.url)) + }); } // Attach info about the currently running test and its project. @@ -142,19 +145,18 @@ exports.test = test.extend({ } }); -exports.expect = expect; -exports.request = request; +export { expect, request, extendedTest as test }; /** * Takes a readable stream and returns a string. * @param {ReadableStream} readable - the readable stream * @return {Promise} the stringified stream */ -exports.streamToString = async function (readable) { +export async function streamToString(readable) { let result = ''; for await (const chunk of readable) { result += chunk; } return result; -}; +} diff --git a/e2e/tests/framework/appActions.e2e.spec.js b/e2e/tests/framework/appActions.e2e.spec.js index cbdba6a4e7..08759b5f71 100644 --- a/e2e/tests/framework/appActions.e2e.spec.js +++ b/e2e/tests/framework/appActions.e2e.spec.js @@ -20,12 +20,12 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../pluginFixtures.js'); -const { +import { createDomainObjectWithDefaults, createNotification, expandEntireTree -} = require('../../appActions.js'); +} from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('AppActions', () => { test('createDomainObjectsWithDefaults', async ({ page }) => { diff --git a/e2e/tests/framework/baseFixtures.e2e.spec.js b/e2e/tests/framework/baseFixtures.e2e.spec.js index ee8dc5a893..90ed0937ed 100644 --- a/e2e/tests/framework/baseFixtures.e2e.spec.js +++ b/e2e/tests/framework/baseFixtures.e2e.spec.js @@ -26,7 +26,7 @@ relates to how we've extended it (i.e. ./e2e/baseFixtures.js) and assumptions ma (`npm start` and ./e2e/webpack-dev-middleware.js) */ -const { test } = require('../../baseFixtures.js'); +import { test } from '../../baseFixtures.js'; test.describe('baseFixtures tests', () => { //Skip this test for now https://github.com/nasa/openmct/issues/6785 diff --git a/e2e/tests/framework/exampleTemplate.e2e.spec.js b/e2e/tests/framework/exampleTemplate.e2e.spec.js index 7435f861a4..b12494751d 100644 --- a/e2e/tests/framework/exampleTemplate.e2e.spec.js +++ b/e2e/tests/framework/exampleTemplate.e2e.spec.js @@ -45,8 +45,8 @@ */ // Structure: Some standard Imports. Please update the required pathing. -const { test, expect } = require('../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../appActions'); +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; /** * Structure: diff --git a/e2e/tests/framework/generateLocalStorageData.e2e.spec.js b/e2e/tests/framework/generateLocalStorageData.e2e.spec.js index 62de8b44e6..03395c4d29 100644 --- a/e2e/tests/framework/generateLocalStorageData.e2e.spec.js +++ b/e2e/tests/framework/generateLocalStorageData.e2e.spec.js @@ -19,7 +19,6 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ /** * This test suite is dedicated to generating LocalStorage via Session Storage to be used * in some visual test suites like controlledClock.visual.spec.js. This suite should run to completion @@ -32,13 +31,11 @@ * and is additionally verified in the validation test suites below. */ -const { test, expect } = require('../../pluginFixtures.js'); -const { - createDomainObjectWithDefaults, - createExampleTelemetryObject -} = require('../../appActions.js'); -const { MISSION_TIME } = require('../../constants.js'); -const path = require('path'); +import { fileURLToPath } from 'url'; + +import { createDomainObjectWithDefaults, createExampleTelemetryObject } from '../../appActions.js'; +import { MISSION_TIME } from '../../constants.js'; +import { expect, test } from '../../pluginFixtures.js'; const overlayPlotName = 'Overlay Plot with Telemetry Object'; @@ -87,7 +84,9 @@ test.describe('Generate Visual Test Data @localStorage @generatedata', () => { //Save localStorage for future test execution await context.storageState({ - path: path.join(__dirname, '../../../e2e/test-data/display_layout_with_child_layouts.json') + path: fileURLToPath( + new URL('../../../e2e/test-data/display_layout_with_child_layouts.json', import.meta.url) + ) }); }); @@ -112,7 +111,9 @@ test.describe('Generate Visual Test Data @localStorage @generatedata', () => { //Save localStorage for future test execution await context.storageState({ - path: path.join(__dirname, '../../../e2e/test-data/flexible_layout_with_child_layouts.json') + path: fileURLToPath( + new URL('../../../e2e/test-data/flexible_layout_with_child_layouts.json', import.meta.url) + ) }); }); @@ -189,7 +190,9 @@ test.describe('Generate Visual Test Data @localStorage @generatedata', () => { // Save localStorage for future test execution await context.storageState({ - path: path.join(__dirname, '../../../e2e/test-data/overlay_plot_storage.json') + path: fileURLToPath( + new URL('../../../e2e/test-data/overlay_plot_storage.json', import.meta.url) + ) }); }); // TODO: Merge this with previous test. Edit object created in previous test. @@ -226,14 +229,18 @@ test.describe('Generate Visual Test Data @localStorage @generatedata', () => { await page.getByRole('button', { name: 'OK' }).click(); //Save localStorage for future test execution await context.storageState({ - path: path.join(__dirname, '../../../e2e/test-data/overlay_plot_with_delay_storage.json') + path: fileURLToPath( + new URL('../../../e2e/test-data/overlay_plot_with_delay_storage.json', import.meta.url) + ) }); }); }); test.describe('Validate Overlay Plot with Telemetry Object @localStorage @generatedata', () => { test.use({ - storageState: path.join(__dirname, '../../../e2e/test-data/overlay_plot_storage.json') + storageState: fileURLToPath( + new URL('../../../e2e/test-data/overlay_plot_storage.json', import.meta.url) + ) }); test('Validate Overlay Plot with Telemetry Object', async ({ page }) => { await page.goto('./', { waitUntil: 'domcontentloaded' }); @@ -275,9 +282,8 @@ test.describe('Validate Overlay Plot with Telemetry Object @localStorage @genera test.describe('Validate Overlay Plot with 5s Delay Telemetry Object @localStorage @generatedata', () => { test.use({ - storageState: path.join( - __dirname, - '../../../e2e/test-data/overlay_plot_with_delay_storage.json' + storageState: fileURLToPath( + new URL('../../../e2e/test-data/overlay_plot_with_delay_storage.json', import.meta.url) ) }); test('Validate Overlay Plot with Telemetry Object', async ({ page }) => { diff --git a/e2e/tests/framework/pluginFixtures.e2e.spec.js b/e2e/tests/framework/pluginFixtures.e2e.spec.js index 837fdcd7fc..009a26471b 100644 --- a/e2e/tests/framework/pluginFixtures.e2e.spec.js +++ b/e2e/tests/framework/pluginFixtures.e2e.spec.js @@ -25,7 +25,7 @@ This test suite is dedicated to testing our use of our custom fixtures to verify that they are working as expected. */ -const { test } = require('../../pluginFixtures.js'); +import { test } from '../../pluginFixtures.js'; // eslint-disable-next-line playwright/no-skipped-test test.describe.skip('pluginFixtures tests', () => { diff --git a/e2e/tests/functional/branding.e2e.spec.js b/e2e/tests/functional/branding.e2e.spec.js index 588af99940..4da18d157b 100644 --- a/e2e/tests/functional/branding.e2e.spec.js +++ b/e2e/tests/functional/branding.e2e.spec.js @@ -24,7 +24,7 @@ This test suite is dedicated to tests which verify branding related components. */ -const { test, expect } = require('../../baseFixtures.js'); +import { expect, test } from '../../baseFixtures.js'; test.describe('Branding tests', () => { test('About Modal launches with basic branding properties', async ({ page }) => { diff --git a/e2e/tests/functional/clearDataAction.e2e.spec.js b/e2e/tests/functional/clearDataAction.e2e.spec.js index 366907013c..de568ce114 100644 --- a/e2e/tests/functional/clearDataAction.e2e.spec.js +++ b/e2e/tests/functional/clearDataAction.e2e.spec.js @@ -24,8 +24,8 @@ Verify that the "Clear Data" menu action performs as expected for various object types. */ -const { test, expect } = require('../../pluginFixtures.js'); -const { createDomainObjectWithDefaults } = require('../../appActions.js'); +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; const backgroundImageSelector = '.c-imagery__main-image__background-image'; diff --git a/e2e/tests/functional/couchdb.e2e.spec.js b/e2e/tests/functional/couchdb.e2e.spec.js index e24a34fe49..6c271e7f6e 100644 --- a/e2e/tests/functional/couchdb.e2e.spec.js +++ b/e2e/tests/functional/couchdb.e2e.spec.js @@ -25,7 +25,7 @@ * */ -const { test, expect } = require('../../pluginFixtures'); +import { expect, test } from '../../pluginFixtures.js'; test.describe('CouchDB Status Indicator with mocked responses @couchdb', () => { test.use({ failOnConsoleError: false }); diff --git a/e2e/tests/functional/example/eventGenerator.e2e.spec.js b/e2e/tests/functional/example/eventGenerator.e2e.spec.js index f36d88dfe6..be016907b2 100644 --- a/e2e/tests/functional/example/eventGenerator.e2e.spec.js +++ b/e2e/tests/functional/example/eventGenerator.e2e.spec.js @@ -24,8 +24,8 @@ This test suite is dedicated to tests which verify the basic operations surrounding the example event generator. */ -const { test, expect } = require('../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../appActions'); +import { createDomainObjectWithDefaults } from '../../../appActions.js'; +import { expect, test } from '../../../pluginFixtures.js'; test.describe('Example Event Generator CRUD Operations', () => { test('Can create a Test Event Generator and it results in the table View', async ({ page }) => { diff --git a/e2e/tests/functional/example/generator/sineWaveLimitProvider.e2e.spec.js b/e2e/tests/functional/example/generator/sineWaveLimitProvider.e2e.spec.js index e644d17a59..2a0548bcca 100644 --- a/e2e/tests/functional/example/generator/sineWaveLimitProvider.e2e.spec.js +++ b/e2e/tests/functional/example/generator/sineWaveLimitProvider.e2e.spec.js @@ -24,7 +24,7 @@ This test suite is dedicated to tests which verify the basic operations surrounding conditionSets. */ -const { test, expect } = require('../../../../baseFixtures'); +import { expect, test } from '../../../../baseFixtures.js'; test.describe('Sine Wave Generator', () => { test('Create new Sine Wave Generator Object and validate create Form Logic', async ({ diff --git a/e2e/tests/functional/forms.e2e.spec.js b/e2e/tests/functional/forms.e2e.spec.js index 4f3c2fd0f3..b25a7b9dca 100644 --- a/e2e/tests/functional/forms.e2e.spec.js +++ b/e2e/tests/functional/forms.e2e.spec.js @@ -19,15 +19,16 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ + /* This test suite is dedicated to tests which verify form functionality in isolation */ -const { test, expect } = require('../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const genUuid = require('uuid').v4; -const path = require('path'); +import { fileURLToPath } from 'url'; +import { v4 as genUuid } from 'uuid'; + +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; const TEST_FOLDER = 'test folder'; const jsonFilePath = 'e2e/test-data/ExampleLayouts.json'; @@ -72,7 +73,7 @@ test.describe('Form Validation Behavior', () => { test.describe('Form File Input Behavior', () => { test.beforeEach(async ({ page }) => { await page.addInitScript({ - path: path.join(__dirname, '../../helper', 'addInitFileInputObject.js') + path: fileURLToPath(new URL('../../helper/addInitFileInputObject.js', import.meta.url)) }); }); @@ -109,7 +110,7 @@ test.describe('Persistence operations @addInit', () => { // add non persistable root item test.beforeEach(async ({ page }) => { await page.addInitScript({ - path: path.join(__dirname, '../../helper', 'addNoneditableObject.js') + path: fileURLToPath(new URL('../../helper/addNoneditableObject.js', import.meta.url)) }); }); diff --git a/e2e/tests/functional/menu.e2e.spec.js b/e2e/tests/functional/menu.e2e.spec.js index 97b913bdc1..7f2e43d797 100644 --- a/e2e/tests/functional/menu.e2e.spec.js +++ b/e2e/tests/functional/menu.e2e.spec.js @@ -19,20 +19,20 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ + /* This test suite is dedicated to tests which verify persistability checks */ -const { test, expect } = require('../../baseFixtures.js'); +import { fileURLToPath } from 'url'; -const path = require('path'); +import { expect, test } from '../../baseFixtures.js'; test.describe('Persistence operations @addInit', () => { // add non persistable root item test.beforeEach(async ({ page }) => { await page.addInitScript({ - path: path.join(__dirname, '../../helper', 'addNoneditableObject.js') + path: fileURLToPath(new URL('../../helper/addNoneditableObject.js', import.meta.url)) }); }); diff --git a/e2e/tests/functional/moveAndLinkObjects.e2e.spec.js b/e2e/tests/functional/moveAndLinkObjects.e2e.spec.js index b7a067bd47..06a5a6ac18 100644 --- a/e2e/tests/functional/moveAndLinkObjects.e2e.spec.js +++ b/e2e/tests/functional/moveAndLinkObjects.e2e.spec.js @@ -24,8 +24,8 @@ This test suite is dedicated to tests which verify the basic operations surrounding moving & linking objects. */ -const { test, expect } = require('../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../appActions'); +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Move & link item tests', () => { test('Create a basic object and verify that it can be moved to another folder', async ({ diff --git a/e2e/tests/functional/notification.e2e.spec.js b/e2e/tests/functional/notification.e2e.spec.js index bb8c3c3196..a1f295d1bb 100644 --- a/e2e/tests/functional/notification.e2e.spec.js +++ b/e2e/tests/functional/notification.e2e.spec.js @@ -24,8 +24,8 @@ This test suite is dedicated to tests which verify Open MCT's Notification functionality */ -const { createDomainObjectWithDefaults, createNotification } = require('../../appActions'); -const { test, expect } = require('../../pluginFixtures'); +import { createDomainObjectWithDefaults, createNotification } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Notifications List', () => { test.fixme('Notifications can be dismissed individually', async ({ page }) => { diff --git a/e2e/tests/functional/planning/ganttChart.e2e.spec.js b/e2e/tests/functional/planning/ganttChart.e2e.spec.js index f6f595ce13..dd083669eb 100644 --- a/e2e/tests/functional/planning/ganttChart.e2e.spec.js +++ b/e2e/tests/functional/planning/ganttChart.e2e.spec.js @@ -19,15 +19,26 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../pluginFixtures'); -const { createPlanFromJSON, createDomainObjectWithDefaults } = require('../../../appActions'); -const testPlan1 = require('../../../test-data/examplePlans/ExamplePlan_Small1.json'); -const testPlan2 = require('../../../test-data/examplePlans/ExamplePlan_Small2.json'); -const { +import fs from 'fs'; + +import { getPreciseDuration } from '../../../../src/utils/duration.js'; +import { createDomainObjectWithDefaults, createPlanFromJSON } from '../../../appActions.js'; +import { assertPlanActivities, setBoundsToSpanAllActivities -} = require('../../../helper/planningUtils'); -const { getPreciseDuration } = require('../../../../src/utils/duration'); +} from '../../../helper/planningUtils.js'; +import { expect, test } from '../../../pluginFixtures.js'; + +const testPlan1 = JSON.parse( + fs.readFileSync( + new URL('../../../test-data/examplePlans/ExamplePlan_Small1.json', import.meta.url) + ) +); +const testPlan2 = JSON.parse( + fs.readFileSync( + new URL('../../../test-data/examplePlans/ExamplePlan_Small2.json', import.meta.url) + ) +); test.describe('Gantt Chart', () => { let ganttChart; diff --git a/e2e/tests/functional/planning/plan.e2e.spec.js b/e2e/tests/functional/planning/plan.e2e.spec.js index 9ac5b8c03d..d695f29e86 100644 --- a/e2e/tests/functional/planning/plan.e2e.spec.js +++ b/e2e/tests/functional/planning/plan.e2e.spec.js @@ -19,15 +19,27 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test } = require('../../../pluginFixtures'); -const { createPlanFromJSON } = require('../../../appActions'); -const { addPlanGetInterceptor } = require('../../../helper/planningUtils.js'); -const testPlan1 = require('../../../test-data/examplePlans/ExamplePlan_Small1.json'); -const testPlanWithOrderedLanes = require('../../../test-data/examplePlans/ExamplePlanWithOrderedLanes.json'); -const { +import fs from 'fs'; + +import { createPlanFromJSON } from '../../../appActions.js'; +import { + addPlanGetInterceptor, assertPlanActivities, assertPlanOrderedSwimLanes -} = require('../../../helper/planningUtils'); +} from '../../../helper/planningUtils.js'; +import { test } from '../../../pluginFixtures.js'; + +const testPlan1 = JSON.parse( + fs.readFileSync( + new URL('../../../test-data/examplePlans/ExamplePlan_Small1.json', import.meta.url) + ) +); + +const testPlanWithOrderedLanes = JSON.parse( + fs.readFileSync( + new URL('../../../test-data/examplePlans/ExamplePlanWithOrderedLanes.json', import.meta.url) + ) +); test.describe('Plan', () => { let plan; diff --git a/e2e/tests/functional/planning/timelist.e2e.spec.js b/e2e/tests/functional/planning/timelist.e2e.spec.js index 65802cf92f..005b0809d4 100644 --- a/e2e/tests/functional/planning/timelist.e2e.spec.js +++ b/e2e/tests/functional/planning/timelist.e2e.spec.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../pluginFixtures'); -const { createDomainObjectWithDefaults, createPlanFromJSON } = require('../../../appActions'); +import { createDomainObjectWithDefaults, createPlanFromJSON } from '../../../appActions.js'; +import { expect, test } from '../../../pluginFixtures.js'; const testPlan = { TEST_GROUP: [ diff --git a/e2e/tests/functional/planning/timestrip.e2e.spec.js b/e2e/tests/functional/planning/timestrip.e2e.spec.js index 4eea93535e..d698d0a983 100644 --- a/e2e/tests/functional/planning/timestrip.e2e.spec.js +++ b/e2e/tests/functional/planning/timestrip.e2e.spec.js @@ -20,12 +20,12 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../pluginFixtures'); -const { +import { createDomainObjectWithDefaults, createPlanFromJSON, setIndependentTimeConductorBounds -} = require('../../../appActions'); +} from '../../../appActions.js'; +import { expect, test } from '../../../pluginFixtures.js'; const testPlan = { TEST_GROUP: [ diff --git a/e2e/tests/functional/plugins/clocks/clock.e2e.spec.js b/e2e/tests/functional/plugins/clocks/clock.e2e.spec.js index b0afc5167f..6684684460 100644 --- a/e2e/tests/functional/plugins/clocks/clock.e2e.spec.js +++ b/e2e/tests/functional/plugins/clocks/clock.e2e.spec.js @@ -24,7 +24,7 @@ This test suite is dedicated to tests which verify the basic operations surrounding Clock. */ -const { test, expect } = require('../../../../baseFixtures'); +import { expect, test } from '../../../../baseFixtures.js'; test.describe('Clock Generator CRUD Operations', () => { test('Timezone dropdown will collapse when clicked outside or on dropdown icon again', async ({ diff --git a/e2e/tests/functional/plugins/clocks/remoteClock.e2e.spec.js b/e2e/tests/functional/plugins/clocks/remoteClock.e2e.spec.js index d34d0be52f..86bf1fdee5 100644 --- a/e2e/tests/functional/plugins/clocks/remoteClock.e2e.spec.js +++ b/e2e/tests/functional/plugins/clocks/remoteClock.e2e.spec.js @@ -22,7 +22,7 @@ // FIXME: Remove this eslint exception once tests are implemented // eslint-disable-next-line no-unused-vars -const { test, expect } = require('../../../../baseFixtures'); +import { expect, test } from '../../../../baseFixtures.js'; test.describe('Remote Clock', () => { // eslint-disable-next-line require-await diff --git a/e2e/tests/functional/plugins/conditionSet/conditionSet.e2e.spec.js b/e2e/tests/functional/plugins/conditionSet/conditionSet.e2e.spec.js index 5217d71a0d..ed4d0390f2 100644 --- a/e2e/tests/functional/plugins/conditionSet/conditionSet.e2e.spec.js +++ b/e2e/tests/functional/plugins/conditionSet/conditionSet.e2e.spec.js @@ -19,19 +19,19 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ /* This test suite is dedicated to tests which verify the basic operations surrounding conditionSets. Note: this suite is sharing state between tests which is considered an anti-pattern. Implementing in this way to demonstrate some playwright for test developers. This pattern should not be re-used in other CRUD suites. */ -const { test, expect } = require('../../../../pluginFixtures.js'); -const { +import { fileURLToPath } from 'url'; + +import { createDomainObjectWithDefaults, createExampleTelemetryObject -} = require('../../../../appActions'); -const path = require('path'); +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; let conditionSetUrl; let getConditionSetIdentifierFromUrl; @@ -50,7 +50,9 @@ test.describe.serial('Condition Set CRUD Operations on @localStorage', () => { //Save localStorage for future test execution await context.storageState({ - path: path.resolve(__dirname, '../../../../test-data/recycled_local_storage.json') + path: fileURLToPath( + new URL('../../../../test-data/recycled_local_storage.json', import.meta.url) + ) }); //Set object identifier from url @@ -63,7 +65,9 @@ test.describe.serial('Condition Set CRUD Operations on @localStorage', () => { //Load localStorage for subsequent tests test.use({ - storageState: path.resolve(__dirname, '../../../../test-data/recycled_local_storage.json') + storageState: fileURLToPath( + new URL('../../../../test-data/recycled_local_storage.json', import.meta.url) + ) }); //Begin suite of tests again localStorage diff --git a/e2e/tests/functional/plugins/displayLayout/displayLayout.e2e.spec.js b/e2e/tests/functional/plugins/displayLayout/displayLayout.e2e.spec.js index 5c58a37fc3..a12ec93ce6 100644 --- a/e2e/tests/functional/plugins/displayLayout/displayLayout.e2e.spec.js +++ b/e2e/tests/functional/plugins/displayLayout/displayLayout.e2e.spec.js @@ -19,20 +19,19 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ -const { test, expect } = require('../../../../pluginFixtures'); -const path = require('path'); -const { - createDomainObjectWithDefaults, - setStartOffset, - setFixedTimeMode, - setRealTimeMode, - setIndependentTimeConductorBounds -} = require('../../../../appActions'); +import { fileURLToPath } from 'url'; -const LOCALSTORAGE_PATH = path.resolve( - __dirname, - '../../../../test-data/display_layout_with_child_layouts.json' +import { + createDomainObjectWithDefaults, + setFixedTimeMode, + setIndependentTimeConductorBounds, + setRealTimeMode, + setStartOffset +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; + +const LOCALSTORAGE_PATH = fileURLToPath( + new URL('../../../../test-data/display_layout_with_child_layouts.json', import.meta.url) ); const TINY_IMAGE_BASE64 = ''; @@ -51,7 +50,7 @@ test.describe('Display Layout Toolbar Actions @localStorage', () => { await page.getByLabel('Edit').click(); }); test.use({ - storageState: path.resolve(__dirname, LOCALSTORAGE_PATH) + storageState: LOCALSTORAGE_PATH }); test('can add/remove Text element to a single layout', async ({ page }) => { diff --git a/e2e/tests/functional/plugins/faultManagement/faultManagement.e2e.spec.js b/e2e/tests/functional/plugins/faultManagement/faultManagement.e2e.spec.js index fb08968f47..bf0d3500e8 100644 --- a/e2e/tests/functional/plugins/faultManagement/faultManagement.e2e.spec.js +++ b/e2e/tests/functional/plugins/faultManagement/faultManagement.e2e.spec.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../../pluginFixtures'); -const utils = require('../../../../helper/faultUtils'); +import * as utils from '../../../../helper/faultUtils.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('The Fault Management Plugin using example faults', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/plugins/flexibleLayout/flexibleLayout.e2e.spec.js b/e2e/tests/functional/plugins/flexibleLayout/flexibleLayout.e2e.spec.js index 1db3e2486d..75e35d03a2 100644 --- a/e2e/tests/functional/plugins/flexibleLayout/flexibleLayout.e2e.spec.js +++ b/e2e/tests/functional/plugins/flexibleLayout/flexibleLayout.e2e.spec.js @@ -19,18 +19,17 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ -const { test, expect } = require('../../../../pluginFixtures'); -const { +import { fileURLToPath } from 'url'; + +import { createDomainObjectWithDefaults, setIndependentTimeConductorBounds -} = require('../../../../appActions'); -const path = require('path'); +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; -const LOCALSTORAGE_PATH = path.resolve( - __dirname, - '../../../../test-data/flexible_layout_with_child_layouts.json' +const LOCALSTORAGE_PATH = fileURLToPath( + new URL('../../../../test-data/flexible_layout_with_child_layouts.json', import.meta.url) ); test.describe('Flexible Layout', () => { @@ -267,7 +266,7 @@ test.describe('Flexible Layout', () => { test.describe('Flexible Layout Toolbar Actions @localStorage', () => { test.use({ - storageState: path.resolve(__dirname, LOCALSTORAGE_PATH) + storageState: LOCALSTORAGE_PATH }); test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/plugins/gauge/gauge.e2e.spec.js b/e2e/tests/functional/plugins/gauge/gauge.e2e.spec.js index 47118d6765..b578a63745 100644 --- a/e2e/tests/functional/plugins/gauge/gauge.e2e.spec.js +++ b/e2e/tests/functional/plugins/gauge/gauge.e2e.spec.js @@ -24,12 +24,13 @@ * This test suite is dedicated to testing the Gauge component. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { +import { v4 as uuid } from 'uuid'; + +import { createDomainObjectWithDefaults, createExampleTelemetryObject -} = require('../../../../appActions'); -const uuid = require('uuid').v4; +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Gauge', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/plugins/imagery/exampleImagery.e2e.spec.js b/e2e/tests/functional/plugins/imagery/exampleImagery.e2e.spec.js index a5204cdb94..e0dddad2c1 100644 --- a/e2e/tests/functional/plugins/imagery/exampleImagery.e2e.spec.js +++ b/e2e/tests/functional/plugins/imagery/exampleImagery.e2e.spec.js @@ -25,9 +25,9 @@ This test suite is dedicated to tests which verify the basic operations surround but only assume that example imagery is present. */ /* globals process */ -const { waitForAnimations } = require('../../../../baseFixtures'); -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults, setRealTimeMode } = require('../../../../appActions'); +import { createDomainObjectWithDefaults, setRealTimeMode } from '../../../../appActions.js'; +import { waitForAnimations } from '../../../../baseFixtures.js'; +import { expect, test } from '../../../../pluginFixtures.js'; const backgroundImageSelector = '.c-imagery__main-image__background-image'; const panHotkey = process.platform === 'linux' ? ['Shift', 'Alt'] : ['Alt']; const tagHotkey = ['Shift', 'Alt']; diff --git a/e2e/tests/functional/plugins/importAndExportAsJSON/exportAsJson.e2e.spec.js b/e2e/tests/functional/plugins/importAndExportAsJSON/exportAsJson.e2e.spec.js index 0c9d478fa4..f52fbe28ad 100644 --- a/e2e/tests/functional/plugins/importAndExportAsJSON/exportAsJson.e2e.spec.js +++ b/e2e/tests/functional/plugins/importAndExportAsJSON/exportAsJson.e2e.spec.js @@ -26,7 +26,7 @@ This test suite is dedicated to tests which verify the basic operations surround // FIXME: Remove this eslint exception once tests are implemented // eslint-disable-next-line no-unused-vars -const { test, expect } = require('../../../../baseFixtures'); +import { expect, test } from '../../../../baseFixtures.js'; test.describe('ExportAsJSON', () => { test.fixme( diff --git a/e2e/tests/functional/plugins/importAndExportAsJSON/importAsJson.e2e.spec.js b/e2e/tests/functional/plugins/importAndExportAsJSON/importAsJson.e2e.spec.js index 94c82af68f..04fc7d2691 100644 --- a/e2e/tests/functional/plugins/importAndExportAsJSON/importAsJson.e2e.spec.js +++ b/e2e/tests/functional/plugins/importAndExportAsJSON/importAsJson.e2e.spec.js @@ -26,7 +26,7 @@ This test suite is dedicated to tests which verify the basic operations surround // FIXME: Remove this eslint exception once tests are implemented // eslint-disable-next-line no-unused-vars -const { test, expect } = require('../../../../baseFixtures'); +import { expect, test } from '../../../../baseFixtures.js'; test.describe('ExportAsJSON', () => { test.fixme('Verify that domain object can be importAsJSON from Tree', async ({ page }) => { diff --git a/e2e/tests/functional/plugins/inspectorDataVisualization/numericData.e2e.spec.js b/e2e/tests/functional/plugins/inspectorDataVisualization/numericData.e2e.spec.js index 41de13334a..31a650dfa0 100644 --- a/e2e/tests/functional/plugins/inspectorDataVisualization/numericData.e2e.spec.js +++ b/e2e/tests/functional/plugins/inspectorDataVisualization/numericData.e2e.spec.js @@ -19,17 +19,19 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const path = require('path'); +import { fileURLToPath } from 'url'; + +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Testing numeric data with inspector data visualization (i.e., data pivoting)', () => { test.beforeEach(async ({ page }) => { // eslint-disable-next-line no-undef await page.addInitScript({ - path: path.join(__dirname, '../../../../helper/', 'addInitDataVisualization.js') + path: fileURLToPath( + new URL('../../../../helper/addInitDataVisualization.js', import.meta.url) + ) }); await page.goto('./', { waitUntil: 'domcontentloaded' }); }); diff --git a/e2e/tests/functional/plugins/lad/lad.e2e.spec.js b/e2e/tests/functional/plugins/lad/lad.e2e.spec.js index d959d06641..828b0eed2a 100644 --- a/e2e/tests/functional/plugins/lad/lad.e2e.spec.js +++ b/e2e/tests/functional/plugins/lad/lad.e2e.spec.js @@ -20,14 +20,14 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../../pluginFixtures'); -const { +import { createDomainObjectWithDefaults, - setStartOffset, + openObjectTreeContextMenu, setFixedTimeMode, setRealTimeMode, - openObjectTreeContextMenu -} = require('../../../../appActions'); + setStartOffset +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Testing LAD table configuration', () => { let ladTable; diff --git a/e2e/tests/functional/plugins/notebook/notebook.e2e.spec.js b/e2e/tests/functional/plugins/notebook/notebook.e2e.spec.js index 354b2e7258..5c1b9a1cad 100644 --- a/e2e/tests/functional/plugins/notebook/notebook.e2e.spec.js +++ b/e2e/tests/functional/plugins/notebook/notebook.e2e.spec.js @@ -19,15 +19,16 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ + /* This test suite is dedicated to tests which verify the basic operations surrounding Notebooks. */ -const { test, expect, streamToString } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const nbUtils = require('../../../../helper/notebookUtils'); -const path = require('path'); +import { fileURLToPath } from 'url'; + +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import * as nbUtils from '../../../../helper/notebookUtils.js'; +import { expect, streamToString, test } from '../../../../pluginFixtures.js'; const NOTEBOOK_NAME = 'Notebook'; @@ -278,7 +279,7 @@ test.describe('Notebook entry tests', () => { test.beforeEach(async ({ page }) => { // eslint-disable-next-line no-undef await page.addInitScript({ - path: path.join(__dirname, '../../../../helper/', 'addInitNotebookWithUrls.js') + path: fileURLToPath(new URL('../../../../helper/addInitNotebookWithUrls.js', import.meta.url)) }); await page.goto('./', { waitUntil: 'domcontentloaded' }); diff --git a/e2e/tests/functional/plugins/notebook/notebookSnapshots.e2e.spec.js b/e2e/tests/functional/plugins/notebook/notebookSnapshots.e2e.spec.js index 877da4da55..a9fa726e70 100644 --- a/e2e/tests/functional/plugins/notebook/notebookSnapshots.e2e.spec.js +++ b/e2e/tests/functional/plugins/notebook/notebookSnapshots.e2e.spec.js @@ -19,15 +19,16 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ + /* This test suite is dedicated to tests which verify the basic operations surrounding Notebooks. */ -const fs = require('fs').promises; -const path = require('path'); -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../../appActions'); +import fs from 'fs/promises'; +import { fileURLToPath } from 'url'; + +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; const NOTEBOOK_NAME = 'Notebook'; @@ -178,7 +179,9 @@ test.describe('Snapshot image tests', () => { test('Can drop an image onto a notebook and create a new entry', async ({ page }) => { const imageData = await fs.readFile( - path.resolve(__dirname, '../../../../../src/images/favicons/favicon-96x96.png') + fileURLToPath( + new URL('../../../../../src/images/favicons/favicon-96x96.png', import.meta.url) + ) ); const imageArray = new Uint8Array(imageData); const fileData = Array.from(imageArray); diff --git a/e2e/tests/functional/plugins/notebook/notebookWithCouchDB.e2e.spec.js b/e2e/tests/functional/plugins/notebook/notebookWithCouchDB.e2e.spec.js index 646e08d0e9..8ca9a23a01 100644 --- a/e2e/tests/functional/plugins/notebook/notebookWithCouchDB.e2e.spec.js +++ b/e2e/tests/functional/plugins/notebook/notebookWithCouchDB.e2e.spec.js @@ -24,9 +24,9 @@ This test suite is dedicated to tests which verify the basic operations surrounding Notebooks with CouchDB. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const nbUtils = require('../../../../helper/notebookUtils'); +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import * as nbUtils from '../../../../helper/notebookUtils.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Notebook Tests with CouchDB @couchdb', () => { let testNotebook; diff --git a/e2e/tests/functional/plugins/notebook/restrictedNotebook.e2e.spec.js b/e2e/tests/functional/plugins/notebook/restrictedNotebook.e2e.spec.js index 669c09241d..f43f857911 100644 --- a/e2e/tests/functional/plugins/notebook/restrictedNotebook.e2e.spec.js +++ b/e2e/tests/functional/plugins/notebook/restrictedNotebook.e2e.spec.js @@ -20,14 +20,14 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect, streamToString } = require('../../../../pluginFixtures'); -const { openObjectTreeContextMenu } = require('../../../../appActions'); -const { - lockPage, +import { openObjectTreeContextMenu } from '../../../../appActions.js'; +import { dragAndDropEmbed, enterTextEntry, + lockPage, startAndAddRestrictedNotebookObject -} = require('../../../../helper/notebookUtils'); +} from '../../../../helper/notebookUtils.js'; +import { expect, streamToString, test } from '../../../../pluginFixtures.js'; const TEST_TEXT = 'Testing text for entries.'; const TEST_TEXT_NAME = 'Test Page'; diff --git a/e2e/tests/functional/plugins/notebook/tags.e2e.spec.js b/e2e/tests/functional/plugins/notebook/tags.e2e.spec.js index b520bf1fb5..00f2e3b05c 100644 --- a/e2e/tests/functional/plugins/notebook/tags.e2e.spec.js +++ b/e2e/tests/functional/plugins/notebook/tags.e2e.spec.js @@ -24,13 +24,13 @@ This test suite is dedicated to tests which verify notebook tag functionality. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const { - enterTextEntry, +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import { createNotebookAndEntry, - createNotebookEntryAndTags -} = require('../../../../helper/notebookUtils'); + createNotebookEntryAndTags, + enterTextEntry +} from '../../../../helper/notebookUtils.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Tagging in Notebooks @addInit', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/plugins/operatorStatus/operatorStatus.e2e.spec.js b/e2e/tests/functional/plugins/operatorStatus/operatorStatus.e2e.spec.js index 7834a3cda2..ae1e3e1b63 100644 --- a/e2e/tests/functional/plugins/operatorStatus/operatorStatus.e2e.spec.js +++ b/e2e/tests/functional/plugins/operatorStatus/operatorStatus.e2e.spec.js @@ -19,13 +19,13 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ /* * This test suite is dedicated to testing the operator status plugin. */ -const path = require('path'); -const { test, expect } = require('../../../../pluginFixtures'); +import { fileURLToPath } from 'url'; + +import { expect, test } from '../../../../pluginFixtures.js'; /* @@ -41,10 +41,10 @@ test.describe('Operator Status', () => { test.beforeEach(async ({ page }) => { // FIXME: determine if plugins will be added to index.html or need to be injected await page.addInitScript({ - path: path.join(__dirname, '../../../../helper/', 'addInitExampleUser.js') + path: fileURLToPath(new URL('../../../../helper/addInitExampleUser.js', import.meta.url)) }); await page.addInitScript({ - path: path.join(__dirname, '../../../../helper/', 'addInitOperatorStatus.js') + path: fileURLToPath(new URL('../../../../helper/addInitOperatorStatus.js', import.meta.url)) }); await page.goto('./', { waitUntil: 'domcontentloaded' }); await expect(page.getByText('Select Role')).toBeVisible(); diff --git a/e2e/tests/functional/plugins/plot/autoscale.e2e.spec.js b/e2e/tests/functional/plugins/plot/autoscale.e2e.spec.js index 74a1d67c9a..870fcc1fcb 100644 --- a/e2e/tests/functional/plugins/plot/autoscale.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/autoscale.e2e.spec.js @@ -24,8 +24,8 @@ Testsuite for plot autoscale. */ -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const { test, expect } = require('../../../../pluginFixtures'); +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.use({ viewport: { width: 1280, diff --git a/e2e/tests/functional/plugins/plot/logPlot.e2e.spec.js b/e2e/tests/functional/plugins/plot/logPlot.e2e.spec.js index cdf39ae89a..75477f731f 100644 --- a/e2e/tests/functional/plugins/plot/logPlot.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/logPlot.e2e.spec.js @@ -25,8 +25,8 @@ Tests to verify log plot functionality. Note this test suite if very much under necessarily be used for reference when writing new tests in this area. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { setTimeConductorBounds } = require('../../../../appActions'); +import { setTimeConductorBounds } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Log plot tests', () => { test('Log Plot ticks are functionally correct in regular and log mode and after refresh', async ({ diff --git a/e2e/tests/functional/plugins/plot/missingPlotObj.e2e.spec.js b/e2e/tests/functional/plugins/plot/missingPlotObj.e2e.spec.js index 4e6e11eaae..50a2d7b543 100644 --- a/e2e/tests/functional/plugins/plot/missingPlotObj.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/missingPlotObj.e2e.spec.js @@ -24,7 +24,7 @@ Tests to verify log plot functionality when objects are missing */ -const { test, expect } = require('../../../../pluginFixtures'); +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Handle missing object for plots', () => { test('Displays empty div for missing stacked plot item @unstable', async ({ diff --git a/e2e/tests/functional/plugins/plot/overlayPlot.e2e.spec.js b/e2e/tests/functional/plugins/plot/overlayPlot.e2e.spec.js index b7dcbd357b..ebe7909ee1 100644 --- a/e2e/tests/functional/plugins/plot/overlayPlot.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/overlayPlot.e2e.spec.js @@ -25,12 +25,12 @@ Tests to verify log plot functionality. Note this test suite if very much under necessarily be used for reference when writing new tests in this area. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { +import { createDomainObjectWithDefaults, getCanvasPixels, waitForPlotsToRender -} = require('../../../../appActions'); +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Overlay Plot', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/plugins/plot/plotRendering.e2e.spec.js b/e2e/tests/functional/plugins/plot/plotRendering.e2e.spec.js index 767a6a1757..1fc2a99d50 100644 --- a/e2e/tests/functional/plugins/plot/plotRendering.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/plotRendering.e2e.spec.js @@ -25,8 +25,8 @@ * */ -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults, getCanvasPixels } = require('../../../../appActions'); +import { createDomainObjectWithDefaults, getCanvasPixels } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Plot Rendering', () => { let sineWaveGeneratorObject; diff --git a/e2e/tests/functional/plugins/plot/scatterPlot.e2e.spec.js b/e2e/tests/functional/plugins/plot/scatterPlot.e2e.spec.js index e6efe1e863..11bffc56b2 100644 --- a/e2e/tests/functional/plugins/plot/scatterPlot.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/scatterPlot.e2e.spec.js @@ -24,9 +24,10 @@ * This test suite is dedicated to testing the Scatter Plot component. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const uuid = require('uuid').v4; +import { v4 as uuid } from 'uuid'; + +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Scatter Plot', () => { let scatterPlot; diff --git a/e2e/tests/functional/plugins/plot/stackedPlot.e2e.spec.js b/e2e/tests/functional/plugins/plot/stackedPlot.e2e.spec.js index 83bc77f62c..7ee47232bc 100644 --- a/e2e/tests/functional/plugins/plot/stackedPlot.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/stackedPlot.e2e.spec.js @@ -25,8 +25,8 @@ Tests to verify log plot functionality. Note this test suite if very much under necessarily be used for reference when writing new tests in this area. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { createDomainObjectWithDefaults, waitForPlotsToRender } = require('../../../../appActions'); +import { createDomainObjectWithDefaults, waitForPlotsToRender } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Stacked Plot', () => { let stackedPlot; diff --git a/e2e/tests/functional/plugins/plot/tagging.e2e.spec.js b/e2e/tests/functional/plugins/plot/tagging.e2e.spec.js index 1baa807a8e..f6c0531853 100644 --- a/e2e/tests/functional/plugins/plot/tagging.e2e.spec.js +++ b/e2e/tests/functional/plugins/plot/tagging.e2e.spec.js @@ -24,18 +24,14 @@ Tests to verify plot tagging functionality. */ -const { test, expect } = require('../../../../pluginFixtures'); -const { - basicTagsTests, - createTags, - testTelemetryItem -} = require('../../../../helper/plotTagsUtils'); -const { +import { createDomainObjectWithDefaults, - setRealTimeMode, setFixedTimeMode, + setRealTimeMode, waitForPlotsToRender -} = require('../../../../appActions'); +} from '../../../../appActions.js'; +import { basicTagsTests, createTags, testTelemetryItem } from '../../../../helper/plotTagsUtils.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Plot Tagging', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/plugins/tabs/tabs.e2e.spec.js b/e2e/tests/functional/plugins/tabs/tabs.e2e.spec.js index c702006a84..263176c97c 100644 --- a/e2e/tests/functional/plugins/tabs/tabs.e2e.spec.js +++ b/e2e/tests/functional/plugins/tabs/tabs.e2e.spec.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { createDomainObjectWithDefaults } = require('../../../../appActions'); -const { test, expect } = require('../../../../pluginFixtures'); +import { createDomainObjectWithDefaults } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Tabs View', () => { test('Renders tabbed elements', async ({ page }) => { diff --git a/e2e/tests/functional/plugins/telemetryTable/telemetryTable.e2e.spec.js b/e2e/tests/functional/plugins/telemetryTable/telemetryTable.e2e.spec.js index fd3b25a593..cda6656bea 100644 --- a/e2e/tests/functional/plugins/telemetryTable/telemetryTable.e2e.spec.js +++ b/e2e/tests/functional/plugins/telemetryTable/telemetryTable.e2e.spec.js @@ -20,11 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { - createDomainObjectWithDefaults, - setTimeConductorBounds -} = require('../../../../appActions'); -const { test, expect } = require('../../../../pluginFixtures'); +import { createDomainObjectWithDefaults, setTimeConductorBounds } from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Telemetry Table', () => { test('unpauses and filters data when paused by button and user changes bounds', async ({ diff --git a/e2e/tests/functional/plugins/timeConductor/timeConductor.e2e.spec.js b/e2e/tests/functional/plugins/timeConductor/timeConductor.e2e.spec.js index 7cd0858d3c..51730297b2 100644 --- a/e2e/tests/functional/plugins/timeConductor/timeConductor.e2e.spec.js +++ b/e2e/tests/functional/plugins/timeConductor/timeConductor.e2e.spec.js @@ -20,14 +20,14 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../../pluginFixtures'); -const { +import { + setEndOffset, setFixedTimeMode, setRealTimeMode, setStartOffset, - setEndOffset, setTimeConductorBounds -} = require('../../../../appActions'); +} from '../../../../appActions.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Time conductor operations', () => { test('validate start time does not exceeds end time', async ({ page }) => { diff --git a/e2e/tests/functional/plugins/timer/timer.e2e.spec.js b/e2e/tests/functional/plugins/timer/timer.e2e.spec.js index bdab38997b..112ef175fe 100644 --- a/e2e/tests/functional/plugins/timer/timer.e2e.spec.js +++ b/e2e/tests/functional/plugins/timer/timer.e2e.spec.js @@ -20,12 +20,12 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../../../pluginFixtures'); -const { - openObjectTreeContextMenu, - createDomainObjectWithDefaults -} = require('../../../../appActions'); -import { MISSION_TIME } from '../../../../constants'; +import { + createDomainObjectWithDefaults, + openObjectTreeContextMenu +} from '../../../../appActions.js'; +import { MISSION_TIME } from '../../../../constants.js'; +import { expect, test } from '../../../../pluginFixtures.js'; test.describe('Timer', () => { let timer; diff --git a/e2e/tests/functional/recentObjects.e2e.spec.js b/e2e/tests/functional/recentObjects.e2e.spec.js index febb9407ca..756dba06ac 100644 --- a/e2e/tests/functional/recentObjects.e2e.spec.js +++ b/e2e/tests/functional/recentObjects.e2e.spec.js @@ -20,9 +20,9 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../pluginFixtures.js'); -const { createDomainObjectWithDefaults } = require('../../appActions.js'); -const { waitForAnimations } = require('../../baseFixtures.js'); +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { waitForAnimations } from '../../baseFixtures.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Recent Objects', () => { /** @type {import('@playwright/test').Locator} */ diff --git a/e2e/tests/functional/renaming.e2e.spec.js b/e2e/tests/functional/renaming.e2e.spec.js index 71c70eecb6..46dc79f7cf 100644 --- a/e2e/tests/functional/renaming.e2e.spec.js +++ b/e2e/tests/functional/renaming.e2e.spec.js @@ -24,11 +24,8 @@ This test suite is dedicated to tests for renaming objects, and their global application effects. */ -const { test, expect } = require('../../baseFixtures.js'); -const { - createDomainObjectWithDefaults, - renameObjectFromContextMenu -} = require('../../appActions.js'); +import { createDomainObjectWithDefaults, renameObjectFromContextMenu } from '../../appActions.js'; +import { expect, test } from '../../baseFixtures.js'; test.describe('Renaming objects', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/functional/search.e2e.spec.js b/e2e/tests/functional/search.e2e.spec.js index 449fc41202..73af73679f 100644 --- a/e2e/tests/functional/search.e2e.spec.js +++ b/e2e/tests/functional/search.e2e.spec.js @@ -23,9 +23,10 @@ * This test suite is dedicated to tests which verify search functionalities. */ -const { test, expect } = require('../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const { v4: uuid } = require('uuid'); +import { v4 as uuid } from 'uuid'; + +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Grand Search', () => { const searchResultSelector = '.c-gsearch-result__title'; diff --git a/e2e/tests/functional/smoke.e2e.spec.js b/e2e/tests/functional/smoke.e2e.spec.js index 1571f73f1c..cf7ef98411 100644 --- a/e2e/tests/functional/smoke.e2e.spec.js +++ b/e2e/tests/functional/smoke.e2e.spec.js @@ -33,7 +33,7 @@ comfortable running this test during a live mission?" Avoid creating or deleting Make no assumptions about the order that elements appear in the DOM. */ -const { test, expect } = require('../../pluginFixtures'); +import { expect, test } from '../../pluginFixtures.js'; test('Verify that the create button appears and that the Folder Domain Object is available for selection', async ({ page diff --git a/e2e/tests/functional/tooltips.e2e.spec.js b/e2e/tests/functional/tooltips.e2e.spec.js index 39165f7df5..c1f1620d74 100644 --- a/e2e/tests/functional/tooltips.e2e.spec.js +++ b/e2e/tests/functional/tooltips.e2e.spec.js @@ -33,8 +33,8 @@ comfortable running this test during a live mission?" Avoid creating or deleting Make no assumptions about the order that elements appear in the DOM. */ -const { test, expect } = require('../../pluginFixtures'); -const { createDomainObjectWithDefaults, expandEntireTree } = require('../../appActions'); +import { createDomainObjectWithDefaults, expandEntireTree } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Verify tooltips', () => { let folder1; diff --git a/e2e/tests/functional/tree.e2e.spec.js b/e2e/tests/functional/tree.e2e.spec.js index ed8246debe..0f5152984a 100644 --- a/e2e/tests/functional/tree.e2e.spec.js +++ b/e2e/tests/functional/tree.e2e.spec.js @@ -20,11 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, expect } = require('../../pluginFixtures.js'); -const { - createDomainObjectWithDefaults, - renameObjectFromContextMenu -} = require('../../appActions.js'); +import { createDomainObjectWithDefaults, renameObjectFromContextMenu } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Main Tree', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/performance/contract/imagery.contract.perf.spec.js b/e2e/tests/performance/contract/imagery.contract.perf.spec.js index e47187c2d4..b55c9c195f 100644 --- a/e2e/tests/performance/contract/imagery.contract.perf.spec.js +++ b/e2e/tests/performance/contract/imagery.contract.perf.spec.js @@ -32,7 +32,7 @@ TODO: */ -const { test, expect } = require('@playwright/test'); +import { expect, test } from '@playwright/test'; const filePath = 'e2e/test-data/PerformanceDisplayLayout.json'; diff --git a/e2e/tests/performance/contract/notebook.contract.perf.spec.js b/e2e/tests/performance/contract/notebook.contract.perf.spec.js index a2d811256e..3c9a9a8d36 100644 --- a/e2e/tests/performance/contract/notebook.contract.perf.spec.js +++ b/e2e/tests/performance/contract/notebook.contract.perf.spec.js @@ -31,7 +31,7 @@ TODO: */ -const { test, expect } = require('@playwright/test'); +import { expect, test } from '@playwright/test'; const notebookFilePath = 'e2e/test-data/PerformanceNotebook.json'; diff --git a/e2e/tests/performance/memory/navigation.memory.perf.spec.js b/e2e/tests/performance/memory/navigation.memory.perf.spec.js index 73954016a3..0256ecdce4 100644 --- a/e2e/tests/performance/memory/navigation.memory.perf.spec.js +++ b/e2e/tests/performance/memory/navigation.memory.perf.spec.js @@ -19,14 +19,12 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ -const { test, expect } = require('@playwright/test'); -const path = require('path'); +import { expect, test } from '@playwright/test'; +import { fileURLToPath } from 'url'; -const memoryLeakFilePath = path.resolve( - __dirname, - '../../../../e2e/test-data/memory-leak-detection.json' +const memoryLeakFilePath = fileURLToPath( + new URL('../../../../e2e/test-data/memory-leak-detection.json', import.meta.url) ); /** * Executes tests to verify that views are not leaking memory on navigation away. This sort of diff --git a/e2e/tests/performance/tabs.e2e.spec.js b/e2e/tests/performance/tabs.e2e.spec.js index 833f2e3669..d0989ed56d 100644 --- a/e2e/tests/performance/tabs.e2e.spec.js +++ b/e2e/tests/performance/tabs.e2e.spec.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { createDomainObjectWithDefaults, waitForPlotsToRender } = require('../../appActions'); -const { test, expect } = require('../../pluginFixtures'); +import { createDomainObjectWithDefaults, waitForPlotsToRender } from '../../appActions.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Tabs View', () => { test('Renders tabbed elements nicely', async ({ page }) => { diff --git a/e2e/tests/performance/tagging.perf.spec.js b/e2e/tests/performance/tagging.perf.spec.js index a655c0149c..d93972ba06 100644 --- a/e2e/tests/performance/tagging.perf.spec.js +++ b/e2e/tests/performance/tagging.perf.spec.js @@ -24,14 +24,14 @@ Tests to verify plot tagging performance. */ -const { test, expect } = require('../../pluginFixtures'); -const { basicTagsTests, createTags, testTelemetryItem } = require('../../helper/plotTagsUtils'); -const { +import { createDomainObjectWithDefaults, - setRealTimeMode, setFixedTimeMode, + setRealTimeMode, waitForPlotsToRender -} = require('../../appActions'); +} from '../../appActions.js'; +import { basicTagsTests, createTags, testTelemetryItem } from '../../helper/plotTagsUtils.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Plot Tagging Performance', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/a11y.visual.spec.js b/e2e/tests/visual-a11y/a11y.visual.spec.js index 32b0cdcd42..425791d3db 100644 --- a/e2e/tests/visual-a11y/a11y.visual.spec.js +++ b/e2e/tests/visual-a11y/a11y.visual.spec.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, scanForA11yViolations } = require('../../avpFixtures'); -const VISUAL_URL = require('../../constants').VISUAL_URL; +import { scanForA11yViolations, test } from '../../avpFixtures.js'; +import { VISUAL_URL } from '../../constants.js'; test.describe('a11y - Default @a11y', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/components/about.visual.spec.js b/e2e/tests/visual-a11y/components/about.visual.spec.js index 719aa87e0a..bc879e8dc1 100644 --- a/e2e/tests/visual-a11y/components/about.visual.spec.js +++ b/e2e/tests/visual-a11y/components/about.visual.spec.js @@ -24,9 +24,10 @@ Tests the branding associated with the default deployment. At least the about modal for now */ -const { test, expect } = require('../../../pluginFixtures'); -const percySnapshot = require('@percy/playwright'); -const VISUAL_URL = require('../../../constants').VISUAL_URL; +import percySnapshot from '@percy/playwright'; + +import { VISUAL_URL } from '../../../constants.js'; +import { expect, test } from '../../../pluginFixtures.js'; test.describe('Visual - Branding', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/components/inspector.visual.spec.js b/e2e/tests/visual-a11y/components/inspector.visual.spec.js index bfff926698..8fdbe18098 100644 --- a/e2e/tests/visual-a11y/components/inspector.visual.spec.js +++ b/e2e/tests/visual-a11y/components/inspector.visual.spec.js @@ -20,9 +20,10 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test } = require('../../../pluginFixtures.js'); -const { VISUAL_URL, MISSION_TIME } = require('../../../constants.js'); -const percySnapshot = require('@percy/playwright'); +import percySnapshot from '@percy/playwright'; + +import { MISSION_TIME, VISUAL_URL } from '../../../constants.js'; +import { test } from '../../../pluginFixtures.js'; //Declare the scope of the visual test const inspectorPane = '.l-shell__pane-inspector'; diff --git a/e2e/tests/visual-a11y/components/tree.visual.spec.js b/e2e/tests/visual-a11y/components/tree.visual.spec.js index f06257fc79..7ea46422eb 100644 --- a/e2e/tests/visual-a11y/components/tree.visual.spec.js +++ b/e2e/tests/visual-a11y/components/tree.visual.spec.js @@ -20,13 +20,11 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test } = require('../../../pluginFixtures.js'); -const { - expandTreePaneItemByName, - createDomainObjectWithDefaults -} = require('../../../appActions.js'); -const VISUAL_URL = require('../../../constants.js').VISUAL_URL; -const percySnapshot = require('@percy/playwright'); +import percySnapshot from '@percy/playwright'; + +import { createDomainObjectWithDefaults, expandTreePaneItemByName } from '../../../appActions.js'; +import { VISUAL_URL } from '../../../constants.js'; +import { test } from '../../../pluginFixtures.js'; //Declare the scope of the visual test const treePane = "[role=tree][aria-label='Main Tree']"; diff --git a/e2e/tests/visual-a11y/controlledClock.visual.spec.js b/e2e/tests/visual-a11y/controlledClock.visual.spec.js index 97acd9fb04..05e551b78b 100644 --- a/e2e/tests/visual-a11y/controlledClock.visual.spec.js +++ b/e2e/tests/visual-a11y/controlledClock.visual.spec.js @@ -25,9 +25,10 @@ Collection of Visual Tests set to run with browser clock manipulate made possibl clockOptions plugin fixture. */ -const { VISUAL_URL, MISSION_TIME } = require('../../constants'); -const { test, expect } = require('../../pluginFixtures'); -const percySnapshot = require('@percy/playwright'); +import percySnapshot from '@percy/playwright'; + +import { MISSION_TIME, VISUAL_URL } from '../../constants.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Visual - Controlled Clock', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/defaultPlugins.visual.spec.js b/e2e/tests/visual-a11y/defaultPlugins.visual.spec.js index 6455baa4e6..c1f9033f86 100644 --- a/e2e/tests/visual-a11y/defaultPlugins.visual.spec.js +++ b/e2e/tests/visual-a11y/defaultPlugins.visual.spec.js @@ -26,10 +26,11 @@ are only meant to run against openmct's app.js started by `npm run start` within `./e2e/playwright-visual.config.js` file. */ -const { test, expect, scanForA11yViolations } = require('../../avpFixtures'); -const percySnapshot = require('@percy/playwright'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const { VISUAL_URL } = require('../../constants'); +import percySnapshot from '@percy/playwright'; + +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, scanForA11yViolations, test } from '../../avpFixtures.js'; +import { VISUAL_URL } from '../../constants.js'; test.describe('Visual - Default @a11y', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/displayLayout.visual.spec.js b/e2e/tests/visual-a11y/displayLayout.visual.spec.js index 0130356806..b0e3e34dc3 100644 --- a/e2e/tests/visual-a11y/displayLayout.visual.spec.js +++ b/e2e/tests/visual-a11y/displayLayout.visual.spec.js @@ -26,10 +26,11 @@ * @property {Object} LayoutLocator */ -const { test } = require('../../pluginFixtures'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const VISUAL_URL = require('../../constants').VISUAL_URL; -const percySnapshot = require('@percy/playwright'); +import percySnapshot from '@percy/playwright'; + +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { VISUAL_URL } from '../../constants.js'; +import { test } from '../../pluginFixtures.js'; const snapshotScope = '.l-shell__pane-main .l-pane__contents'; test.describe('Visual - Display Layout', () => { diff --git a/e2e/tests/visual-a11y/faultManagement.visual.spec.js b/e2e/tests/visual-a11y/faultManagement.visual.spec.js index 133b00e338..53f41bd36a 100644 --- a/e2e/tests/visual-a11y/faultManagement.visual.spec.js +++ b/e2e/tests/visual-a11y/faultManagement.visual.spec.js @@ -19,17 +19,16 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -/* global __dirname */ -const path = require('path'); -const { test } = require('../../pluginFixtures'); -const percySnapshot = require('@percy/playwright'); +import percySnapshot from '@percy/playwright'; +import { fileURLToPath } from 'url'; -const utils = require('../../helper/faultUtils'); +import * as utils from '../../helper/faultUtils.js'; +import { test } from '../../pluginFixtures.js'; test.describe('Fault Management Visual Tests', () => { test('icon test', async ({ page, theme }) => { await page.addInitScript({ - path: path.join(__dirname, '../../helper/', 'addInitFaultManagementPlugin.js') + path: fileURLToPath(new URL('../../helper/addInitFaultManagementPlugin.js', import.meta.url)) }); await page.goto('./', { waitUntil: 'domcontentloaded' }); diff --git a/e2e/tests/visual-a11y/ladTable.visual.spec.js b/e2e/tests/visual-a11y/ladTable.visual.spec.js index f64cfc17c7..5690cf053f 100644 --- a/e2e/tests/visual-a11y/ladTable.visual.spec.js +++ b/e2e/tests/visual-a11y/ladTable.visual.spec.js @@ -20,10 +20,11 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { expect, test } = require('../../pluginFixtures'); -const percySnapshot = require('@percy/playwright'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const VISUAL_URL = require('../../constants').VISUAL_URL; +import percySnapshot from '@percy/playwright'; + +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { VISUAL_URL } from '../../constants.js'; +import { expect, test } from '../../pluginFixtures.js'; test.describe('Visual - LAD Table', () => { /** @type {import('@playwright/test').Locator} */ diff --git a/e2e/tests/visual-a11y/notebook.visual.spec.js b/e2e/tests/visual-a11y/notebook.visual.spec.js index a99034687d..eb45c9a68e 100644 --- a/e2e/tests/visual-a11y/notebook.visual.spec.js +++ b/e2e/tests/visual-a11y/notebook.visual.spec.js @@ -20,14 +20,12 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, scanForA11yViolations } = require('../../avpFixtures'); -const percySnapshot = require('@percy/playwright'); -const { expandTreePaneItemByName, createDomainObjectWithDefaults } = require('../../appActions'); -const { - startAndAddRestrictedNotebookObject, - enterTextEntry -} = require('../../helper/notebookUtils'); -const { VISUAL_URL } = require('../../constants'); +import percySnapshot from '@percy/playwright'; + +import { createDomainObjectWithDefaults, expandTreePaneItemByName } from '../../appActions.js'; +import { scanForA11yViolations, test } from '../../avpFixtures.js'; +import { VISUAL_URL } from '../../constants.js'; +import { enterTextEntry, startAndAddRestrictedNotebookObject } from '../../helper/notebookUtils.js'; test.describe('Visual - Restricted Notebook', () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/notification.visual.spec.js b/e2e/tests/visual-a11y/notification.visual.spec.js index 2d73fadc59..7be4a4e92f 100644 --- a/e2e/tests/visual-a11y/notification.visual.spec.js +++ b/e2e/tests/visual-a11y/notification.visual.spec.js @@ -24,10 +24,11 @@ * This test is dedicated to test notification banner functionality and its accessibility attributes. */ -const { test, expect, scanForA11yViolations } = require('../../avpFixtures'); -const percySnapshot = require('@percy/playwright'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const VISUAL_URL = require('../../constants').VISUAL_URL; +import percySnapshot from '@percy/playwright'; + +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, scanForA11yViolations, test } from '../../avpFixtures.js'; +import { VISUAL_URL } from '../../constants.js'; test.describe("Visual - Check Notification Info Banner of 'Save successful' @a11y", () => { test.beforeEach(async ({ page }) => { diff --git a/e2e/tests/visual-a11y/planning.visual.spec.js b/e2e/tests/visual-a11y/planning.visual.spec.js index 4faca551da..f2a05ef54d 100644 --- a/e2e/tests/visual-a11y/planning.visual.spec.js +++ b/e2e/tests/visual-a11y/planning.visual.spec.js @@ -20,15 +20,17 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -const { test, scanForA11yViolations } = require('../../avpFixtures'); -const { - setBoundsToSpanAllActivities, - setDraftStatusForPlan -} = require('../../helper/planningUtils'); -const { createDomainObjectWithDefaults, createPlanFromJSON } = require('../../appActions'); -const percySnapshot = require('@percy/playwright'); -const VISUAL_URL = require('../../constants').VISUAL_URL; -const examplePlanSmall = require('../../test-data/examplePlans/ExamplePlan_Small2.json'); +import percySnapshot from '@percy/playwright'; +import fs from 'fs'; + +import { createDomainObjectWithDefaults, createPlanFromJSON } from '../../appActions.js'; +import { scanForA11yViolations, test } from '../../avpFixtures.js'; +import { VISUAL_URL } from '../../constants.js'; +import { setBoundsToSpanAllActivities, setDraftStatusForPlan } from '../../helper/planningUtils.js'; + +const examplePlanSmall = JSON.parse( + fs.readFileSync(new URL('../../test-data/examplePlans/ExamplePlan_Small2.json', import.meta.url)) +); const snapshotScope = '.l-shell__pane-main .l-pane__contents'; diff --git a/e2e/tests/visual-a11y/search.visual.spec.js b/e2e/tests/visual-a11y/search.visual.spec.js index a67068f6af..9d2be2215b 100644 --- a/e2e/tests/visual-a11y/search.visual.spec.js +++ b/e2e/tests/visual-a11y/search.visual.spec.js @@ -24,11 +24,11 @@ This test suite is dedicated to tests which verify search functionality. */ -const { test, expect, scanForA11yViolations } = require('../../avpFixtures'); -const { createDomainObjectWithDefaults } = require('../../appActions'); -const { VISUAL_URL } = require('../../constants'); +import percySnapshot from '@percy/playwright'; -const percySnapshot = require('@percy/playwright'); +import { createDomainObjectWithDefaults } from '../../appActions.js'; +import { expect, scanForA11yViolations, test } from '../../avpFixtures.js'; +import { VISUAL_URL } from '../../constants.js'; test.describe('Grand Search @a11y', () => { let conditionWidget; diff --git a/example/dataVisualization/plugin.js b/example/dataVisualization/plugin.js index 9a0ec26755..5519067c97 100644 --- a/example/dataVisualization/plugin.js +++ b/example/dataVisualization/plugin.js @@ -19,7 +19,7 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -import ExampleDataVisualizationSourceViewProvider from './ExampleDataVisualizationSourceViewProvider'; +import ExampleDataVisualizationSourceViewProvider from './ExampleDataVisualizationSourceViewProvider.js'; export default function () { return function install(openmct) { diff --git a/example/eventGenerator/plugin.js b/example/eventGenerator/plugin.js index 6da2c9c670..df395153b0 100644 --- a/example/eventGenerator/plugin.js +++ b/example/eventGenerator/plugin.js @@ -19,8 +19,8 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -import EventMetadataProvider from './EventMetadataProvider'; -import EventTelemetryProvider from './EventTelemetryProvider'; +import EventMetadataProvider from './EventMetadataProvider.js'; +import EventTelemetryProvider from './EventTelemetryProvider.js'; export default function EventGeneratorPlugin(options) { return function install(openmct) { diff --git a/example/eventGenerator/pluginSpec.js b/example/eventGenerator/pluginSpec.js index 2e4caee272..2047446997 100644 --- a/example/eventGenerator/pluginSpec.js +++ b/example/eventGenerator/pluginSpec.js @@ -19,7 +19,7 @@ * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ -import { createOpenMct, resetApplicationState } from '../../src/utils/testing'; +import { createOpenMct, resetApplicationState } from '../../src/utils/testing.js'; import EventMessageGeneratorPlugin from './plugin.js'; describe('the plugin', () => { diff --git a/example/exampleUser/ExampleUserProvider.js b/example/exampleUser/ExampleUserProvider.js index 89f87d0e9c..948f4b7911 100644 --- a/example/exampleUser/ExampleUserProvider.js +++ b/example/exampleUser/ExampleUserProvider.js @@ -23,7 +23,7 @@ import EventEmitter from 'EventEmitter'; import { v4 as uuid } from 'uuid'; -import createExampleUser from './exampleUserCreator'; +import createExampleUser from './exampleUserCreator.js'; const STATUSES = [ { diff --git a/example/exampleUser/plugin.js b/example/exampleUser/plugin.js index ffbcae08ba..a4acbabb96 100644 --- a/example/exampleUser/plugin.js +++ b/example/exampleUser/plugin.js @@ -20,7 +20,7 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import ExampleUserProvider from './ExampleUserProvider'; +import ExampleUserProvider from './ExampleUserProvider.js'; const AUTO_LOGIN_USER = 'mct-user'; const STATUS_ROLES = ['flight', 'driver']; diff --git a/example/exampleUser/pluginSpec.js b/example/exampleUser/pluginSpec.js index 0beddf32b9..d0d1b07cda 100644 --- a/example/exampleUser/pluginSpec.js +++ b/example/exampleUser/pluginSpec.js @@ -20,8 +20,8 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import { createOpenMct, resetApplicationState } from '../../src/utils/testing'; -import ExampleUserProvider from './ExampleUserProvider'; +import { createOpenMct, resetApplicationState } from '../../src/utils/testing.js'; +import ExampleUserProvider from './ExampleUserProvider.js'; describe('The Example User Plugin', () => { let openmct; diff --git a/example/faultManagement/exampleFaultSource.js b/example/faultManagement/exampleFaultSource.js index 20002b5221..d44e40be21 100644 --- a/example/faultManagement/exampleFaultSource.js +++ b/example/faultManagement/exampleFaultSource.js @@ -20,7 +20,7 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import utils from './utils'; +import utils from './utils.js'; export default function (staticFaults = false) { return function install(openmct) { diff --git a/example/faultManagement/pluginSpec.js b/example/faultManagement/pluginSpec.js index fa5e698ea8..d27e608363 100644 --- a/example/faultManagement/pluginSpec.js +++ b/example/faultManagement/pluginSpec.js @@ -20,7 +20,7 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import { createOpenMct, resetApplicationState } from '../../src/utils/testing'; +import { createOpenMct, resetApplicationState } from '../../src/utils/testing.js'; describe('The Example Fault Source Plugin', () => { let openmct; diff --git a/example/generator/GeneratorProvider.js b/example/generator/GeneratorProvider.js index 28b4e91d8c..120af28601 100644 --- a/example/generator/GeneratorProvider.js +++ b/example/generator/GeneratorProvider.js @@ -20,7 +20,7 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import WorkerInterface from './WorkerInterface'; +import WorkerInterface from './WorkerInterface.js'; const REQUEST_DEFAULTS = { amplitude: 1, diff --git a/example/generator/plugin.js b/example/generator/plugin.js index 6f60cd83d4..d78b02341a 100644 --- a/example/generator/plugin.js +++ b/example/generator/plugin.js @@ -20,11 +20,11 @@ * at runtime from the About dialog for additional information. *****************************************************************************/ -import GeneratorMetadataProvider from './GeneratorMetadataProvider'; -import GeneratorProvider from './GeneratorProvider'; -import SinewaveLimitProvider from './SinewaveLimitProvider'; -import SinewaveStalenessProvider from './SinewaveStalenessProvider'; -import StateGeneratorProvider from './StateGeneratorProvider'; +import GeneratorMetadataProvider from './GeneratorMetadataProvider.js'; +import GeneratorProvider from './GeneratorProvider.js'; +import SinewaveLimitProvider from './SinewaveLimitProvider.js'; +import SinewaveStalenessProvider from './SinewaveStalenessProvider.js'; +import StateGeneratorProvider from './StateGeneratorProvider.js'; export default function (openmct) { openmct.types.addType('example.state-generator', { diff --git a/index-test.js b/index-test.cjs similarity index 100% rename from index-test.js rename to index-test.cjs diff --git a/karma.conf.js b/karma.conf.cjs similarity index 92% rename from karma.conf.js rename to karma.conf.cjs index b169af51dd..33e11e3eda 100644 --- a/karma.conf.js +++ b/karma.conf.cjs @@ -22,17 +22,17 @@ /*global module,process*/ -module.exports = (config) => { +module.exports = async (config) => { let webpackConfig; let browsers; let singleRun; if (process.env.KARMA_DEBUG) { - webpackConfig = require('./.webpack/webpack.dev.js'); + webpackConfig = (await import('./.webpack/webpack.dev.js')).default; browsers = ['ChromeDebugging']; singleRun = false; } else { - webpackConfig = require('./.webpack/webpack.coverage.js'); + webpackConfig = (await import('./.webpack/webpack.coverage.js')).default; browsers = ['ChromeHeadless']; singleRun = true; } @@ -45,7 +45,7 @@ module.exports = (config) => { basePath: '', frameworks: ['jasmine', 'webpack'], files: [ - 'index-test.js', + 'index-test.cjs', // included means: should the files be included in the browser using